我可以在沙盒 macOS 应用程序中使用 Peertalk 或 usbmuxd 吗?

Can I use Peertalk or usbmuxd in a sandboxed macOS app?

Peertalk 是一个库,它通过 lightning/USB 电缆提供 mac 和 iOS 设备之间的通信。它通过这样做建立连接:

  struct sockaddr_un addr;
  addr.sun_family = AF_UNIX;
  strcpy(addr.sun_path, "/var/run/usbmuxd");
  socklen_t socklen = sizeof(addr);
  if (connect(fd, (struct sockaddr*)&addr, socklen) == -1) {
    if (error) *error = [[NSError alloc] initWithDomain:NSPOSIXErrorDomain code:errno userInfo:nil];
    return NO;
  }

这在非沙盒应用中没有问题。在沙盒应用程序中,即使允许网络和 USB,它也会失败并显示 errno EPERM - Operation Not Permitted.

有什么方法可以让它在沙盒 Mac 应用程序中工作?


更新:

.entitlements 添加临时例外无效:

<?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>com.apple.security.app-sandbox</key>
    <true/>
    <key>com.apple.security.network.client</key>
    <true/>
    <key>com.apple.security.network.server</key>
    <true/>
    <key>com.apple.security.temporary-exception.files.absolute-path.read-write</key>
    <string>/var/run/usbmuxd</string>
</dict>
</plist>

不,这不可能。

我最终想到的解决方案是一个中继应用程序,用户可以手动下载并安装为非沙盒应用程序。主应用通过网络环回地址与中继通信,然后中继通过usbmuxd与设备通信。