iCloudKV

Cordova iCloud Key Value Plugin
pierrickrouxel0.1.04
platforms: ios
$ cordova plugin add fr.pierrickrouxel.iCloudKV

phonegap-icloudkv-plugin

iOS iCloud KeyValue Store plugin for PhoneGap

Allows storing small amounts of configuration data in iCloud from Cordova/PhoneGap. Wraps NSUbiquitousKeyValueStore class.

Compatibility

Cordova/PhoneGap >= 3.0

Adding the plugin to your project

cordova plugin add http://github.com/pierrickrouxel/phonegap-icloudkv-plugin

Using the plugin

Import iCloudKV.js

<script src="iCloudKV.js" type="text/javascript"></script>

The plugin creates the object iCloudKV with the following methods:

sync(successCallback/*(dictionary_with_all_sync_keys)*/ , failCallback) 
   In addition to calling NSUbiquitousKeyValueStore sync method the plugin's sync returns the dictionary holding all iCloud data for the app.
   Normally you only need to call the sync once - on application load. 
   Reminder: Calling sync does not guarantee (or matter for) syncrhonization with iCloud but only between the in-memory and the flash storage that will be eventually synced with iCloud by an independent agent.

save(key, value, successCallback) 
   Saves string value for the key.

load(key, successCallback/*(value)*/, failCallback) 
   Loads string value for the key.

remove(key, successCallback) 
    Removes the key. 

monitor(notificationCallback/*(value)*/, successCallback) 
    Monitor changes of the app's iCloud.

For the simplest (but probably sufficient for most apps) implementation you will only need two methods: sync (on page load) and save (each time a value is changed).

Thanks

Special thanks to Alex Drel who create the plugin for PhoneGap 2.

Bugs and contributions

If you have a patch, fork my repo and send me a pull request. Submit bug reports on GitHub, please.