【发布时间】:2016-07-16 04:32:55
【问题描述】:
我在 Mac OSX 上使用 Objective C 制作的基于 Cocoa 的自定义 setup.app 需要安装 LaunchDaemon 来执行提升权限的任务,例如需要扫描整个硬盘驱动器并因此需要 root 权限的防病毒程序。如何让我的设置应用程序提示客户进行管理员登录,然后将该 LaunchDaemon 安装到 /Library/LaunchDaemons 中(注意我不是指 ~/Library/LaunchDaemons)?
我目前处理它的方式是使用具有管理员权限的 AppleScript。它提示此登录,然后 AppleScript 将复制到此文件夹中,而操作系统不会抱怨。但是,我认为这不是正确的技术——我应该以某种方式完全在 Objective C 中执行此操作?
请注意,在这种情况下我不能使用 SMBlessJob,因为正是出于这个原因,我首先创建了启动守护程序。
背景信息
我特别需要创建一个自定义 setup.app——就像诺顿的 AV 应用程序使用自定义 setup.app 一样。这是因为 Apple PKG 和 DMG 安装程序不允许在安装过程中从服务器下载非常大的文件(如病毒定义)并提供某种友好的反馈。我的意思是,当运行 Perl 脚本或 Bash 脚本时,我可以让 PKG 文件从服务器下载文件,但是安装程序只会在下载所需的分钟数内挂起进度条,而不给任何其他反馈用户除了挂起的进度条,所以用户认为安装程序坏了,其实不是。这就是为什么我必须制作自己的自定义 setup.app,就像 Norton 为他们的 AV 应用程序所做的那样。
【问题讨论】:
-
当用户提供其凭据时,用户安装的 pkg 将获得管理员权限。它还可以包含安装前和安装后脚本。使用包安装程序中的脚本来安装守护进程,复制相关的 plist 并开始运行。
-
但这会卡在需要 10 分钟的非常大的下载中。它有效,但对于正在发生的事情提供了较差的可见进展。试试看,你会看到的。这就是我制作自定义设置应用程序的原因,就像 Symantec/Norton 对他们的应用程序所做的那样。
-
我不建议使用脚本下载,而是安装守护程序应用程序,然后它会为您下载。
标签: objective-c macos installation elevated-privileges launch-daemon