Незнание пароля усложняет задачу , но, возможно, решение таково: возможно ли временно удалить пароль пользователя? (И впоследствии сбросьте его на то, что было раньше.)
Для начала:
Сначала получите окно входа для отображения. Просто выйдите из текущего пользователя, используйте быстрое переключение пользователей или используйте SSH:
cd "/ Система / Библиотека / CoreServices / Дополнения меню / User.menu / Содержание / Ресурсы /"
sudo ./CGSession -suspend
Или, чтобы сразу переключиться на конкретного пользователя, который, вероятно, покажет окно входа в систему (это внезапно больше не работает на моем 10.5 Leopard):
sudo ./CGSession -switchToUserID 501
То, что показано сейчас, немного зависит от системных настроек, но давайте предположим, что это значки пользователей и их имена. Чтобы активировать имя, мы должны ввести первые буквы. Затем после возврата отображается запрос пароля. В качестве альтернативы можно выбрать любое имя (например, нажав стрелку вниз), а затем нажать Option-Return, чтобы запросить любое имя пользователя и его пароль. Я не знаю, как можно определить, какой экран отображается, но давайте сохраним это на потом ...
Итак, чтобы выбрать первое (случайное) имя пользователя и нажать Option-Return, введите определенное имя пользователя, нажмите Return и введите пароль:
sudo osascript -e 'сказать приложение "Системные события"
код ключа 125
возврат нажатия клавиши, используя опцию вниз
нажатие клавиши "имя пользователя"
задержка 1,0
возврат клавиши
задержка 1,0
нажатие клавиши "пароль"
задержка 1,0
возврат клавиши
конец сказать
Выше показана некоторая ошибка, которая, насколько я могу судить, не ограничивает использование:
osascript [285]: 3891612: (connectAndCheck) Ненадежные приложения не являются
разрешено подключаться или запускать Window Server перед входом в систему.
_RegisterApplication (), НЕ удалось установить соединение по умолчанию с
WindowServer, _CGSDefaultConnection () имеет значение NULL.
В качестве альтернативы используйте скрипт для конкретного языка из « Сценарий окна входа через Apple Remote Desktop » (возможно, однажды комментарии на этом сайте покажут лучшее решение):
расскажите процесс "SecurityAgent"
установить значение текстового поля 1 группы 1 окна 1 равным «имени пользователя»
установить значение текстового поля 2 группы 1 окна 1 равным «паролю»
конец сказать
нажмите кнопку «Войти» в окне 1 процесса приложения «SecurityAgent»
Но главная проблема в том, что для этого еще нужен пароль . Однако: очевидно, что пароль не требуется, когда у пользователя есть пустой пароль. На самом деле, для пустых паролей достаточно просто щелкнуть значок пользователя. Итак, если отправка нажатий клавиш с помощью AppleScript является приемлемой, то, возможно, «все», что осталось выяснить:
Можно ли временно удалить пароль пользователя, чтобы разрешить запуск (или возобновление) сеанса, не зная этого пароля ...?
Можно ли сделать AppleScript защищенным от ошибок? Подобно:
- Как сказать , если окно Логин виден? (возможно,
stat -f%Su /dev/console
может помочь, так как это дает,root
пока отображается окно входа в систему)
- Как узнать, какое окно входа отображается? (Например: один показывает значки и имена для входа, или выпадающий список, или, может быть, только запрос пароля, если кто-то выбрал переключение на какого-то конкретного пользователя?)
- Избавиться от задержек.
- Как насчет этого сообщения об ошибке?
(Примечание для тестирования: при использовании общего доступа к экрану кажется, что установка предпочтения При управлении компьютерами: шифровать пароли и нажатия клавиш также сохраняет соединение только при отображении окна входа в систему или после успешного входа пользователя в систему. При использовании шифрования всей сети данные затем мой Mac необходимо повторно установить соединение совместного использования экрана каждый раз , когда Войти отображаются или пользователь коммутируемый.)