launchd Chiave UserName non funzionante

0

Quindi sto provando a scrivere un file launchd per eseguire uno script su un Mac Mini come utente specifico quando non sono loggati. Questo è il file plist:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>com.wintr.eodemail</string>
    <key>Program</key>
    <string>/Users/*myusername*/Desktop/testdaemon/testdaemon.sh</string>
    <key>StandardErrorPath</key>
    <string>/var/log/eod-email.log</string>
    <key>StandardOutPath</key>
    <string>/var/log/eod-email.log</string>
    <key>RunAtLoad</key>
    <true/>
    <key>StartCalendarInterval</key>
    <array>
        <dict>
            <key>Minute</key>
            <integer>20</integer>
        </dict>
    </array>
</dict>
</plist>

L'ho inserito in /Library/LaunchDaemons/ e funziona perfettamente come utente root. Funziona esattamente quando lo dico quando nessuno è loggato, tuttavia quando aggiungo la chiave UserName improvvisamente smette di funzionare:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>com.wintr.eodemail</string>
    <key>Program</key>
    <string>/Users/*myusername*/Desktop/testdaemon/testdaemon.sh</string>
    <key>StandardErrorPath</key>
    <string>/var/log/eod-email.log</string>
    <key>StandardOutPath</key>
    <string>/var/log/eod-email.log</string>
    <key>RunAtLoad</key>
    <true/>
    <key>StartCalendarInterval</key>
    <array>
        <dict>
            <key>Minute</key>
            <integer>20</integer>
        </dict>
    </array>
    <key>UserName</key>
    <string>*myusername*</string>
</dict>
</plist>

Quando scarico e carica il file, quindi controlla se è stato caricato correttamente con sudo launchctl list | grep wintr mostra:

-       78      com.wintr.eodemail

E non funziona. Cosa sto facendo di sbagliato qui?

    
posta Nick Welna 22.09.2017 - 23:51
fonte

1 risposta

0

Come sottolineato da fd0, il mio utente non poteva scrivere nella directory /private/var/log , poiché non avevo bisogno dei log ho rimosso le seguenti righe:

<key>StandardErrorPath</key>
<string>/var/log/eod-email.log</string>
<key>StandardOutPath</key>
<string>/var/log/eod-email.log</string>

E ha iniziato a funzionare! Avrei potuto anche cambiarle in una directory in cui il mio utente può scrivere per risolvere il problema.

    
risposta data 25.09.2017 - 23:07
fonte

Leggi altre domande sui tag