我可以在沙盒 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与设备通信。
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与设备通信。