Отказано в доступе при попытке использовать файл launchd .plist для запуска сценария оболочки - PullRequest
1 голос
/ 14 января 2012

Я пытаюсь создать новый файл агента запуска, который будет выполнять сценарий оболочки для резервного копирования в папку ftp.содержимое файла .plist выглядит следующим образом:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" \
"http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>com.team.backup</string>
    <key>ProgramArguments</key>
    <array>
    <string>/Users/jackm/Documents/Uni/backup.sh</string>
    </array>
    <key>StartCalendarInterval</key>
    <array>
    <dict>
    <key>Hour</key>
    <integer>15</integer>
    <key>Minute</key>
    <integer>30</integer>
    </dict>
    </array>
    <key>StandardErrorPath</key>
    <string>/Users/jackm/Documents/Uni/backup_err.log</string>
</dict>
</plist>

Файл backup.sh выглядит следующим образом:

#!/bin/bash
scp -r username@thehost.co.uk:/the/ftp/folder/      "/Users/jackm/morefolders/Backups/D2 Backup/$(date '+%d-%b-%H:%M')"

Файл backup.sh работает абсолютно нормально при выполнении черезтерминал, спрашивает у меня пароль, затем загружает папку.Однако при использовании launchd у меня даже не запрашивается пароль, я просто получаю следующее в файле журнала ошибок:

Permission denied, please try again.
Permission denied, please try again.
Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).

список launchctl дает plist статус 1. 1. ~ / etc /ssh_config PasswordConfirmation - 1, файл .plist находится в папке launchagents

Cheers

1 Ответ

2 голосов
/ 14 января 2012

При запуске через launchd к вашему сценарию не подключен интерактивный tty, и поэтому он не может запрашивать пароль.Вместо этого вы должны установить аутентификацию с открытым ключом .

...