.. _module-splice-dso-decentralizedsynchronizer-50859: Splice.DSO.DecentralizedSynchronizer ==================================== Data structures and contracts related managing the decentralized synchronizer\. Data Types ---------- .. _type-splice-dso-decentralizedsynchronizer-dsodecentralizedsynchronizerconfig-15965: **data** `DsoDecentralizedSynchronizerConfig `_ The decentralized synchronizer consists of a series of actual synchronizers\. New synchronizers are created by the SVs for the rare case of needing to roll\-out a BFT protocol upgrade that cannot be rolled out in a backwards compatible fashion\. Note that synchronizers themselves are formed by a cluster of nodes run by the SVs\. As can be seen form ``SynchronizerNodeConfig`` each sv runs multiple different kinds of physical nodes\. .. _constr-splice-dso-decentralizedsynchronizer-dsodecentralizedsynchronizerconfig-75458: `DsoDecentralizedSynchronizerConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - synchronizers - `Map `_ `Text `_ `SynchronizerConfig `_ - The actual synchronizers, numbered sequentially\. * - lastSynchronizerId - `Text `_ - The last allocated synchronizer Id\. * - activeSynchronizerId - `Text `_ - The synchronizer to be used for managing standard DSO and Amulet workflows\. **instance** `Eq `_ `DsoDecentralizedSynchronizerConfig `_ **instance** `Show `_ `DsoDecentralizedSynchronizerConfig `_ **instance** `GetField `_ \"activeSynchronizerId\" `DsoDecentralizedSynchronizerConfig `_ `Text `_ **instance** `GetField `_ \"decentralizedSynchronizer\" :ref:`DsoRulesConfig ` `DsoDecentralizedSynchronizerConfig `_ **instance** `GetField `_ \"lastSynchronizerId\" `DsoDecentralizedSynchronizerConfig `_ `Text `_ **instance** `GetField `_ \"synchronizers\" `DsoDecentralizedSynchronizerConfig `_ (`Map `_ `Text `_ `SynchronizerConfig `_) **instance** `SetField `_ \"activeSynchronizerId\" `DsoDecentralizedSynchronizerConfig `_ `Text `_ **instance** `SetField `_ \"decentralizedSynchronizer\" :ref:`DsoRulesConfig ` `DsoDecentralizedSynchronizerConfig `_ **instance** `SetField `_ \"lastSynchronizerId\" `DsoDecentralizedSynchronizerConfig `_ `Text `_ **instance** `SetField `_ \"synchronizers\" `DsoDecentralizedSynchronizerConfig `_ (`Map `_ `Text `_ `SynchronizerConfig `_) .. _type-splice-dso-decentralizedsynchronizer-legacysequencerconfig-76078: **data** `LegacySequencerConfig `_ Config for a legacy sequencer, i\.e\., a migration id that is still up but paused\. This is useful to allow validators to catch up\. .. _constr-splice-dso-decentralizedsynchronizer-legacysequencerconfig-74515: `LegacySequencerConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - migrationId - `Int `_ - The synchronizer migration id corresponding to this sequencer\. * - sequencerId - `Text `_ - The id of the sequencer\. * - url - `Text `_ - The public accessible url of the sequencer\. **instance** `Eq `_ `LegacySequencerConfig `_ **instance** `Show `_ `LegacySequencerConfig `_ **instance** `GetField `_ \"legacySequencerConfig\" `SynchronizerNodeConfig `_ (`Optional `_ `LegacySequencerConfig `_) **instance** `GetField `_ \"migrationId\" `LegacySequencerConfig `_ `Int `_ **instance** `GetField `_ \"sequencerId\" `LegacySequencerConfig `_ `Text `_ **instance** `GetField `_ \"url\" `LegacySequencerConfig `_ `Text `_ **instance** `SetField `_ \"legacySequencerConfig\" `SynchronizerNodeConfig `_ (`Optional `_ `LegacySequencerConfig `_) **instance** `SetField `_ \"migrationId\" `LegacySequencerConfig `_ `Int `_ **instance** `SetField `_ \"sequencerId\" `LegacySequencerConfig `_ `Text `_ **instance** `SetField `_ \"url\" `LegacySequencerConfig `_ `Text `_ .. _type-splice-dso-decentralizedsynchronizer-mediatorconfig-99298: **data** `MediatorConfig `_ Config for a mediator\. .. _constr-splice-dso-decentralizedsynchronizer-mediatorconfig-88513: `MediatorConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - mediatorId - `Text `_ - The id of the mediator\. **instance** `Eq `_ `MediatorConfig `_ **instance** `Show `_ `MediatorConfig `_ **instance** `GetField `_ \"mediator\" `SynchronizerNodeConfig `_ (`Optional `_ `MediatorConfig `_) **instance** `GetField `_ \"mediatorId\" `MediatorConfig `_ `Text `_ **instance** `SetField `_ \"mediator\" `SynchronizerNodeConfig `_ (`Optional `_ `MediatorConfig `_) **instance** `SetField `_ \"mediatorId\" `MediatorConfig `_ `Text `_ .. _type-splice-dso-decentralizedsynchronizer-scanconfig-87910: **data** `ScanConfig `_ Config for a Scan instance\. .. _constr-splice-dso-decentralizedsynchronizer-scanconfig-27525: `ScanConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - publicUrl - `Text `_ - The publicly accessible URL of the Scan instance\. **instance** `Eq `_ `ScanConfig `_ **instance** `Show `_ `ScanConfig `_ **instance** `GetField `_ \"publicUrl\" `ScanConfig `_ `Text `_ **instance** `GetField `_ \"scan\" `SynchronizerNodeConfig `_ (`Optional `_ `ScanConfig `_) **instance** `SetField `_ \"publicUrl\" `ScanConfig `_ `Text `_ **instance** `SetField `_ \"scan\" `SynchronizerNodeConfig `_ (`Optional `_ `ScanConfig `_) .. _type-splice-dso-decentralizedsynchronizer-sequencerconfig-38423: **data** `SequencerConfig `_ Config for a sequencer\. .. _constr-splice-dso-decentralizedsynchronizer-sequencerconfig-73098: `SequencerConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - migrationId - `Int `_ - The synchronizer migration id corresponding to this sequencer\. * - sequencerId - `Text `_ - The id of the sequencer\. * - url - `Text `_ - The public accessible url of the sequencer\. * - availableAfter - `Optional `_ `Time `_ - Any participant should subscribe this sequencer after this time\. \^ If not set the sequencer is not yet accessible **instance** `Eq `_ `SequencerConfig `_ **instance** `Show `_ `SequencerConfig `_ **instance** `GetField `_ \"availableAfter\" `SequencerConfig `_ (`Optional `_ `Time `_) **instance** `GetField `_ \"migrationId\" `SequencerConfig `_ `Int `_ **instance** `GetField `_ \"sequencer\" `SynchronizerNodeConfig `_ (`Optional `_ `SequencerConfig `_) **instance** `GetField `_ \"sequencerId\" `SequencerConfig `_ `Text `_ **instance** `GetField `_ \"url\" `SequencerConfig `_ `Text `_ **instance** `SetField `_ \"availableAfter\" `SequencerConfig `_ (`Optional `_ `Time `_) **instance** `SetField `_ \"migrationId\" `SequencerConfig `_ `Int `_ **instance** `SetField `_ \"sequencer\" `SynchronizerNodeConfig `_ (`Optional `_ `SequencerConfig `_) **instance** `SetField `_ \"sequencerId\" `SequencerConfig `_ `Text `_ **instance** `SetField `_ \"url\" `SequencerConfig `_ `Text `_ .. _type-splice-dso-decentralizedsynchronizer-synchronizerconfig-49093: **data** `SynchronizerConfig `_ The DSO\-level configuration of a synchronizer\. This contains the shared parameters of the synchronizer\. .. _constr-splice-dso-decentralizedsynchronizer-synchronizerconfig-62326: `SynchronizerConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - state - `SynchronizerState `_ - The state of this synchronizer * - cometBftGenesisJson - `Text `_ - The CometBftGenesis json value required for new svs to bring up their CometBft nodes for this synchronizer\. * - acsCommitmentReconciliationInterval - `Optional `_ `Int `_ - Participants connected to the decentralized synchronizer exchange ACS commitment messages every reconciliation interval seconds\. **instance** `Eq `_ `SynchronizerConfig `_ **instance** `Show `_ `SynchronizerConfig `_ **instance** `GetField `_ \"acsCommitmentReconciliationInterval\" `SynchronizerConfig `_ (`Optional `_ `Int `_) **instance** `GetField `_ \"cometBftGenesisJson\" `SynchronizerConfig `_ `Text `_ **instance** `GetField `_ \"state\" `SynchronizerConfig `_ `SynchronizerState `_ **instance** `GetField `_ \"synchronizers\" `DsoDecentralizedSynchronizerConfig `_ (`Map `_ `Text `_ `SynchronizerConfig `_) **instance** `SetField `_ \"acsCommitmentReconciliationInterval\" `SynchronizerConfig `_ (`Optional `_ `Int `_) **instance** `SetField `_ \"cometBftGenesisJson\" `SynchronizerConfig `_ `Text `_ **instance** `SetField `_ \"state\" `SynchronizerConfig `_ `SynchronizerState `_ **instance** `SetField `_ \"synchronizers\" `DsoDecentralizedSynchronizerConfig `_ (`Map `_ `Text `_ `SynchronizerConfig `_) .. _type-splice-dso-decentralizedsynchronizer-synchronizernodeconfig-10457: **data** `SynchronizerNodeConfig `_ The configuration of a sv's node for a particular synchronizer\. .. _constr-splice-dso-decentralizedsynchronizer-synchronizernodeconfig-64798: `SynchronizerNodeConfig `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - cometBft - :ref:`CometBftConfig ` - The configuration of this sv's CometBFT nodes and keys\. * - sequencer - `Optional `_ `SequencerConfig `_ - The configuration of this sv's optional local sequencer\. * - mediator - `Optional `_ `MediatorConfig `_ - The configuration of this sv's optional local mediator\. * - scan - `Optional `_ `ScanConfig `_ - The configuration of this sv's optional Scan instance\. * - legacySequencerConfig - `Optional `_ `LegacySequencerConfig `_ - The legacy sequencer config for the prior migration id that is still up\. We store this so it can be published on scan and validators can catchup\. **instance** `Eq `_ `SynchronizerNodeConfig `_ **instance** `Show `_ `SynchronizerNodeConfig `_ **instance** `GetField `_ \"cometBft\" `SynchronizerNodeConfig `_ :ref:`CometBftConfig ` **instance** `GetField `_ \"legacySequencerConfig\" `SynchronizerNodeConfig `_ (`Optional `_ `LegacySequencerConfig `_) **instance** `GetField `_ \"mediator\" `SynchronizerNodeConfig `_ (`Optional `_ `MediatorConfig `_) **instance** `GetField `_ \"newNodeConfig\" :ref:`DsoRules_SetSynchronizerNodeConfig ` `SynchronizerNodeConfig `_ **instance** `GetField `_ \"scan\" `SynchronizerNodeConfig `_ (`Optional `_ `ScanConfig `_) **instance** `GetField `_ \"sequencer\" `SynchronizerNodeConfig `_ (`Optional `_ `SequencerConfig `_) **instance** `SetField `_ \"cometBft\" `SynchronizerNodeConfig `_ :ref:`CometBftConfig ` **instance** `SetField `_ \"legacySequencerConfig\" `SynchronizerNodeConfig `_ (`Optional `_ `LegacySequencerConfig `_) **instance** `SetField `_ \"mediator\" `SynchronizerNodeConfig `_ (`Optional `_ `MediatorConfig `_) **instance** `SetField `_ \"newNodeConfig\" :ref:`DsoRules_SetSynchronizerNodeConfig ` `SynchronizerNodeConfig `_ **instance** `SetField `_ \"scan\" `SynchronizerNodeConfig `_ (`Optional `_ `ScanConfig `_) **instance** `SetField `_ \"sequencer\" `SynchronizerNodeConfig `_ (`Optional `_ `SequencerConfig `_) .. _type-splice-dso-decentralizedsynchronizer-synchronizernodeconfiglimits-3659: **data** `SynchronizerNodeConfigLimits `_ .. _constr-splice-dso-decentralizedsynchronizer-synchronizernodeconfiglimits-16072: `SynchronizerNodeConfigLimits `_ .. list-table:: :widths: 15 10 30 :header-rows: 1 * - Field - Type - Description * - cometBft - :ref:`CometBftConfigLimits ` - **instance** `Eq `_ `SynchronizerNodeConfigLimits `_ **instance** `Show `_ `SynchronizerNodeConfigLimits `_ **instance** `GetField `_ \"cometBft\" `SynchronizerNodeConfigLimits `_ :ref:`CometBftConfigLimits ` **instance** `GetField `_ \"synchronizerNodeConfigLimits\" :ref:`DsoRulesConfig ` `SynchronizerNodeConfigLimits `_ **instance** `SetField `_ \"cometBft\" `SynchronizerNodeConfigLimits `_ :ref:`CometBftConfigLimits ` **instance** `SetField `_ \"synchronizerNodeConfigLimits\" :ref:`DsoRulesConfig ` `SynchronizerNodeConfigLimits `_ .. _type-splice-dso-decentralizedsynchronizer-synchronizernodeconfigmap-59848: **type** `SynchronizerNodeConfigMap `_ \= `Map `_ `Text `_ `SynchronizerNodeConfig `_ A map from synchronizer\-ids to the configuration of a sv's node for this synchronizer\. **instance** `GetField `_ \"sv1SynchronizerNodes\" :ref:`DsoBootstrap ` `SynchronizerNodeConfigMap `_ **instance** `GetField `_ \"synchronizerNodes\" :ref:`NodeState ` `SynchronizerNodeConfigMap `_ **instance** `SetField `_ \"sv1SynchronizerNodes\" :ref:`DsoBootstrap ` `SynchronizerNodeConfigMap `_ **instance** `SetField `_ \"synchronizerNodes\" :ref:`NodeState ` `SynchronizerNodeConfigMap `_ .. _type-splice-dso-decentralizedsynchronizer-synchronizerstate-25483: **data** `SynchronizerState `_ The state of a synchronizer\. .. _constr-splice-dso-decentralizedsynchronizer-dsbootstrapping-64886: `DS_Bootstrapping `_ The synchronizer is still being bootstrapped, and SVs are required to provision their nodes for it\. .. _constr-splice-dso-decentralizedsynchronizer-dsoperational-99130: `DS_Operational `_ The synchronizer is operational, and thus can be used as the active synchronizer\. .. _constr-splice-dso-decentralizedsynchronizer-dsdecomissioned-12812: `DS_Decomissioned `_ The synchronizer has been decommissioned and svs are now allowed to shutdown their nodes for that synchronizer\. We track this state explicitly instead of just deleting the synchronizer config, as decomissioning likely takes a while, and we want to avoid confusion among SV operators when they see errors raised from some of their synchronizer nodes\. .. _constr-splice-dso-decentralizedsynchronizer-extsynchronizerstate-26922: `ExtSynchronizerState `_ Extension constructor to work around the current lack of upgrading for variants in Daml 3\.0\. Will serve as the default value in a containing record in case of an extension\. **instance** `Eq `_ `SynchronizerState `_ **instance** `Show `_ `SynchronizerState `_ **instance** `GetField `_ \"state\" `SynchronizerConfig `_ `SynchronizerState `_ **instance** `SetField `_ \"state\" `SynchronizerConfig `_ `SynchronizerState `_ Functions --------- .. _function-splice-dso-decentralizedsynchronizer-nosynchronizernodes-89430: `noSynchronizerNodes `_ \: `SynchronizerNodeConfigMap `_ .. _function-splice-dso-decentralizedsynchronizer-emptysynchronizernodeconfig-56591: `emptySynchronizerNodeConfig `_ \: `SynchronizerNodeConfig `_ .. _function-splice-dso-decentralizedsynchronizer-validsynchronizernodeconfig-25090: `validSynchronizerNodeConfig `_ \: `SynchronizerNodeConfigLimits `_ \-\> `SynchronizerNodeConfig `_ \-\> `Bool `_ .. _function-splice-dso-decentralizedsynchronizer-defaultsynchronizernodeconfiglimits-67119: `defaultSynchronizerNodeConfigLimits `_ \: `SynchronizerNodeConfigLimits `_