Агент запуска не может получить доступ к «защищенным» папкам macOS

#macos #permissions #launch-agent

Вопрос:

У меня есть скрипт оболочки, который делает это:

 #!/bin/bash

ls -la "$HOME/Pictures/Photos Library.photoslibrary"

 

Когда я запускаю этот скрипт в оболочке, он работает нормально. Если я определю агент запуска (в разделе $HOME/Library/LaunchAgents ), который выполняет этот сценарий, я получу следующее сообщение об ошибке:

 ls: Photos Library.photoslibrary: Operation not permitted
 

Мой реальный скрипт вызывает HashBackup ( hb ), Что приводит к одной и той же ошибке во всех этих «защищенных» папках (фотографии, адресная книга и т. Д.). Но я смог воспроизвести с помощью простого ls .

Что я должен сделать, чтобы это исправить?

Это на macOS 10.14.6.

Спасибо

Комментарии:

1. Решает ли проблему какой-либо из ответов на этот вопрос, задающий другой вопрос ?

2. Спасибо @GordonDavisson, так как вопрос, на который вы ссылаетесь, — это явно то, о чем я спрашивал.

Ответ №1:

Благодаря комментарию Гордона я смог выполнить действия и исправить свою проблему. Шаги, которые на самом деле сработали для меня, заключаются в следующем.

Для более полного решения, вот небольшое решение на основе CMake:

  1. main.cpp
 #include <iostream>

int main()
{
  std::cout << "Wrapper app which is authorized for full disk access so that the shell script can run with the same permission" << std::endl;
  return 0;
}
 
  1. backup_argon.sh
 #!/bin/bash

# this is just a test... it should invoke hb instead
ls -la "$HOME/Pictures/Photos Library.photoslibrary"
 
  1. Info.plist.in
 <?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>CFBundleDevelopmentRegion</key>
    <string>English</string>
    <key>CFBundleExecutable</key>
    <string>${MACOSX_BUNDLE_EXECUTABLE_NAME}</string>
    <key>CFBundleIconFile</key>
    <string>${MACOSX_BUNDLE_ICON_FILE}</string>
    <key>CFBundleIdentifier</key>
    <string>${MACOSX_BUNDLE_GUI_IDENTIFIER}</string>
    <key>CFBundleInfoDictionaryVersion</key>
    <string>6.0</string>
    <key>CFBundleName</key>
    <string>${MACOSX_BUNDLE_BUNDLE_NAME}</string>
    <key>CFBundlePackageType</key>
    <string>APPL</string>
    <key>CFBundleShortVersionString</key>
    <string>${MACOSX_BUNDLE_SHORT_VERSION_STRING}</string>
    <key>CFBundleSignature</key>
    <string>????</string>
    <key>CFBundleVersion</key>
    <string>${MACOSX_BUNDLE_BUNDLE_VERSION}</string>
    <key>CSResourcesFileMapped</key>
    <true/>
    <key>NSHumanReadableCopyright</key>
    <string>${MACOSX_BUNDLE_COPYRIGHT}</string>
    <key>LSUIElement</key>
    <true/>
    </dict>
</plist>
 
  1. CMakeLists.txt
 cmake_minimum_required(VERSION 3.19)

set(VERSION 1.0.0)

project(HashBackupLaunchAgent VERSION "${VERSION}")

set(CMAKE_CXX_STANDARD 17)

set(MACOSX_BUNDLE_BUNDLE_NAME "HashBackupLaunchAgent")
set(MACOSX_BUNDLE_GUI_IDENTIFIER "com.pongasoft.HashBackupLaunchAgent")
set(MACOSX_BUNDLE_SHORT_VERSION_STRING "${VERSION}")
set(MACOSX_BUNDLE_BUNDLE_VERSION "${VERSION}")
set(MACOSX_BUNDLE_COPYRIGHT "2021 pongasoft")

add_executable(HashBackupLaunchAgent MACOSX_BUNDLE main.cpp backup_argon.sh)

set_target_properties(HashBackupLaunchAgent PROPERTIES MACOSX_BUNDLE_INFO_PLIST "${CMAKE_CURRENT_LIST_DIR}/Info.plist.in")

set_source_files_properties(backup_argon.sh PROPERTIES MACOSX_PACKAGE_LOCATION MacOS)
 

Компиляция этого проекта приведет к созданию приложения ( HashBackupLaunchAgent.app ), под которым я скопировал /Applications .

Затем я предоставил Full Disk Access привилегию этому приложению под System Preferences/Security amp; Privacy/ Privacy

Затем у меня есть агент запуска со следующим определением:

 <?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.ypujante.hashbackup.argon.plist</string>

    <key>EnvironmentVariables</key>
      <dict>
        <key>PATH</key>
        <string>/bin:/usr/bin:/usr/local/bin</string>
      </dict>

    <key>ProgramArguments</key>
    <array>
        <string>/Applications/HashBackupLaunchAgent.app/Contents/MacOS/backup_argon.sh</string>
    </array>

    <key>StandardOutPath</key>
    <string>/Users/ypujante/Library/Logs/HashBackup/argon.log</string>
    <key>StandardErrorPath</key>
    <string>/Users/ypujante/Library/Logs/HashBackup/argon.log</string>
    <key>StartCalendarInterval</key>
    <array>
      <dict>
          <key>Hour</key>
          <integer>7</integer>
          <key>Minute</key>
          <integer>30</integer>
      </dict>
    </array>
  </dict>
</plist>
 

Обратите внимание, как определение агента запуска вызывает сценарий внутри приложения, а не само приложение. И это работает: скрипт наследует привилегию полного доступа к диску, предоставленную приложению.