Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SIP on Sierra blocks changes to the accessibility database #51

Open
hb3b opened this issue Jan 30, 2017 · 7 comments
Open

SIP on Sierra blocks changes to the accessibility database #51

hb3b opened this issue Jan 30, 2017 · 7 comments

Comments

@hb3b
Copy link

hb3b commented Jan 30, 2017

ERROR: OperationalError: attempt to write a readonly database

@uurazzle
Copy link

Hello hb3b:

Here is a workaround the issue...

sudo launchctl unload /System/Library/LaunchDaemons/com.apple.locationd.plist
sudo /usr/libexec/PlistBuddy -c "Set :com.apple.locationd.bundle-/System/Library/PrivateFrameworks/AssistantServices.framework:Authorized true" /var/db/locationd/clients.plist
sudo launchctl load /System/Library/LaunchDaemons/com.apple.locationd.plist

@uurazzle
Copy link

uurazzle commented Jan 30, 2017 via email

@dhoer
Copy link

dhoer commented Feb 12, 2017

I tried this and it didn't work:
https://github.com/dhoer/chef-privacy_services_manager/blob/sierra/providers/default.rb#L25-L38

Error:
https://travis-ci.org/dhoer/chef-privacy_services_manager/jobs/200815034#L406

Any advice on what to try to resolve this SIP issue would be welcomed.

@uurazzle
Copy link

Currently, with macOS Sierra, you have a couple options, modify the TCC database booted from another system like during imaging, others are doing this. Or disable SIP temporarily to make changes using like using a NetInstall to disable/enable SIP and make modification to the TCC database when SIP is disabled. I would recommend sending Apple feedback to include the ability to set items like this via Configuration Profiles.

@uurazzle
Copy link

FYI:

Here is one workaround the SIP restrictions, not sure this will work for your environment or system management, but...

  • Boot to Recovery HD
  • From Terminal, run the following commands:
    $ cd /Volumes/Macintosh\ HD/Library/Application\ Support/
    $ cp -R com.apple.TCC TCC
    $ rm -r com.apple.TCC
    $ mv TCC com.apple.TCC
    $ reboot

Once rebooted, no restrictions will be on the TCC.db even while SIP is enabled.

You might be able to create a NetInstall script that does the above steps that could be include in a imaging process.

Hope this helps.

@dhoer
Copy link

dhoer commented Feb 15, 2017

Thank you for the help!

@uurazzle
Copy link

uurazzle commented Feb 15, 2017

Note, this workaround might go away in a future OS upgrade. I would recommend filing a radar to support this functionality using a configuration profile. It's because the folder in question is only set one time via rootless.conf and it's not part of the current core to perpetually protected paths. So if you strip the flag post OS install, then it stays stripped. A major or minor OS update in the future can repair/re-set it.

https://pbs.twimg.com/media/C4qki5zVMAAKLMf.jpg

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants