This module defines theDocumentation Index
Fetch the complete documentation index at: https://cantonfoundation-issue-365-details-history.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Allocation interface and supporting types.
Contracts implementing the Allocation interface represent a reservation of assets to transfer them as part of an atomic on-ledger settlement requested by an app.
Interfaces
interface Allocation
A contract representing an allocation of some amount of aasset holdings to a specific leg of a settlement. viewtype AllocationView
Choice Allocation_CancelCancel the allocation. Requires authorization from sender, receiver, and executor. Typically this authorization is granted by sender and receiver to the executor as part of the contract coordinating the settlement, so that that the executor can release the allocated assets early in case the settlement is aborted or it has definitely failed. Controller: allocationControllers (view this) Returns: Allocation_CancelResult
Field Type Description extraArgs ExtraArgs Additional context required in order to exercise the choice. Choice Allocation_ExecuteTransferExecute the transfer of the allocated assets. Intended to be used to execute the settlement. This choice SHOULD succeed provided thesettlement.settleBeforedeadline has not yet passed. Controller: allocationControllers (view this) Returns: Allocation_ExecuteTransferResult
Field Type Description extraArgs ExtraArgs Additional context required in order to exercise the choice. Choice Allocation_WithdrawWithdraw the allocated assets. Used by the sender to withdraw the assets before settlement was completed. This SHOULD not fail settlement if the sender has still time to allocate the assets again; i.e., thesettlement.allocateBeforedeadline has not yet passed. Controller: (DA.Internal.Record.getField @“sender” (DA.Internal.Record.getField @“transferLeg” (DA.Internal.Record.getField @“allocation” (view this)))) Returns: Allocation_WithdrawResult
Field Type Description extraArgs ExtraArgs Additional context required in order to exercise the choice. - Choice Archive Controller: Signatories of implementing template Returns: () (no fields)
- Method allocation_cancelImpl : ContractId Allocation -> Allocation_Cancel -> Update Allocation_CancelResult
- Method allocation_executeTransferImpl : ContractId Allocation -> Allocation_ExecuteTransfer -> Update Allocation_ExecuteTransferResult
- Method allocation_withdrawImpl : ContractId Allocation -> Allocation_Withdraw -> Update Allocation_WithdrawResult
Data Types
data AllocationSpecification
The specification of an allocation of assets to a specific leg of a settlement. In contrast to anAllocationViewthis just specifies what should be allocated, but not the holdings that are backing the allocation.AllocationSpecificationinstance Eq AllocationSpecification instance Show AllocationSpecification instance GetField “allocation” AllocationView AllocationSpecification instance GetField “settlement” AllocationSpecification SettlementInfo instance GetField “transferLeg” AllocationSpecification TransferLeg instance GetField “transferLegId” AllocationSpecification Text instance SetField “allocation” AllocationView AllocationSpecification instance SetField “settlement” AllocationSpecification SettlementInfo instance SetField “transferLeg” AllocationSpecification TransferLeg instance SetField “transferLegId” AllocationSpecification Text
Field Type Description settlement SettlementInfo The settlement for whose execution the assets are being allocated. transferLegId Text A unique identifer for the transfer leg within the settlement. transferLeg TransferLeg The transfer for which the assets are being allocated.
data AllocationView
View of a funded allocation of assets to a specific leg of a settlement.AllocationViewinstance Eq AllocationView instance Show AllocationView instance HasFromAnyView Allocation AllocationView instance HasInterfaceView Allocation AllocationView instance GetField “allocation” AllocationView AllocationSpecification instance GetField “holdingCids” AllocationView [ContractId Holding] instance GetField “meta” AllocationView Metadata instance SetField “allocation” AllocationView AllocationSpecification instance SetField “holdingCids” AllocationView [ContractId Holding] instance SetField “meta” AllocationView Metadata
Field Type Description allocation AllocationSpecification The settlement for whose execution the assets are being allocated. holdingCids [ContractId Holding] The holdings that are backing this allocation. Provided so that that wallets can correlate the allocation with the holdings. MAY be empty for registries that do not represent their holdings on-ledger. meta Metadata Additional metadata specific to the allocation, used for extensibility.
data Allocation_CancelResult
The result of theAllocation_Cancelchoice.Allocation_CancelResultinstance Eq Allocation_CancelResult instance Show Allocation_CancelResult instance HasMethod Allocation “allocation_cancelImpl” (ContractId Allocation -> Allocation_Cancel -> Update Allocation_CancelResult) instance GetField “meta” Allocation_CancelResult Metadata instance GetField “senderHoldingCids” Allocation_CancelResult [ContractId Holding] instance SetField “meta” Allocation_CancelResult Metadata instance SetField “senderHoldingCids” Allocation_CancelResult [ContractId Holding] instance HasExercise Allocation Allocation_Cancel Allocation_CancelResult instance HasExerciseGuarded Allocation Allocation_Cancel Allocation_CancelResult instance HasFromAnyChoice Allocation Allocation_Cancel Allocation_CancelResult instance HasToAnyChoice Allocation Allocation_Cancel Allocation_CancelResult
Field Type Description senderHoldingCids [ContractId Holding] The holdings that were released back to the sender. meta Metadata Additional metadata specific to the allocation, used for extensibility.
data Allocation_ExecuteTransferResult
The result of theAllocation_ExecuteTransferchoice.Allocation_ExecuteTransferResultinstance Eq Allocation_ExecuteTransferResult instance Show Allocation_ExecuteTransferResult instance HasMethod Allocation “allocation_executeTransferImpl” (ContractId Allocation -> Allocation_ExecuteTransfer -> Update Allocation_ExecuteTransferResult) instance GetField “meta” Allocation_ExecuteTransferResult Metadata instance GetField “receiverHoldingCids” Allocation_ExecuteTransferResult [ContractId Holding] instance GetField “senderHoldingCids” Allocation_ExecuteTransferResult [ContractId Holding] instance SetField “meta” Allocation_ExecuteTransferResult Metadata instance SetField “receiverHoldingCids” Allocation_ExecuteTransferResult [ContractId Holding] instance SetField “senderHoldingCids” Allocation_ExecuteTransferResult [ContractId Holding] instance HasExercise Allocation Allocation_ExecuteTransfer Allocation_ExecuteTransferResult instance HasExerciseGuarded Allocation Allocation_ExecuteTransfer Allocation_ExecuteTransferResult instance HasFromAnyChoice Allocation Allocation_ExecuteTransfer Allocation_ExecuteTransferResult instance HasToAnyChoice Allocation Allocation_ExecuteTransfer Allocation_ExecuteTransferResult
Field Type Description senderHoldingCids [ContractId Holding] The holdings that were created for the sender. Can be used to return “change” to the sender if required. receiverHoldingCids [ContractId Holding] The holdings that were created for the receiver. meta Metadata Additional metadata specific to the transfer instruction, used for extensibility.
data Allocation_WithdrawResult
The result of theAllocation_Withdrawchoice.Allocation_WithdrawResultinstance Eq Allocation_WithdrawResult instance Show Allocation_WithdrawResult instance HasMethod Allocation “allocation_withdrawImpl” (ContractId Allocation -> Allocation_Withdraw -> Update Allocation_WithdrawResult) instance GetField “meta” Allocation_WithdrawResult Metadata instance GetField “senderHoldingCids” Allocation_WithdrawResult [ContractId Holding] instance SetField “meta” Allocation_WithdrawResult Metadata instance SetField “senderHoldingCids” Allocation_WithdrawResult [ContractId Holding] instance HasExercise Allocation Allocation_Withdraw Allocation_WithdrawResult instance HasExerciseGuarded Allocation Allocation_Withdraw Allocation_WithdrawResult instance HasFromAnyChoice Allocation Allocation_Withdraw Allocation_WithdrawResult instance HasToAnyChoice Allocation Allocation_Withdraw Allocation_WithdrawResult
Field Type Description senderHoldingCids [ContractId Holding] The holdings that were released back to the sender. meta Metadata Additional metadata specific to the allocation, used for extensibility.
data Reference
A generic type to refer to data defined within an app.Referenceinstance Eq Reference instance Show Reference instance GetField “cid” Reference (Optional AnyContractId) instance GetField “id” Reference Text instance GetField “settlementRef” SettlementInfo Reference instance SetField “cid” Reference (Optional AnyContractId) instance SetField “id” Reference Text instance SetField “settlementRef” SettlementInfo Reference
Field Type Description id Text The key that identifies the data. Can be set to the empty string if the contract-id is provided and is sufficient. cid Optional AnyContractId Optional contract-id to use for referring to contracts. This field is there for technical reasons, as contract-ids cannot be converted to text from within Daml, which is due to their full textual representation being only known after transactions have been prepared.
data SettlementInfo
The minimal set of information about a settlement that an app would like to execute.SettlementInfoinstance Eq SettlementInfo instance Show SettlementInfo instance GetField “allocateBefore” SettlementInfo Time instance GetField “executor” SettlementInfo Party instance GetField “meta” SettlementInfo Metadata instance GetField “requestedAt” SettlementInfo Time instance GetField “settleBefore” SettlementInfo Time instance GetField “settlement” AllocationSpecification SettlementInfo instance GetField “settlementRef” SettlementInfo Reference instance SetField “allocateBefore” SettlementInfo Time instance SetField “executor” SettlementInfo Party instance SetField “meta” SettlementInfo Metadata instance SetField “requestedAt” SettlementInfo Time instance SetField “settleBefore” SettlementInfo Time instance SetField “settlement” AllocationSpecification SettlementInfo instance SetField “settlementRef” SettlementInfo Reference
Field Type Description executor Party The party that is responsible for executing the settlement. settlementRef Reference Reference to the settlement that app would like to execute. requestedAt Time When the settlement was requested. Provided for display and debugging purposes, but SHOULD be in the past. allocateBefore Time Until when (exclusive) the senders are given time to allocate their assets. This field has a particular relevance with respect to instrument versioning / corporate actions, in that the settlement pertains to the instrument version resulting from the processing of all corporate actions falling strictly before the allocateBeforetime.settleBefore Time Until when (exclusive) the executor is given time to execute the settlement. SHOULD be strictly after allocateBefore.meta Metadata Additional metadata about the settlement, used for extensibility.
data TransferLeg
A specification of a transfer of holdings between two parties for the purpose of a settlement, which often requires the atomic execution of multiple legs.TransferLeginstance Eq TransferLeg instance Ord TransferLeg instance Show TransferLeg instance GetField “amount” TransferLeg Decimal instance GetField “instrumentId” TransferLeg InstrumentId instance GetField “meta” TransferLeg Metadata instance GetField “receiver” TransferLeg Party instance GetField “sender” TransferLeg Party instance GetField “transferLeg” AllocationSpecification TransferLeg instance SetField “amount” TransferLeg Decimal instance SetField “instrumentId” TransferLeg InstrumentId instance SetField “meta” TransferLeg Metadata instance SetField “receiver” TransferLeg Party instance SetField “sender” TransferLeg Party instance SetField “transferLeg” AllocationSpecification TransferLeg
Functions
allocationControllers
: AllocationView -> [Party]Convenience function to refer to the union of sender, receiver, and executor of the settlement, which jointly control the execution of the allocation.
allocation_executeTransferImpl
: Allocation -> ContractId Allocation -> Allocation_ExecuteTransfer -> Update Allocation_ExecuteTransferResult
allocation_cancelImpl
: Allocation -> ContractId Allocation -> Allocation_Cancel -> Update Allocation_CancelResult
allocation_withdrawImpl
: Allocation -> ContractId Allocation -> Allocation_Withdraw -> Update Allocation_WithdrawResult