Class SyncConfiguration.Builder
On this page
- io.realm.mongodb.sync
- Constructors
- Method Summary
- Inherited Methods
- Constructor Detail
- Method Detail
- addModule
- allowQueriesOnUiThread
- allowWritesOnUiThread
- assetFile
- build
- clientResetHandler
- compactOnLaunch
- encryptionKey
- errorHandler
- flowFactory
- inMemory
- initialData
- initialSubscriptions
- maxNumberOfActiveVersions
- modules
- name
- readOnly
- rxFactory
- schemaVersion
- syncClientResetStrategy
- urlPrefix
- waitForInitialRemoteData
io.realm.mongodb.sync
Enclosing class:
Builder used to construct instances of a SyncConfiguration in a fluent manner.
Constructors
Constructor and Description |
---|
Method Summary
Modifier and Type | Method and Description |
---|---|
public SyncConfiguration.Builder | |
public SyncConfiguration.Builder | Sets whether or not |
public SyncConfiguration.Builder | Sets whether or not calls to Realm.executeTransaction are allowed from the UI thread. |
public SyncConfiguration.Builder | |
public SyncConfiguration | build () Creates the RealmConfiguration based on the builder parameters. |
public SyncConfiguration.Builder | Sets the handler for when a Client Reset occurs. |
public SyncConfiguration.Builder | Sets this to determine if the Realm file should be compacted before returned to the user. |
public SyncConfiguration.Builder | Setting this will cause Realm to compact the Realm file if the Realm file has grown too large and a significant amount of space can be recovered. |
public SyncConfiguration.Builder | Sets the io.realm.Realm#ENCRYPTION_KEY_LENGTH bytes key used to encrypt and decrypt the Realm file. |
public SyncConfiguration.Builder | Sets the error handler used by this configuration. |
public SyncConfiguration.Builder | Sets the FlowFactory used to create coroutines Flows from Realm objects. |
public SyncConfiguration.Builder | inMemory () Setting this will create an in-memory Realm instead of saving it to disk. |
public SyncConfiguration.Builder | Sets the initial data in io.realm.Realm . |
public SyncConfiguration.Builder | Sets the initial Subscription s for the io.realm.Realm . |
public SyncConfiguration.Builder | Sets the maximum number of live versions in the Realm file before an IllegalStateException is thrown when attempting to write more data. |
public SyncConfiguration.Builder | Replaces the existing module(s) with one or more RealmModule s. |
public SyncConfiguration.Builder | Replaces the existing module(s) with one or more RealmModule s. |
public SyncConfiguration.Builder | |
public SyncConfiguration.Builder | readOnly () Setting this will cause the Realm to become read only and all write transactions made against this Realm will fail with an IllegalStateException . |
public SyncConfiguration.Builder | Sets the RxObservableFactory used to create Rx Observables from Realm objects. |
public SyncConfiguration.Builder | Sets the schema version of the Realm. |
public SyncConfiguration.Builder | Sets the handler for when a Client Reset occurs. |
public SyncConfiguration.Builder | Sets the handler for when a Client Reset occurs. |
public SyncConfiguration.Builder | |
public SyncConfiguration.Builder | Setting this will cause the Realm to download all known changes from the server the first time a Realm is opened. |
public SyncConfiguration.Builder | Setting this will cause the Realm to download all known changes from the server the first time a Realm is opened. |
Inherited Methods
Methods inherited from class java.lang.Object :
getClass
,hashCode
,equals
,clone
,toString
,notify
,notifyAll
,wait
,wait
,wait
,finalize
Constructor Detail
Creates an instance of the builder for a Partition-based Sync SyncConfiguration with the given user and partition value. Parameters
|
Creates an instance of the builder for a Partition-based Sync SyncConfiguration with the given user and partition value. Parameters
|
Method Detail
addModule
Adds a module to the already defined modules. |
allowQueriesOnUiThread
Sets whether or not By default Realm allows queries on the main thread. However, by doing so your application may experience a drop of frames or even ANRs. We recommend diverting queries to non-UI threads or, alternatively, using RealmQuery.findAllAsync() or RealmQuery.findFirstAsync() . |
allowWritesOnUiThread
Sets whether or not calls to Realm.executeTransaction are allowed from the UI thread. WARNING: Realm does not allow synchronous transactions to be run on the main thread unless users explicitly opt in with this method. We recommend diverting calls to |
assetFile
When opening the Realm for the first time, instead of creating an empty file, the Realm file will be copied from the provided asset file and used instead.This can be used to pre-populate the Realm with data, so it doesn't have to be downloaded from the server. The provided Realm file must be a valid synced Realm for the given user, and it must have been created using the Realm.writeCopyTo(File) API. WARNING: This could potentially be a lengthy operation and should ideally be done on a background thread. Parameters
Throws
|
build
public SyncConfiguration build () |
---|
Creates the RealmConfiguration based on the builder parameters. Returns the created SyncConfiguration . Throws
|
clientResetHandler
Sets the handler for when a Client Reset occurs. If no handler is set, and error is logged when a Client Reset occurs. Parameters
|
compactOnLaunch
Sets this to determine if the Realm file should be compacted before returned to the user. It is passed the total file size (data + free space) and the bytes used by data in the file. Parameters
|
public SyncConfiguration.Builder compactOnLaunch () |
---|
Setting this will cause Realm to compact the Realm file if the Realm file has grown too large and a significant amount of space can be recovered. See DefaultCompactOnLaunchCallback for details. |
encryptionKey
Sets the io.realm.Realm#ENCRYPTION_KEY_LENGTH bytes key used to encrypt and decrypt the Realm file. Parameters
Throws
|
errorHandler
Sets the error handler used by this configuration.Only errors not handled by the defined Parameters
Throws
|
flowFactory
Sets the FlowFactory used to create coroutines Flows from Realm objects. The default factory is RealmFlowFactory . Parameters
|
inMemory
public SyncConfiguration.Builder inMemory () |
---|
Setting this will create an in-memory Realm instead of saving it to disk. In-memory Realms might still use disk space if memory is running low, but all files created by an in-memory Realm will be deleted when the Realm is closed.Note that because in-memory Realms are not persisted, you must be sure to hold on to at least one non-closed reference to the in-memory Realm object with the specific name as long as you want the data to last. |
initialData
Sets the initial data in io.realm.Realm . This transaction will be executed only the first time the Realm file is opened (created) or while migrating the data if RealmConfiguration.Builder.deleteRealmIfMigrationNeeded() is set. Parameters
|
initialSubscriptions
Sets the initial Subscription s for the io.realm.Realm . This will only be executed the first time the Realm file is opened (and the file created). If waitForInitialRemoteData() is configured as well, the realm file isn't fully opened until all subscription data also has been uploaded. Parameters
|
maxNumberOfActiveVersions
Sets the maximum number of live versions in the Realm file before an IllegalStateException is thrown when attempting to write more data. Realm is capable of concurrently handling many different versions of Realm objects. This can happen if you have a Realm open on many different threads or are freezing objects while data is being written to the file. Under normal circumstances this is not a problem, but if the number of active versions grow too large, it will have a negative effect on the filesize on disk. Setting this parameters can therefore be used to prevent uses of Realm that can result in very large Realms. Note, the version number will also increase when changes from other devices are integrated on this device, so the number of active versions will also depend on what other devices writing to the same Realm are doing. Parameters
TipSee also: |
modules
Replaces the existing module(s) with one or more RealmModule s. Using this method will replace the current schema for this Realm with the schema defined by the provided modules. A reference to the default Realm module containing all Realm classes in the project (but not dependencies), can be found using Realm.getDefaultModule() . Combining the schema from the app project and a library dependency is thus done using the following code:
Parameters
Throws
TipSee also: |
Replaces the existing module(s) with one or more RealmModule s. Using this method will replace the current schema for this Realm with the schema defined by the provided modules. A reference to the default Realm module containing all Realm classes in the project (but not dependencies), can be found using Realm.getDefaultModule() . Combining the schema from the app project and a library dependency is thus done using the following code:
Parameters
Throws
TipSee also: |
name
Sets the filename for the Realm file on this device. Parameters
|
readOnly
public SyncConfiguration.Builder readOnly () |
---|
Setting this will cause the Realm to become read only and all write transactions made against this Realm will fail with an IllegalStateException . This in particular mean that initialData(Realm.Transaction) will not work in combination with a read only Realm and setting this will result in a IllegalStateException being thrown. Marking a Realm as read only only applies to the Realm in this process. Other processes and devices can still write to the Realm. |
rxFactory
Sets the RxObservableFactory used to create Rx Observables from Realm objects. The default factory is RealmObservableFactory . Parameters
|
schemaVersion
Sets the schema version of the Realm.Synced Realms only support additive schema changes which can be applied without requiring a manual migration. The schema version will only be used as an indication to the underlying storage layer to remove or add indexes. These will be recalculated if the provided schema version differ from the version in the Realm file. WARNING: There is no guarantee that the value inserted here is the same returned by Realm.getVersion(). Due to the nature of synced Realms, the value can both be higher and lower.
Parameters
Throws
|
syncClientResetStrategy
Sets the handler for when a Client Reset occurs. If no handler is set, and error is logged when a Client Reset occurs. This strategy is only available for synced realms using partition based sync. Realms using flexible sync currently only support syncClientResetStrategy(ManuallyRecoverUnsyncedChangesStrategy) . Parameters
|
Sets the handler for when a Client Reset occurs. If no handler is set, and error is logged when a Client Reset occurs. Parameters
|
urlPrefix
The prefix that is prepended to the path in the WebSocket request that initiates a sync connection to MongoDB Realm. The value specified must match the server’s configuration otherwise the device will not be able to create a connection. This value is optional and should only be set if a specific firewall rule requires it. Parameters
|
waitForInitialRemoteData
Setting this will cause the Realm to download all known changes from the server the first time a Realm is opened. The Realm will not open until all the data has been downloaded. This means that if a device is offline the Realm will not open.Since downloading all changes can be an lengthy operation that might block the UI thread, Realms with this setting enabled should only be opened on background threads or with Realm.getInstanceAsync(RealmConfiguration, Realm.Callback) on the UI thread. This check is only enforced the first time a Realm is created. If you otherwise want to make sure a Realm has the latest changes, use SyncSession.downloadAllServerChanges() . Parameters
|
Setting this will cause the Realm to download all known changes from the server the first time a Realm is opened. The Realm will not open until all the data has been downloaded. This means that if a device is offline the Realm will not open.Since downloading all changes can be an lengthy operation that might block the UI thread, Realms with this setting enabled should only be opened on background threads or with Realm.getInstanceAsync(RealmConfiguration, Realm.Callback) on the UI thread. This check is only enforced the first time a Realm is created. If you otherwise want to make sure a Realm has the latest changes, use SyncSession.downloadAllServerChanges() . |