submitReplaceAuthorityTx
Midnight.js API Reference v3.1.0
Midnight.js API Reference / @midnight-ntwrk/midnight-js-contracts / submitReplaceAuthorityTx
Function: submitReplaceAuthorityTx()
submitReplaceAuthorityTx<
C>(providers,compiledContract,contractAddress): (newAuthority) =>Promise<FinalizedTxData>
Constructs and submits a transaction that replaces the maintenance authority stored on the blockchain for this contract. After the transaction is finalized, the current signing key stored in the given private state provider is overwritten with the given new authority key.
Transaction Execution Phases
Midnight transactions execute in two phases:
- Guaranteed phase: If failure occurs, the transaction is NOT included in the blockchain
- Fallible phase: If failure occurs, the transaction IS recorded on-chain as a partial success
Failure Behavior
Guaranteed Phase Failure:
- Transaction is rejected and not included in the blockchain
ReplaceMaintenanceAuthorityTxFailedErroris thrown with transaction data- Signing key in private state provider is NOT updated (remains as current authority)
- Contract authority on-chain remains unchanged
Fallible Phase Failure:
- Transaction is recorded on-chain with non-
SucceedEntirelystatus ReplaceMaintenanceAuthorityTxFailedErroris thrown with transaction data- Signing key in private state provider is NOT updated (remains as current authority)
- Contract authority on-chain may be partially updated but inconsistent
- Transaction appears in blockchain history as partial success
Type Parameters
C
C extends Any
Parameters
providers
The providers to use to manage the transaction lifecycle.
compiledContract
CompiledContract<C, any>
The compiled contract for which the maintenance authority should be updated.
contractAddress
string
The address of the contract for which the maintenance authority should be updated.
TODO: There are at least three options we should support in the future:
- Replace authority and maintain key (current).
- Replace authority and do not maintain key.
- Add additional authorities and maintain original key.
Returns
(
newAuthority):Promise<FinalizedTxData>
Parameters
newAuthority
string
The signing key of the new contract maintenance authority.
Returns
Promise<FinalizedTxData>
A promise that resolves with the finalized transaction data, or rejects if an error occurs along the way.
Throws
When transaction fails in either guaranteed or fallible phase. The error contains the finalized transaction data for debugging.