1

サンドボックス化された AppKit アプリから Automator ワークフローを実行しようとしています。

最小限の例 + github リポジトリ:

   NSOpenPanel * panel = [NSOpenPanel openPanel];
   [panel setAllowsMultipleSelection:NO];
   [panel setCanChooseFiles:YES];
   [panel setCanChooseDirectories:NO];
   [panel setAllowedFileTypes:[NSArray arrayWithObject: @"com.apple.automator-workflow"]];
    NSInteger result = [panel runModal];

    if (result == NSFileHandlingPanelOKButton) {
      NSURL * workflow = [[panel URLs]objectAtIndex:0];
      NSLog(@"selected url %@", workflow);
      NSError * error = nil;
      [AMWorkflow runWorkflowAtURL:workflow withInput:[NSArray arrayWithObject:workflow] error:&error];
      if(error) {
          NSLog(@"Error while executing workflow %@", [error localizedDescription]);
      }        
    }

AMWorkflow API に関する私の現在の理解から、Mach IPC を使用して別の Automator Runner プロセスでワークフローを実行すると仮定します。

これが、アプリに次の資格を追加した理由です。

   <key>com.apple.security.temporary-exception.mach-lookup.global-name</key>
   <array>
     <string>com.apple.AutomatorRunner</string>
     <string>com.apple.Automator</string>
   </array>

しかし、どうやら Automator Runner は呼び出し元のアプリに接続しようとして失敗し、次のエラー メッセージが表示されます。

Automator Runner(2717) deny mach-lookup  /Users/pbrc/Library/Developer/Xcode/DerivedData/AMWorkflowCaller-arjgkslqihljquelyvybmpsnljrn/Build/Products/Debug/AMWorkf

0   libsystem_kernel.dylib          0x00007fff96ce9686 mach_msg_trap + 10
1   liblaunch.dylib                 0x00007fff8db637c4
2   liblaunch.dylib                 0x00007fff8db624d9 bootstrap_look_up3 + 69
3   liblaunch.dylib                 0x00007fff8db62609 bootstrap_look_up2 + 40
4   Foundation                      0x00007fff8f4acffe -[NSMachBootstrapServer portForName:options:] + 102
5   Foundation                      0x00007fff8f4b84cb +[NSConnection connectionWithRegisteredName:host:usingNameServer:] + 30
6   Automator Runner                0x0000000100001a51 -[AMRunnerDelegate processArguments] + 487

何か案は?

4

1 に答える 1

2

簡単な答えは、AMWorkflowAPIはサンドボックス化されたアプリケーションでは機能しないということです。最近導入された代替APIがあり、サンドボックス化されたアプリケーションで機能します。

NSUserAutomatorTask executeWithInput:completionHandler:

このAPIを使用すると、アプリケーションのスクリプトフォルダーにあるオートマタースクリプトを実行できます。

/Users/USERNAME/Library/Application Scripts / BUNDLENAME.APPNAME

重要な注意点が1つあります。メソッドの「input」引数にもかかわらず、10.8.312D75より前のバージョンのMacOSでは入力がAutomatorワークフローに渡されません(これはバグです)。

NSUserAutomatorTask * task = [[NSUserAutomatorTask alloc] initWithURL:workflow error:&error];
if(error) {
    NSLog(@"Error while creating script task %@", [error localizedDescription]);
}

[task executeWithInput: @"this will never reach your workflow" completionHandler:^(id result, NSError *error){
    if(error)
        NSLog(@"Error while executing workflow %@", [error localizedDescription]);
}];
于 2012-11-11T08:50:14.257 に答える