Как включить и отладить расширение поставщика файлов macOS?

Я пытаюсь создать базовое приложение с Xcode 12.5 Beta 3 на macOS Big Sur 11.2.2 с расширением поставщика файлов. Я использую бета-версию Xcode, потому что предыдущие версии не предоставляют шаблон для расширений поставщика файлов (пример проекта на GitHub).

Приложение и его расширение имеют общую группу приложений, настроенную в их правах, и автоматически подписываются моей личной командой и сертификатом разработки.

Я создал и запустил свое приложение и расширение. Но, насколько я знаю, теперь я могу контролировать, когда он (раз)загружается, потому что это зависит от системы.

Наблюдения

  1. Расширение поставщика файлов никогда не отображается в системных настройках.
  2. Консольное приложение не предоставляет никакой значимой информации с отдельным именем проекта, кроме lsd (LaunchServices), проверяющего, является ли приложение управляемым.
  3. Расширение не отображается в мониторе активности.
  4. Pluginkit сообщает, что расширение найдено, но добавляет восклицательный знак (при запуске pluginkit -vvvvmi SomeOrganization.SomeProduct.SomeProvider).
$ pluginkit -vvvvmi SomeOrganization.SomeProduct.SomeProvider                                                                                       
!    SomeOrganization.SomeProduct.SomeProvider(1.0)
                Path = /Users/peter/Library/Developer/Xcode/DerivedData/SomeProduct-gyyunhpcbweleidtluxpslpciwjj/Build/Products/Debug/SomeProduct.app/Contents/PlugIns/SomeProvider.appex
                UUID = E2FDC7AB-3CDD-4AEE-A2B2-CC2BA0CBC409
           Timestamp = 2021-03-09 16:49:57 +0000
                 SDK = com.apple.fileprovider-nonui
       Parent Bundle = /Users/peter/Library/Developer/Xcode/DerivedData/SomeProduct-gyyunhpcbweleidtluxpslpciwjj/Build/Products/Debug/SomeProduct.app
        Display Name = SomeProvider
          Short Name = SomeProvider
         Parent Name = SomeProduct

 (1 plug-in)
  1. Фильтруя системную консоль с помощью подсистемы com.apple.FileProvider, я натыкаюсь на эти сообщения после создания расширения (мне пришлось раскрыть частные значения как описано в этом ответе< /а>):
[ERROR] could not load the domain properties
[WARNING] found directory with no domain plist in it: ~/L{5}y/A{17}t/F{10}r/S{26}t.SomeProvider

Есть также два других о PhotosFileProvider и com.apple.CloudDocs.MobileDocumentsFileProvider, которые (я думаю) не связаны. PhotosFileProvider сообщает о том же предупреждении. Указанный выше путь можно расширить до:

~/Library/Application Support/FileProvider/SomeOrganization.SomeProduct.SomeProvider

который содержит Domains.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>NSFileProviderDomainDefaultIdentifier</key>
    <dict>
        <key>Connected</key>
        <false/>
        <key>Enabled</key>
        <false/>
    </dict>
</dict>
</plist>

Проблема

Я не нашел ничего о значении восклицательного знака или о том, как узнать, в чем собственно проблема. Как я могу отладить это? Ошибка в Консоли подозрительно торчит. Мне кажется, что мне не хватает какой-то части головоломки, которая не упоминается в документации, как секретный шаг в инструкции.

Для справки: мой вопрос на форумах разработчиков Apple.


person Peter    schedule 09.03.2021    source источник
comment
Я отправляю Strongsync, который является поставщиком файлов (и работаю над ним с июля прошлого года). . Рад немного помочь. Мне немного непонятно, почему ваше расширение не загружается. 1. проверьте поток журнала журнала -predicate 'subsystem == com.apple.FileProvider' 2. загляните в файл fileproviderctl, который находится на вашем компьютере. 3. Не стесняйтесь загружать Strongsync и просматривать сделанные записи plist.   -  person hemancuso    schedule 11.03.2021
comment
Спасибо за подсказки, @hemancuso - я обновил свои наблюдения. Я просмотрел документы Info.plist в Strongsync, но пока не нашел ничего многообещающего. fileproviderctl кажется полезным, когда расширение действительно загружено.   -  person Peter    schedule 15.03.2021
comment
Может ли моя проблема быть связана с правами на связанные домены, @hemancuso? У вас есть такая настройка для вашего продукта?   -  person Peter    schedule 19.03.2021


Ответы (1)


Вы звоните +[NSFileProviderManager addDomain:completionHandler:] из своего приложения? https://developer.apple.com/documentation/fileprovider/nsfileprovidermanager/2890934-adddomain?language=objc

В macOS, в отличие от iOS, не существует домена FileProvider по умолчанию, созданного системой. Ваше приложение должно явно регистрировать домены.

person Chris Lenart    schedule 25.03.2021
comment
Я еще не сделал. Спасибо! Теперь я также могу отлаживать работающее расширение. Я никогда не сталкивался с этим шагом в своем исследовании. - person Peter; 25.03.2021