iOS 8 revealed a new API yesterday concerning App Groups. It was kind of messy before to share data and communicate between apps and I believe that's precisely what App Groups is intended to correct.
In my app I have enabled App Groups and added a new group but I just can't find any documentation on how to use it. Documentation and API references only state how to add a group.
So what is App Groups really intended to do? Is there any documentation somewhere on how to use it?
Another benefit to App Groups is the ability to share a
NSUserDefaults
database. This also works for App Extensions (notification center widgets, custom keyboards, etc).Initialize your
NSUserDefaults
object like this in all applications in the app group and they will share the database:Objective-C:
Swift:
Keep in mind everything from the
[NSUserDefaults standardUserDefaults]
database for each application will not carry over into this database.The documentation gives a correct example as well (As of Beta 3).
And don't forget to synchronize the database:
To store
Application groups, according to my interpretation of the existing documentation, are primarily targeted for extensions, more specifically, for widgets. Widgets are their own application bundle that coexist with your app. Since they are a separate application and therefore have their own sandbox, you will need to use App Groups to share files.
After some header grep'ing, I think I found the API needed, but was actually put in as part of iOS 7.
NSFileManager
has a method on itcontainerURLForSecurityApplicationGroupIdentifier:
where you can pass in the identifier you created when turning on App Groups for your apps:One important trap I tapped into today is the following:
In many projects I saw a single app target and with different bundle identifiers set for each configuration of that target. Here things get messy. What the developers intended was to create a debug app for the debug config and a production app for the release target.
If you do so both apps will share the same NSUserDefaults when they are set up like so
This causes problems in many places:
The solution to this problem in general is to prefix the defaults keys with the current configuration built. You can detect the configuration easily at runtime by setting different bundle identifiers for your configurations. Then just read the bundle identifier from
NSBundle.mainBundle()
. If you have the same bundle identifiers you need to set different preprocessor macros likeIn Swift it will look almost the same:
Sharing NSUserDefaults data between multiple apps
In order to have shared defaults between an app and an extension or between 2 apps you have to add an App Group in your settings using the following steps:
Note: If you go to the Apple Developer Portal (the Apple website that shows all of your Certificates, Identifiers, Devices and Provisioning Profiles) and go to Identifiers > App Groups you should see this new App Group.
To store data:
To retrieve data: