TICDSDocumentSyncManager Class Reference
Inherits from | NSObject |
Conforms to | TICDSDocumentRegistrationOperationDelegate TICDSSynchronizationOperationDelegate |
Declared in | TICDSDocumentSyncManager.h |
Overview
TICDSDocumentSyncManager
describes the generic behavior provided by a Document Sync Manager in the TICoreDataSync
framework.
A Document Sync Manager is responsible for synchronization settings relating to a single document—you’ll need one for each document you wish to synchronize. If your application is a non-document-based application, you’ll still need a single document sync manager to represent your application’s data.
Don’t instantiate this class directly, but instead use one of the subclasses:
You must register the document sync manager before you can use it to synchronize the document, or perform any other tasks.
Tasks
One-Shot Document Registration
-
– registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
Register a document ready for synchronization.
Delayed Document Registration
-
– configureWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
Configure a document but don’t immediately register it.
-
– registerConfiguredDocumentSyncManager
Register a document that has already been pre-configured.
General Registration
-
– continueRegistrationByCreatingRemoteFileStructure:
Continue Registration.
-
– preConfigureWithDelegate:appSyncManager:documentIdentifier:
Pre-configure a sync manager for a document that’s just been downloaded, but without carrying out full registration.
-
– addManagedObjectContext:
Add an additional background managed object context to this document sync manager.
Whole Store Upload and Download
-
– initiateUploadOfWholeStore
Start the process manually to upload the entire store file for this document, along with the relevant
AppliedSyncChanges.ticdsync
file. -
– initiateDownloadOfWholeStore
Start the process to download the entire store file for this document, along with the relevant
AppliedSyncChanges.ticdsync
file.
Synchronization Process
-
– initiateSynchronization
Start synchronizing the document with the remote location.
-
– continueSynchronizationByResolvingConflictWithResolutionType:
If a conflict is encountered during synchronization, your delegate will be notified with the
solveConflict:
method. You must decide whether the remote or localSyncChange
wins, and inform the document sync manager using this method to continue synchronization.
Vacuuming Unneeded Files
-
– initiateVacuumOfUnneededRemoteFiles
Initiate a vacuum operation to clean up files hanging around on the remote that are no longer needed by any registered clients.
Information on Registered Clients
-
– requestInformationForAllRegisteredDevices
Fetch a list of devices that are registered to synchronize with this client.
Deleting Clients from a Document
-
– deleteDocumentSynchronizationDataForClientWithIdentifier:
Delete the files used by a client to synchronize with this document.
Methods Overridden by Subclasses
-
– documentRegistrationOperation
Returns a document registration operation.
-
– wholeStoreUploadOperation
Returns a whole store upload operation.
-
– wholeStoreDownloadOperation
Returns a whole store download operation.
-
– synchronizationOperation
Returns a synchronization operation.
-
– vacuumOperation
Returns a vacuum operation.
-
– listOfDocumentRegisteredClientsOperation
Returns a “list of registered clients for this document” operation.
-
– documentClientDeletionOperation
Returns a “deletion of client synchronization data from a document” operation.
Managed Object Context Saving
-
– synchronizedMOCWillSave:
Indicate that the synchronized managed object context is about to save.
-
– synchronizedMOCDidSave:
Indicate that the synchronized managed object context completed a successful save.
-
– synchronizedMOCFailedToSave:withError:
Indicate that the synchronized managed object context failed to save.
Properties
-
state
Document Sync Manager State.
property -
shouldUseEncryption
Used to indicate whether the document sync manager should use encryption for the remote files.
property -
mustUploadStoreAfterRegistration
Used internally to indicate whether the document sync manager must upload the store after registration has completed.
property -
delegate
The Document Sync Manager Delegate.
property -
applicationSyncManager
The Application Sync Manager responsible for this document.
property -
documentIdentifier
The Document Identifier used for registration.
property -
documentDescription
The Document Description used for registration.
property -
clientIdentifier
The Client Identifier used for registration.
property -
documentUserInfo
The User Info used for registration.
property -
fileManager
An
propertyNSFileManager
suitable for use in document registration tasks. -
helperFileDirectoryLocation
The location of a directory used by the
propertyTICoreDataSync
framework to store local helper files for this document. -
syncChangesMOCs
A dictionary containing the SyncChanges managed object contexts to use for each document managed object context.
property -
– syncChangesMocForDocumentMoc:
Returns a SyncChanges managed object context for a given document managed object context.
-
primaryDocumentMOC
The document managed object context that was supplied at registration, and therefore treated as the primary context.
property -
coreDataFactory
The
propertyTICoreDataFactory
object used for SyncChange managed object contexts.
Operation Queues
-
registrationQueue
The operation queue used for registration operations.
property -
synchronizationQueue
The operation queue used for synchronization operations.
property -
otherTasksQueue
The operation queue used for other tasks.
property
Relative Paths
-
relativePathToClientDevicesDirectory
The path to the
propertyClientDevices
directory, relative to the root of the remote file structure. -
relativePathToInformationDirectory
The path to the
propertyInformation
directory, relative to the root of the remote file structure. -
relativePathToInformationDeletedDocumentsDirectory
The path to the
propertyDeletedDocuments
directory inside theInformation
directory, relative to the root of the remote file structure. -
relativePathToDeletedDocumentsThisDocumentIdentifierPlistFile
The path to this document’s
propertyidentifier.plist
file inside theDeletedDocuments
directory, relative to the root of the remote file structure. -
relativePathToDocumentsDirectory
The path to the
propertyDocuments
directory, relative to the root of the remote file structure. -
relativePathToThisDocumentDirectory
The path to this document’s directory inside the
propertyDocuments
directory, relative to the root of the remote file structure. -
relativePathToThisDocumentDeletedClientsDirectory
The path to this document’s
propertyDeletedClients
directory, relative to the root of the remote file structure. -
relativePathToThisDocumentSyncChangesDirectory
The path to the
propertySyncChanges
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentSyncChangesThisClientDirectory
The path to this client’s directory inside the
propertySyncChanges
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentSyncCommandsDirectory
The path to the
propertySyncCommands
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentSyncCommandsThisClientDirectory
The path to this client’s directory inside the
propertySyncCommands
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentWholeStoreDirectory
The path to the
propertyWholeStore
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentWholeStoreThisClientDirectory
The path to this client’s directory inside the
propertyWholeStore
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentTemporaryFilesDirectory
The path to the
propertyTemporaryFiles
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentTemporaryWholeStoreDirectory
The path to the
propertyWholeStore
directory inside theTemporaryFiles
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentTemporaryWholeStoreThisClientDirectory
The path to this client’s directory inside the
propertyWholeStore
directory inside theTemporaryFiles
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentTemporaryWholeStoreThisClientDirectoryWholeStoreFile
The path to this client’s
propertyWholeStore.ticdsync
file inside it’s directory inside theWholeStore
directory inside theTemporaryFiles
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentTemporaryWholeStoreThisClientDirectoryAppliedSyncChangeSetsFile
The path to this client’s
propertyAppliedSyncChangeSets.ticdsync
file inside it’s directory inside theWholeStore
directory inside theTemporaryFiles
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentWholeStoreThisClientDirectoryWholeStoreFile
The path to this client’s
propertyWholeStore.ticdsync
file inside it’s directory inside theWholeStore
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentWholeStoreThisClientDirectoryAppliedSyncChangeSetsFile
The path to this client’s
propertyAppliedSyncChangeSets.ticdsync
file inside it’s directory inside theWholeStore
directory for this document, relative to the root of the remote file structure. -
relativePathToThisDocumentRecentSyncsDirectory
The path to this document’s
propertyRecentSyncs
directory, relative to the root of the remote file structure. -
relativePathToThisDocumentRecentSyncsDirectoryThisClientFile
The path this client’s RecentSync file inside this document’s
propertyRecentSyncs
directory, relative to the root of the remote file structure. -
localAppliedSyncChangesFilePath
The path to the
propertyAppliedSyncChanges.ticdsync
file, located in thehelperFileDirectoryLocation
. -
syncChangesBeingSynchronizedStorePath
The path to the
propertySyncChangesBeingSynchronized.syncchg
file, located in thehelperFileDirectoryLocation
. -
unsynchronizedSyncChangesStorePath
The path to the
propertyUnsynchronizedSyncChanges.syncchg
file, located in thehelperFileDirectoryLocation
. -
integrityKey
The integrity key used to check whether the synchronization data matches what’s expected.
property
Properties
applicationSyncManager
The Application Sync Manager responsible for this document.
@property (nonatomic, retain) TICDSApplicationSyncManager *applicationSyncManager
Declared In
TICDSDocumentSyncManager.h
clientIdentifier
The Client Identifier used for registration.
@property (nonatomic, readonly, retain) NSString *clientIdentifier
Discussion
Set the identifier when registering with registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
.
Declared In
TICDSDocumentSyncManager.h
coreDataFactory
The TICoreDataFactory
object used for SyncChange managed object contexts.
@property (nonatomic, retain) TICoreDataFactory *coreDataFactory
Declared In
TICDSDocumentSyncManager.h
delegate
The Document Sync Manager Delegate.
@property (nonatomic, assign) id<TICDSDocumentSyncManagerDelegate> delegate
Declared In
TICDSDocumentSyncManager.h
documentDescription
The Document Description used for registration.
@property (nonatomic, readonly, retain) NSString *documentDescription
Discussion
Set the identifier when registering with registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
.
Declared In
TICDSDocumentSyncManager.h
documentIdentifier
The Document Identifier used for registration.
@property (nonatomic, readonly, retain) NSString *documentIdentifier
Discussion
Set the identifier when registering with registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
.
Declared In
TICDSDocumentSyncManager.h
documentUserInfo
The User Info used for registration.
@property (nonatomic, readonly, retain) NSDictionary *documentUserInfo
Discussion
Set the user info when registering with registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
.
Declared In
TICDSDocumentSyncManager.h
fileManager
An NSFileManager
suitable for use in document registration tasks.
@property (nonatomic, readonly, retain) NSFileManager *fileManager
Declared In
TICDSDocumentSyncManager.h
helperFileDirectoryLocation
The location of a directory used by the TICoreDataSync
framework to store local helper files for this document.
@property (readonly, retain) NSURL *helperFileDirectoryLocation
Discussion
You typically set this property by implementing the TICDSDocumentSyncManagerDelegate
method documentSyncManager:helperFileDirectoryURLForDocumentWithIdentifier:description:userInfo:
.
By default, the framework will use the location ~/Library/Application Support/ApplicationName/Documents/
documentIdentifier.
Declared In
TICDSDocumentSyncManager.h
integrityKey
The integrity key used to check whether the synchronization data matches what’s expected.
@property (nonatomic, retain) NSString *integrityKey
Declared In
TICDSDocumentSyncManager.h
localAppliedSyncChangesFilePath
The path to the AppliedSyncChanges.ticdsync
file, located in the helperFileDirectoryLocation
.
@property (nonatomic, readonly) NSString *localAppliedSyncChangesFilePath
Declared In
TICDSDocumentSyncManager.h
mustUploadStoreAfterRegistration
Used internally to indicate whether the document sync manager must upload the store after registration has completed.
@property (nonatomic, assign) BOOL mustUploadStoreAfterRegistration
Discussion
This will be YES
if this is the first time this document has been registered.
Declared In
TICDSDocumentSyncManager.h
otherTasksQueue
The operation queue used for other tasks.
@property (nonatomic, readonly, retain) NSOperationQueue *otherTasksQueue
Discussion
The queue is suspended until the document has registered successfully.
Declared In
TICDSDocumentSyncManager.h
primaryDocumentMOC
The document managed object context that was supplied at registration, and therefore treated as the primary context.
@property (nonatomic, retain) TICDSSynchronizedManagedObjectContext *primaryDocumentMOC
Declared In
TICDSDocumentSyncManager.h
registrationQueue
The operation queue used for registration operations.
@property (nonatomic, readonly, retain) NSOperationQueue *registrationQueue
Declared In
TICDSDocumentSyncManager.h
relativePathToClientDevicesDirectory
The path to the ClientDevices
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToClientDevicesDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToDeletedDocumentsThisDocumentIdentifierPlistFile
The path to this document’s identifier.plist
file inside the DeletedDocuments
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToDeletedDocumentsThisDocumentIdentifierPlistFile
Declared In
TICDSDocumentSyncManager.h
relativePathToDocumentsDirectory
The path to the Documents
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToDocumentsDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToInformationDeletedDocumentsDirectory
The path to the DeletedDocuments
directory inside the Information
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToInformationDeletedDocumentsDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToInformationDirectory
The path to the Information
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToInformationDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentDeletedClientsDirectory
The path to this document’s DeletedClients
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentDeletedClientsDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentDirectory
The path to this document’s directory inside the Documents
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentRecentSyncsDirectory
The path to this document’s RecentSyncs
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentRecentSyncsDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentRecentSyncsDirectoryThisClientFile
The path this client’s RecentSync file inside this document’s RecentSyncs
directory, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentRecentSyncsDirectoryThisClientFile
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentSyncChangesDirectory
The path to the SyncChanges
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentSyncChangesDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentSyncChangesThisClientDirectory
The path to this client’s directory inside the SyncChanges
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentSyncChangesThisClientDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentSyncCommandsDirectory
The path to the SyncCommands
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentSyncCommandsDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentSyncCommandsThisClientDirectory
The path to this client’s directory inside the SyncCommands
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentSyncCommandsThisClientDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentTemporaryFilesDirectory
The path to the TemporaryFiles
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentTemporaryFilesDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentTemporaryWholeStoreDirectory
The path to the WholeStore
directory inside the TemporaryFiles
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentTemporaryWholeStoreDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentTemporaryWholeStoreThisClientDirectory
The path to this client’s directory inside the WholeStore
directory inside the TemporaryFiles
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentTemporaryWholeStoreThisClientDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentTemporaryWholeStoreThisClientDirectoryAppliedSyncChangeSetsFile
The path to this client’s AppliedSyncChangeSets.ticdsync
file inside it’s directory inside the WholeStore
directory inside the TemporaryFiles
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentTemporaryWholeStoreThisClientDirectoryAppliedSyncChangeSetsFile
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentTemporaryWholeStoreThisClientDirectoryWholeStoreFile
The path to this client’s WholeStore.ticdsync
file inside it’s directory inside the WholeStore
directory inside the TemporaryFiles
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentTemporaryWholeStoreThisClientDirectoryWholeStoreFile
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentWholeStoreDirectory
The path to the WholeStore
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentWholeStoreDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentWholeStoreThisClientDirectory
The path to this client’s directory inside the WholeStore
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentWholeStoreThisClientDirectory
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentWholeStoreThisClientDirectoryAppliedSyncChangeSetsFile
The path to this client’s AppliedSyncChangeSets.ticdsync
file inside it’s directory inside the WholeStore
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentWholeStoreThisClientDirectoryAppliedSyncChangeSetsFile
Declared In
TICDSDocumentSyncManager.h
relativePathToThisDocumentWholeStoreThisClientDirectoryWholeStoreFile
The path to this client’s WholeStore.ticdsync
file inside it’s directory inside the WholeStore
directory for this document, relative to the root of the remote file structure.
@property (nonatomic, readonly) NSString *relativePathToThisDocumentWholeStoreThisClientDirectoryWholeStoreFile
Declared In
TICDSDocumentSyncManager.h
shouldUseEncryption
Used to indicate whether the document sync manager should use encryption for the remote files.
@property (nonatomic, assign) BOOL shouldUseEncryption
Discussion
This value is set automatically by the application sync manager.
Declared In
TICDSDocumentSyncManager.h
state
Document Sync Manager State.
@property (nonatomic, assign) TICDSDocumentSyncManagerState state
Discussion
The state of the document sync manager indicates whether it is ready to synchronize.
Possible values are defined in TICDSTypesAndEnums.h
.
Declared In
TICDSDocumentSyncManager.h
syncChangesBeingSynchronizedStorePath
The path to the SyncChangesBeingSynchronized.syncchg
file, located in the helperFileDirectoryLocation
.
@property (nonatomic, readonly) NSString *syncChangesBeingSynchronizedStorePath
Declared In
TICDSDocumentSyncManager.h
syncChangesMOCs
A dictionary containing the SyncChanges managed object contexts to use for each document managed object context.
@property (retain) NSMutableDictionary *syncChangesMOCs
Declared In
TICDSDocumentSyncManager.h
synchronizationQueue
The operation queue used for synchronization operations.
@property (nonatomic, readonly, retain) NSOperationQueue *synchronizationQueue
Discussion
The queue supports only 1 operation at a time, and is suspended until the document has registered successfully.
Declared In
TICDSDocumentSyncManager.h
unsynchronizedSyncChangesStorePath
The path to the UnsynchronizedSyncChanges.syncchg
file, located in the helperFileDirectoryLocation
.
@property (nonatomic, readonly) NSString *unsynchronizedSyncChangesStorePath
Declared In
TICDSDocumentSyncManager.h
Instance Methods
addManagedObjectContext:
Add an additional background managed object context to this document sync manager.
- (void)addManagedObjectContext:(TICDSSynchronizedManagedObjectContext *)aContext
Parameters
- aContext
The additional managed object context to add.
Discussion
Use this method to add an additional managed object context in which changes should be tracked, for example a context used to add items in the background.
Declared In
TICDSDocumentSyncManager.h
configureWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
Configure a document but don’t immediately register it.
- (void)configureWithDelegate:(id<TICDSDocumentSyncManagerDelegate>)aDelegate appSyncManager:(TICDSApplicationSyncManager *)anAppSyncManager managedObjectContext:(TICDSSynchronizedManagedObjectContext *)aContext documentIdentifier:(NSString *)aDocumentIdentifier description:(NSString *)aDocumentDescription userInfo:(NSDictionary *)someUserInfo
Parameters
- aDelegate
The object you wish to be notified regarding document-related sync information; this object must conform to the
TICDSDocumentSyncManagerDelegate
protocol, which includes some required methods.
- anAppSyncManager
The application sync manager responsible for overseeing this document.
- aContext
The primary managed object context in your application; this must be an instance of
TICDSSynchronizedManagedObjectContext
and not just a plainNSManagedObjectContext
.
- aDocumentIdentifier
An identification string to identify this document uniquely. You would typically create a UUID string the first time this doc is registered and store this in e.g. the store metadata.
- aDocumentDescription
A human-readable string used to identify this document, e.g. the full name of the document.
- someUserInfo
A dictionary of information that will be saved throughout all future synchronizations. Because this information is saved in a plist, everything in the dictionary must be archivable using
NSKeyedArchiver
.
Discussion
Use this method to configure the sync manager in environments where you may not have a permanent internet connection, such as an iOS device, or a desktop WebDAV client, etc.
This will configure everything necessary to track changes made by the user. When you wish to initiate a sync, or perform any other task, you’ll need to call the registerConfiguredDocumentSyncManager
method first to initiate registration.
You must call this method before using the document sync manager for any other purpose.
Do not use this method of registration the very first time the user configures registration on a document, or the internal checks to update the sync attribute on any pre-existing managed objects will not be made.
Declared In
TICDSDocumentSyncManager.h
continueRegistrationByCreatingRemoteFileStructure:
Continue Registration.
- (void)continueRegistrationByCreatingRemoteFileStructure:(BOOL)shouldCreateFileStructure
Parameters
- shouldCreateFileStructure
YES
if the registration should continue and create the necessary remote file structure, orNO
to cancel the registration.
Discussion
If this is the first time you have registered this document, or the remote file structure has been removed for some reason, your delegate will be notified with the documentSyncManager:didPauseRegistrationAsRemoteFileStructureDoesNotExistForDocumentWithIdentifier:description:userInfo:
method. You must continue registration manually by calling this method, specifying whether or not the registration should continue by creating the remote file structure.
If you specify NO
, registration will fail with an error.
Declared In
TICDSDocumentSyncManager.h
continueSynchronizationByResolvingConflictWithResolutionType:
If a conflict is encountered during synchronization, your delegate will be notified with the solveConflict:
method. You must decide whether the remote or local SyncChange
wins, and inform the document sync manager using this method to continue synchronization.
- (void)continueSynchronizationByResolvingConflictWithResolutionType:(TICDSSyncConflictResolutionType)aType
Parameters
- aType
The type of conflict resolution; see
TICDSTypesAndEnums.h
for possible values.
Declared In
TICDSDocumentSyncManager.h
deleteDocumentSynchronizationDataForClientWithIdentifier:
Delete the files used by a client to synchronize with this document.
- (void)deleteDocumentSynchronizationDataForClientWithIdentifier:(NSString *)anIdentifier
Parameters
- anIdentifier
The unique synchronization identifier of the client to delete.
Discussion
This will automatically spawn a TICDSDocumentClientDeletionOperation
, and notify you of progress through the TICDSDocumentSyncManagerDelegate
methods.
Declared In
TICDSDocumentSyncManager.h
documentClientDeletionOperation
Returns a “deletion of client synchronization data from a document” operation.
- (TICDSDocumentClientDeletionOperation *)documentClientDeletionOperation
Return Value
A correctly-configured subclass of TICDSDocumentClientDeletionOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured operation for their particularly sync method.
Declared In
TICDSDocumentSyncManager.h
documentRegistrationOperation
Returns a document registration operation.
- (TICDSDocumentRegistrationOperation *)documentRegistrationOperation
Return Value
A correctly-configured subclass of TICDSDocumentRegistrationOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured document registration operation for their particular sync method.
Declared In
TICDSDocumentSyncManager.h
initiateDownloadOfWholeStore
Start the process to download the entire store file for this document, along with the relevant AppliedSyncChanges.ticdsync
file.
- (void)initiateDownloadOfWholeStore
Discussion
This will automatically spawn a TICDSWholeStoreDownloadOperation
, and notify you of progress through the TICDSDocumentSyncManagerDelegate
methods.
The location of the store file (and the applied sync changes file) will be requested from the delegate immediately after calling this method.
Declared In
TICDSDocumentSyncManager.h
initiateSynchronization
Start synchronizing the document with the remote location.
- (void)initiateSynchronization
Discussion
This will automatically spawn a TICDSSynchronizationOperation
, and notify you of progress through the TICDSDocumentSyncManagerDelegate
methods.
Declared In
TICDSDocumentSyncManager.h
initiateUploadOfWholeStore
Start the process manually to upload the entire store file for this document, along with the relevant AppliedSyncChanges.ticdsync
file.
- (void)initiateUploadOfWholeStore
Discussion
This will automatically spawn a TICDSWholeStoreUploadOperation
, and notify you of progress through the TICDSDocumentSyncManagerDelegate
methods.
The location of the store file (and the applied sync changes file) will be requested from the delegate immediately after calling this method.
Declared In
TICDSDocumentSyncManager.h
initiateVacuumOfUnneededRemoteFiles
Initiate a vacuum operation to clean up files hanging around on the remote that are no longer needed by any registered clients.
- (void)initiateVacuumOfUnneededRemoteFiles
Discussion
This will automatically spawn a TICDSVacuumOperation
, and notify you of progress through the TICDSDocumentSyncManagerDelegate
methods.
Declared In
TICDSDocumentSyncManager.h
listOfDocumentRegisteredClientsOperation
Returns a “list of registered clients for this document” operation.
- (TICDSListOfDocumentRegisteredClientsOperation *)listOfDocumentRegisteredClientsOperation
Return Value
A correctly-configured subclass of TICDSListOfDocumentRegisteredClientsOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured operation for their particularly sync method.
Declared In
TICDSDocumentSyncManager.h
preConfigureWithDelegate:appSyncManager:documentIdentifier:
Pre-configure a sync manager for a document that’s just been downloaded, but without carrying out full registration.
- (void)preConfigureWithDelegate:(id<TICDSDocumentSyncManagerDelegate>)aDelegate appSyncManager:(TICDSApplicationSyncManager *)anAppSyncManager documentIdentifier:(NSString *)aDocumentIdentifier
Parameters
- aDelegate
The object you wish to be notified regarding document-related sync information; this object must conform to the
TICDSDocumentSyncManagerDelegate
protocol, which includes some required methods.
- anAppSyncManager
The application sync manager responsible for overseeing this document.
- aDocumentIdentifier
An identification string to identify this document uniquely. You would typically create a UUID string the first time this doc is registered and store this in e.g. the store metadata.
Discussion
Use this method to provide basic configuration of the sync manager for a document that’s been downloaded by calling the TICDSApplicationSyncManager
method requestDownloadOfDocumentWithIdentifier:toLocation:
, normally in response to the TICDSApplicationSyncManager
delegate method applicationSyncManager:preConfiguredDocumentSyncManagerForDownloadedDocumentWithIdentifier:atURL:
.
This will setup the necessary helper file location and do any local configuration, but won’t register the document with the remote.
If an error occurs, the delegate will be informed via the applicationSyncManager:didFailToRegisterWithError:
method.
This method is called automatically by registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
, so you should only call it when needed during the document download process, not during general document registration.
Declared In
TICDSDocumentSyncManager.h
registerConfiguredDocumentSyncManager
Register a document that has already been pre-configured.
- (void)registerConfiguredDocumentSyncManager
Discussion
Use this method to register a document sync manager that you have already configured using the configureWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
method.
Declared In
TICDSDocumentSyncManager.h
registerWithDelegate:appSyncManager:managedObjectContext:documentIdentifier:description:userInfo:
Register a document ready for synchronization.
- (void)registerWithDelegate:(id<TICDSDocumentSyncManagerDelegate>)aDelegate appSyncManager:(TICDSApplicationSyncManager *)anAppSyncManager managedObjectContext:(TICDSSynchronizedManagedObjectContext *)aContext documentIdentifier:(NSString *)aDocumentIdentifier description:(NSString *)aDocumentDescription userInfo:(NSDictionary *)someUserInfo
Parameters
- aDelegate
The object you wish to be notified regarding document-related sync information; this object must conform to the
TICDSDocumentSyncManagerDelegate
protocol, which includes some required methods.
- anAppSyncManager
The application sync manager responsible for overseeing this document.
- aContext
The primary managed object context in your application; this must be an instance of
TICDSSynchronizedManagedObjectContext
and not just a plainNSManagedObjectContext
.
- aDocumentIdentifier
An identification string to identify this document uniquely. You would typically create a UUID string the first time this doc is registered and store this in e.g. the store metadata.
- aDocumentDescription
A human-readable string used to identify this document, e.g. the full name of the document.
- someUserInfo
A dictionary of information that will be saved throughout all future synchronizations. Because this information is saved in a plist, everything in the dictionary must be archivable using
NSKeyedArchiver
.
Discussion
Use this method to register the sync manager ready for document synchronization.
This will automatically spawn a TICDSDocumentRegistrationOperation
, and notify you of progress through the TICDSDocumentSyncManagerDelegate
methods.
If this is the first time you have registered the document with this identifier, registration will automatically create the file structure necessary at the remote end for this and other clients to synchronize. See [TICDSUtilities remoteDocumentFileStructure]
for the structure that will be created.
If you provide an application sync manager that isn’t yet ready to sync, the document registration task will be suspended until the application has finished registering.
If this is the first time you have registered this document, or the remote file structure has been removed for some reason, your delegate will be notified with the documentSyncManager:didPauseRegistrationAsRemoteFileStructureDoesNotExistForDocumentWithIdentifier:description:userInfo:
method. You must continue registration manually by calling the continueRegistrationByCreatingRemoteFileStructure:
method.
You must call this method before using the document sync manager for any other purpose.
Declared In
TICDSDocumentSyncManager.h
requestInformationForAllRegisteredDevices
Fetch a list of devices that are registered to synchronize with this client.
- (void)requestInformationForAllRegisteredDevices
Declared In
TICDSDocumentSyncManager.h
syncChangesMocForDocumentMoc:
Returns a SyncChanges managed object context for a given document managed object context.
- (NSManagedObjectContext *)syncChangesMocForDocumentMoc:(TICDSSynchronizedManagedObjectContext *)aContext
Declared In
TICDSDocumentSyncManager.h
synchronizationOperation
Returns a synchronization operation.
- (TICDSSynchronizationOperation *)synchronizationOperation
Return Value
A correctly-configured subclass of TICDSSynchronizationOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured synchronization operation for their particular sync method.
Declared In
TICDSDocumentSyncManager.h
synchronizedMOCDidSave:
Indicate that the synchronized managed object context completed a successful save.
- (void)synchronizedMOCDidSave:(TICDSSynchronizedManagedObjectContext *)aMoc
Parameters
- aMoc
The synchronized managed object context.
Discussion
This method is called automatically by TICDSSynchronizedManagedObjectContext
when it has successfully completed a save:
.
Declared In
TICDSDocumentSyncManager.h
synchronizedMOCFailedToSave:withError:
Indicate that the synchronized managed object context failed to save.
- (void)synchronizedMOCFailedToSave:(TICDSSynchronizedManagedObjectContext *)aMoc withError:(NSError *)anError
Parameters
- aMoc
The synchronized managed object context.
- anError
The relevant saving error.
Discussion
This method is called automatically by TICDSSynchronizedManagedObjectContext
when it’s failed to save:
.
Declared In
TICDSDocumentSyncManager.h
synchronizedMOCWillSave:
Indicate that the synchronized managed object context is about to save.
- (void)synchronizedMOCWillSave:(TICDSSynchronizedManagedObjectContext *)aMoc
Parameters
- aMoc
The synchronized managed object context.
Discussion
This method is called automatically by TICDSSynchronizedManagedObjectContext
when it’s about to initiate a save:
.
Declared In
TICDSDocumentSyncManager.h
vacuumOperation
Returns a vacuum operation.
- (TICDSVacuumOperation *)vacuumOperation
Return Value
A correctly-configured subclass of TICDSVacuumOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured vacuum operation for their particular sync method.
Declared In
TICDSDocumentSyncManager.h
wholeStoreDownloadOperation
Returns a whole store download operation.
- (TICDSWholeStoreDownloadOperation *)wholeStoreDownloadOperation
Return Value
A correctly-configured subclass of TICDSWholeStoreDownloadOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured whole store download operation (including the remote location of the document’s whole store, etc) for their particular sync method.
Declared In
TICDSDocumentSyncManager.h
wholeStoreUploadOperation
Returns a whole store upload operation.
- (TICDSWholeStoreUploadOperation *)wholeStoreUploadOperation
Return Value
A correctly-configured subclass of TICDSWholeStoreUploadOperation
.
Discussion
Subclasses of TICDSDocumentSyncManager
use this method to return a correctly-configured whole store upload operation for their particular sync method.
Declared In
TICDSDocumentSyncManager.h