CloudKitPy - A python wrapper around CloudKit Web Services for server-to-server connections.
This project is still under initial development. This means parts of it may incomplete or not fully tested in it's current state, and probably shouldn't not yet be used in production projects yet.
CloudKitPy is built to be a wrapper around CloudKit Web Services, similar to how CloudKit JS is. Because of this it has been designed around the native framework and CloudKit JS's structure to allow ease of transition between platforms.
Before you can make connection to CloudKit you must first setup CloudKit via an iOS or OS X app. Also, you need to have created a server-to-server key and set it in the CloudKit dashboard for your app. For more details on both of these steps, please refer to Apple's Documentation.
This framework is based on Python 2.7 (with plans to add support for Python 3.4 and 3.5 in the future).
To install CloudKitPy follow the steps below:
- cdinto the root directory via the terminal,
- Run python setup.py install
- You're installed! Just add import cloudkitpyinto your project to get started.
Note: In the future I am planning to submit this to allow installation via pip. However I want this framework to be a lot more fleshed out before I do that.
To setup a CloudKit instance to connect to CloudKit, use the following code:
from cloudkitpy.ckdatatypes import ContainerConfig
from cloudkitpy.ckdatatypes import CloudKitConfig
from cloudkitpy.cloudkit import CloudKit
my_container = ContainerConfig(
    '<your container id>',
    CloudKit.DEVELOPMENT_ENVIRONMENT,   # Or CloudKit.PRODUCTION_ENVIRONMENT for production
    server_to_server_key='<your server-to-server key id>',
    cert_path='<path to your private key>'
)
cloudkit_config = CloudKitConfig([my_container])
ck = CloudKit(cloudkit_config)
container = ck.get_default_container()Now to get the current user and print it's record name, all you have to do is:
result = container.fetch_user_info()
if result.is_success is True:
    print result.value.user_record_nameFurther examples for setup and basic container and database operations can be found in the Wiki.
If you would like to contribute, please create an issue first before creating a pull request, just incase I am already working on that part of the project.
- Create wrappers for base parts of the CloudKit framework (data types, containers, databases and configuring)
- Implement an error handling system and logging
- [IN PROGRESS] Create Example Code
- Add support for Python 3.4 and 3.5
- Continue with further wrappers for remaining parts of CloudKit
- Upload and download assets
- Expand Example Code
- Async Callbacks
- Expand for API usage for non-server-to-server usage
- Comprehensive Unit Test Coverage
- Complete Documentation
Below is listed the sections of CloudKit that are being created in CloudKitPy. This is a continuous list and will be added to and updated as development continues.
-  CloudKit
- Configuration
- Container Management
- Constants
 
-  Data Types
- Asset
- Filter
- Location
- Notification Info
- Query
- Record
- Reference
- Sort Descriptor
- Subscription
- User Info
- Zone
- Zone ID
- CloutKit Config
- Container Config
 
-  CKValue (mostly implemented, needs some expansion of typebut the basic principle works)
- CKError
-  Container
- Configuration
- Private and Public database creation
- Discovering Users
 
-  Database
- Accessing Records
- Syncing Records
- Accessing Record Zones
 
- [IN PROGRESS] Records Batch Builder
-  Response
-  Record Zones Response
- Changed Records Response
- Query Response
 
- Subscriptions Response
- User Info Response
 
-  Record Zones Response