Ditto 3.0.10
|
The entrypoint to the Ditto SDK. More...
Public Member Functions | |
Ditto (DittoIdentity identity=default, string workingDir="ditto") | |
Initializes a new instance of the Ditto class. | |
string | AppId () |
Get the Ditto application Id. | |
void | StartSync () |
Starts the network transports. Ditto will connect to other devices. | |
void | StopSync () |
Stops all network transports. | |
void | SetOfflineOnlyLicenseToken (string licenseToken) |
Activate an offline Ditto instance by setting a license token. You cannot sync with Ditto before you have activated it. The offline license token is only valid for Development, Manual, OfflinePlayground and SharedKey identities. | |
DittoTransportDiagnostics | TransportDiagnostics () |
Request bulk status information about the transports. This is mostly intended for statistical or debugging purposes. | |
DittoPeersObserver | ObservePeers (Action< List< DittoRemotePeer > > callback) |
Request information about Ditto peers in range of this device. This method returns an observer which should be held as long as updates are required. A newly registered observer will have a peers update delivered to it immediately. From then on it will be invoked repeatedly when Ditto devices come and go, or the active connections to them change. | |
void | DisableSyncWithV2 () |
Explicitly opt-in to disabling the ability to sync with Ditto peers running any version of the SDK in the v2 series of releases. | |
void | RunGarbageCollection () |
Removes all sync metadata for any remote peers which aren't currently connected. This method shouldn't usually be called. Manually running garbage collection often will result in slower sync times. Ditto automatically runs a garbage collection process in the background at optimal times. | |
Protected Member Functions | |
override void | Dispose (bool disposing) |
Overload for types to dispose of resources, regardless of whether the type is being disposed or finalized. Note that finalization occurs on a dedicated thread. | |
Properties | |
bool | IsSyncActive [get] |
Gets a value indicating whether or not sync is active. Use StartSync() to activate and StopSync() to deactivate sync. | |
bool | Activated [get] |
Gets a value indicating whether or not the SDK has been activated. | |
string | DeviceName [get, set] |
Gets or sets a custom identifier for the current device. | |
ulong | SiteId [get] |
Gets the unique identifier of a peer in Ditto's distributed mesh network. | |
string | PersistenceDirectory [get] |
Gets the persistence directory used by Ditto to persist data. | |
DittoStore | Store [get] |
Gets a reference to the embedded data store. | |
DittoPresence | Presence [get] |
Gets a reference to the presence manager. | |
DittoDiskUsage | DiskUsage [get] |
Gets a reference to the disk usage. | |
string | SDKVersion [get] |
Gets a string identifying the version of the Ditto SDK. | |
DittoAuthenticator | Auth [get] |
Gets a DittoAuthenticator that provides access to authentication information and methods for logging on to Ditto Cloud. | |
DittoTransportConfig | TransportConfig [get, set] |
Gets or sets assign a new transports configuration. By default peer-to-peer transports are enabled. | |
Events | |
EventHandler< DittoTransportConditionChangedEventArgs > | DittoTransportConditionChanged |
An optional EventHandler delegate that can be provided to get updates about events relating to changes in network transports. | |
EventHandler< DittoAuthenticationRequestEventArgs > | DittoIdentityProviderAuthenticationRequest |
An optional EventHandler delegate that can be provided to respond to incoming authentication requests from peers who wish to join the Ditto mesh. Requires setup of signing and verification keys in the Http part of TransportConfig . | |
The entrypoint to the Ditto SDK.
For a Ditto
instance to continue to connect to other devices it must be kept in scope.
|
inline |
Initializes a new instance of the Ditto class.
identity | Provide the identity of the entity that is interacting with Ditto. |
workingDir | The directory that will be used to persist Ditto data. |
|
inline |
Get the Ditto application Id.
|
inline |
Explicitly opt-in to disabling the ability to sync with Ditto peers running any version of the SDK in the v2 series of releases.
Assuming this succeeds then this peer will only be able to sync with other peers using SDKs in the v3 series of releases. Note that this disabling of sync spreads to peers that sync with a peer that has disabled, or has (transitively) had disabled, syncing with v2 SDK peers.
|
inlineprotected |
Overload for types to dispose of resources, regardless of whether the type is being disposed or finalized. Note that finalization occurs on a dedicated thread.
disposing | true when invoked from an explicit Dispose() call. false when invoked from the finalizer. |
|
inline |
Request information about Ditto peers in range of this device. This method returns an observer which should be held as long as updates are required. A newly registered observer will have a peers update delivered to it immediately. From then on it will be invoked repeatedly when Ditto devices come and go, or the active connections to them change.
callback | The Action that will be invoked when there is a presence update. |
DittoPeersObserver
instance, which must be retained to continue receiving callback updates.
|
inline |
Removes all sync metadata for any remote peers which aren't currently connected. This method shouldn't usually be called. Manually running garbage collection often will result in slower sync times. Ditto automatically runs a garbage collection process in the background at optimal times.
Manually running garbage collection is typically only useful during testing if large amounts of data are being generated. Alternatively, if an entire data set is to be evicted and it's clear that maintaining this metadata isn't necessary, then garbage collection could be run after evicting the old data.
|
inline |
Activate an offline Ditto instance by setting a license token. You cannot sync with Ditto before you have activated it. The offline license token is only valid for Development, Manual, OfflinePlayground and SharedKey identities.
licenseToken | The license token to activate the Ditto instance with, which you can find on the Ditto portal (https://portal.ditto.live). |
DittoException | Thrown if the provided license token is expired or invalid. |
Exception | Thrown if you attempt to set an offline license token on an online idetity. |
|
inline |
Starts the network transports. Ditto will connect to other devices.
By default Ditto will enable all peer-to-peer transport types. The network configuration can be customized using the SetTransportConfig
method.
DittoException | Thrown if the Ditto instance hasn't been activated by a successful call to SetLicenseToken . |
|
inline |
Stops all network transports.
You may continue to use the database locally but no data will sync to or from other devices.
|
inline |
Request bulk status information about the transports. This is mostly intended for statistical or debugging purposes.
DittoTransportDiagnostics
that represents the current state of the network transports that the SDK is using.
|
get |
Gets a value indicating whether or not the SDK has been activated.
If false
then you need to call Ditto.SetLicenseToken(string) before interacting with the SDK.
|
getset |
Gets or sets a custom identifier for the current device.
When using ObservePeers()
, each remote peer is represented by a short UTF-8 "device name". By default this will be a truncated version of the device's hostname. It does not need to be unique among peers. Configure the device name before calling StartSync()
. If it is too long it may be truncated.
|
get |
Gets a string identifying the version of the Ditto SDK.
|
get |
Gets the unique identifier of a peer in Ditto's distributed mesh network.
IMPORTANT: This must be unique or the merging and conflict resolution will have unexpected behavior.
|
getset |
Gets or sets assign a new transports configuration. By default peer-to-peer transports are enabled.
You may use this method to alter the configuration at any time, however sync will not begin until StartSync()
is called.