From cfe6244f8954efce4ef12b9b4338cc0d41a9ff40 Mon Sep 17 00:00:00 2001 From: Bryan Forbes Date: Wed, 17 Mar 2010 01:12:52 -0500 Subject: Moved everything but iDevice and LockdownClient to pxi files. Added MobileBackupClient and PropertyListService. --- cython/mobilebackup.pxi | 54 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 cython/mobilebackup.pxi (limited to 'cython/mobilebackup.pxi') diff --git a/cython/mobilebackup.pxi b/cython/mobilebackup.pxi new file mode 100644 index 0000000..2bbaebe --- /dev/null +++ b/cython/mobilebackup.pxi @@ -0,0 +1,54 @@ +cdef extern from "libimobiledevice/mobilebackup.h": + cdef struct mobilebackup_client_int: + pass + ctypedef mobilebackup_client_int *mobilebackup_client_t + + ctypedef int16_t mobilebackup_error_t + int16_t MOBILEBACKUP_E_SUCCESS + int16_t MOBILEBACKUP_E_INVALID_ARG + int16_t MOBILEBACKUP_E_PLIST_ERROR + int16_t MOBILEBACKUP_E_MUX_ERROR + int16_t MOBILEBACKUP_E_BAD_VERSION + int16_t MOBILEBACKUP_E_UNKNOWN_ERROR + + mobilebackup_error_t mobilebackup_client_new(idevice_t device, uint16_t port, mobilebackup_client_t * client) + mobilebackup_error_t mobilebackup_client_free(mobilebackup_client_t client) + mobilebackup_error_t mobilebackup_receive(mobilebackup_client_t client, plist.plist_t *plist) + mobilebackup_error_t mobilebackup_send(mobilebackup_client_t client, plist.plist_t plist) + +cdef class MobileBackupError(BaseError): + def __init__(self, *args, **kwargs): + self._lookup_table = { + MOBILEBACKUP_E_SUCCESS: "Success", + MOBILEBACKUP_E_INVALID_ARG: "Invalid argument", + MOBILEBACKUP_E_PLIST_ERROR: "PList Error", + MOBILEBACKUP_E_MUX_ERROR: "MUX Error", + MOBILEBACKUP_E_BAD_VERSION: "Bad Version", + MOBILEBACKUP_E_UNKNOWN_ERROR: "Unknown error" + } + BaseError.__init__(self, *args, **kwargs) + +cdef class MobileBackupClient(PropertyListService): + cdef mobilebackup_client_t _c_client + + def __cinit__(self, iDevice device not None, LockdownClient lockdown=None, *args, **kwargs): + cdef iDevice dev = device + cdef LockdownClient lckd + if lockdown is None: + lckd = LockdownClient(dev) + else: + lckd = lockdown + port = lckd.start_service("com.apple.mobilebackup") + err = MobileBackupError(mobilebackup_client_new(dev._c_dev, port, &self._c_client)) + if err: raise err + + def __dealloc__(self): + if self._c_client is not NULL: + err = MobileBackupError(mobilebackup_client_free(self._c_client)) + if err: raise err + + cdef _send(self, plist.plist_t node): + return MobileBackupError(mobilebackup_send(self._c_client, node)) + + cdef _receive(self, plist.plist_t* node): + return MobileBackupError(mobilebackup_receive(self._c_client, node)) -- cgit v1.1-32-gdbae