Payment service flows
Use Payment Service flows to initiate payments and account management requests from a node on a Corda network. These requests can then be picked up by the Payments Agent on your network.
Use the Payment Service flows to:
- Create a request for a payment to be made. MakePayment.
- Reinstate a stalled payment into the payment workflow. ReinstatePayment.
- Cancel a stalled payment. CancelPayment.
- Update and reinstate a stalled payment into the payment workflow. RemediatePayment.
- Return the list of payments stalled on an error. StalledPayments.
- Return the payment state associated with a specific payment ID or provided transaction reference. PaymentById.
- Return the PSPs that are configured on the system and available to use. AvailablePSPs.
- Return a PSP specification from the Payments Agent. PspSpecification.
- Add a payment account for an existing account on the PSP. AddPaymentAccount.
- Create a customer account for an existing customer on the PSP. CreateCustomerAccount.
- Add a beneficiary account for an external customer. AddBeneficiaryAccount.
- Update payment account details. UpdatePaymentAccount.
- Update a beneficiary account details. UpdateBeneficiaryAccount.
- Return a list of payment accounts held by the owning party. PaymentAccounts.
- Return the payment account associated with a payment account ID. PaymentAccountId.
- Return a list of transactions made against this account. Transactions
- Return a list of payments made on the system by a given payment account. Payments.
- Return the account balance for a given payment account ID. AccountBalance.
- Return the current default payments agent. GetPaymentAgent.
MakePayment
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Initiate a payment between participating nodes on the network.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
amount
: Amount<FiatCurrency
>. Required. The amount and currency of the payment to make. In the Corda Payments Technical Preview, you can use GBP or EUR.debtor
: String. Required. A reference (signature) to debtor account (the account from which the payment is to be made—or the account from whichmakePayment
is initiated) which is in turn resolved by theAccountsResolver
service.creditor
: String. Required. A reference (signature) to creditor account (the account into which the payment is to be made) which is in turn resolved by theAccountsResolver
service.transactionRef
: String. Provided reference to the specified transaction. Bound to theexternalId
of the generatedPaymentState
’sUniqueIdentifier
. Should be unique.externalId
: String. Corresponds to the ID provided by the PSP.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentState
- The object containing information regarding the requested payment.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class MakePayment(
private val amount: Amount
private val debtor: PaymentAccountId,
private val creditor: PaymentAccountId,
private val externalRef: String?,
private val transactionRef: String?,
private val details: Map<String, Any>,
private val comments: List
) : FlowLogic
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
val paymentState = proxy.startTrackedFlow(
::MakePayment,
1 of GBP,
accountB.accountId,
accountA.accountId
).returnValue.getOrThrow()\
ReinstatePayment
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Reinstate a stalled payment into the payment workflow.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
paymentId
UUID. ID of the stalled payment to be reinstated.comment
String. User supplied comment.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentState
- The object containing information regarding the requested payment.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class ReinstatePayment(
private val uuid: UUID,
private val commandName: String,
private val comment: String?
) : ReinstatePaymentInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
val paymentState = proxy.startTrackedFlow(
::ReinstatePayment,
paymentId,
PaymentCommands.ManuallyFixedPayment(),
comment
).returnValue.getOrThrow()
CancelPayment
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Cancel a stalled payment.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
paymentId
UUID. Payment ID of the stalled payment.comment
String. User supplied comment.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentState
- The object containing information regarding the requested payment.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Both retrying a stalled payment and cancelling a stalled payment use the same flow with a different command attached.
@StartableByRPC
@StartableByService
class ReinstatePayment(
private val uuid: UUID,
private val commandName: String,
private val comment: String?
) : ReinstatePaymentInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
val paymentState = proxy.startTrackedFlow(
::ReinstatePayment,
paymentId,
PaymentCommands.ManuallyFailed(),
comment
).returnValue.getOrThrow()
RemediatePayment
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Update a stalled payment and reinstate into the payment workflow.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
payment
The updated payment state.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentState
- The object containing information regarding the requested payment.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class RemediatePayment(
private val updatedPayment: PaymentState,
private val commandName: String
) : RemediatePaymentInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
val tx = service.startFlow(
::RemediatePayment,
updatedState,
"ManuallyFixedPayment").returnValue.get()
StalledPayments
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Return a list of payments stalled on an error.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
None.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
List of PaymentState
objects for payments stalled on an error.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class StalledPayments : FlowLogic<List<PaymentState>>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
flowAwareStartFlow(StalledPayments()).getOrThrow()
PaymentById
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Return the PaymentState
associated with either a paymentId
or transactionRef
.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
You can use either of the following:
paymentId
: UUID. The unique identifier component of thePaymentState
.transactionRef
UUID. TheexternalId
component of the targetPaymentState
.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentState
- Object containing information regarding the requested payment.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class PaymentById private constructor(
private val transactionRef: String?,
private val paymentId: UUID?
) : FlowLogic<List<PaymentState>>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
flowAwareStartFlow(PaymentById(paymentId)).getOrThrow()
AvailablePSPs
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Get a list of the Payment Service Providers (PSPs) that are registered on the sent node—making them available for payments on your network.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
None.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
List<PSPSpecification>
. A list of PSP identifiers, such as “MODULR”, that are available on the system to make payments against.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class AvailablePSPs : AvailablePSPsInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
flowAwareStartFlow(AvailablePSPs()).getOrThrow()
PspSpecification
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Return the PSP specification for the named PSP on the agent. In the Corda Payments Technical Preview, the PSP can only be Modulr.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
name
. The name of the PSP.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class AvailablePSPs : AvailablePSPsInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
flowAwareStartFlow(AvailablePSPs()).getOrThrow()
AddPaymentAccount
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Create a record of an existing payment account in the application.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountName
: String. Account name to be stored against the account details that are received from the PSP (Modulr).currency
: FiatCurrency. The currency that the account should be created with.psp
: String. The PSP to create the account with. In Corda Payments Technical Preview, this can only be Modulr.agent
: Party [Optional]. The Payments Agent on your network. If not provided, the account will default to an agent configured via the node’s Payment Service CorDapp config.details
: Map<String, String> [Optional]. Additional Key-value data associated with the Payment Account. These details will be stored in the underlyingPaymentAccountDetailsState
shared between agent and node. They are not available through the returnedPaymentAccount
object.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentAccount
: Object. The payment account details.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class AddPaymentAccount(
private val accountName: String,
private val currency: FiatCurrency,
private val psp: String,
private val pspAccountId: String,
private val credentials: Map<String, String>
) : FlowLogic<PaymentAccount>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::AddPaymentAccount,
accountName,
FiatCurrency(currency),
psp,
accountId,
authDetails).returnValue.get()
CreateCustomerAccount
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Create a record of payment account linked to a specific customer in the application.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountName
. A common name for the accountcurrency
. The currency of the accountpsp
. Payment Service Provider associated with this accountcustomerId
. ID of the customer who owns the account. You should get this information from the Payments Agent on your network.pspAccountId
. OriginalaccountId
on PSP for re-registered accounts.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentAccount
: Object. The payment account details.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class AddCustomerAccount(
private val accountName: String,
private val currency: FiatCurrency,
private val psp: String,
private val customerId: PaymentCustomerId,
private val pspAccountId: String?
) : FlowLogic<PaymentAccount>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::AddCustomerAccount,
accountName,
FiatCurrency(currency),
psp,
customerId,
accountId).returnValue.get()
AddBeneficiaryAccount
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Create a local record of a beneficiary payment account for a party that is not present on the network.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountName
. A common name for the account.currency
. The currency required for the account.psp
. Payment Service Provider associated with this account.details
. Additional key-value data to be stored.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentAccount
: Object. Contains details of the payment account.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class AddBeneficiaryAccount(
private val accountName: String,
private val currency: FiatCurrency,
private val psp: String,
private val details: Map<String, String>
) : AddBeneficiaryAccountInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::AddBeneficiaryAccount,
accountName,
FiatCurrency(currency),
psp,
details).returnValue.get()
UpdatePaymentAccount
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Send a request to update the underlying PaymentAccountDetailsState
with the provided details.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
details
: Map<String, String>. Additional Key-value data associated with the Payment Account. These details are stored in the underlyingPaymentAccountDetailsState
shared between agent and node—but are not available through the returnedPaymentAccount
object.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentAccount
: Object. The payment account details.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class UpdatePaymentAccount(
private val accountId: PaymentAccountId,
private val credentials: Map<String, String>
): FlowLogic<PaymentAccount>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::UpdatePaymentAccount,
account.accountId,
authDetails).returnValue.get()
UpdateBeneficiaryAccount
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Update a beneficiary payment account details. If an existing key is provided in details
, the value will be updated. If a new key is provided, a new entry in the map will be created.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountId
. The unique account identifier.details
: Map<String, String>. Additional Key-value data associated with the Payment Account. These details are stored in the underlyingPaymentAccountDetailsState
shared between agent and node—but are not available through the returnedPaymentAccount
object.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentAccount
: Object. The payment account details.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class UpdateBeneficiaryAccount(
private val accountId: PaymentAccountId,
private val details: Map<String, String>
): FlowLogic<PaymentAccount>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::UpdateBeneficiaryAccount,
account.accountId,
details).returnValue.get()
PaymentAccounts
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Get a list of PaymentAccount
s for all the accounts owned by the party passed as a parameter.
The AccountDetails
object captures the owning key for these details which could refer to a well-known party or Corda account.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
owningParty
: AbstractParty
- the owning party of the payment accounts.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
List<PaymentAccount>
- The list of internal account references. Returns an empty list if none exist.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class PaymentAccounts(
private val owningParty: AbstractParty
) : PaymentAccountsInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::PaymentAccounts,
ownerParty).returnValue.get()
PaymentAccountById
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Get the PaymentAccount
associated with a unique account identifier (signature).
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountId
: String. A type of PaymentAccountId
.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PaymentAccount
: The payment account object.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class PaymentAccountById(private val accountId: PaymentAccountId) : PaymentAccountByIdInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::PaymentAccountById,
accountId).returnValue.get()
Transactions
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Return a list of transactions made against this account as recorded on the PSP, using the criteria given to this function.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountId
. The identifier of the account which is involved as debtor or creditor.searchCriteria
. Optional criteria to further filter transaction search.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PagedResponse<PaymentTransaction>
. A paged response of transactions.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class Transactions(
private val accountId: PaymentAccountId,
private val searchCriteria: PaymentTransactionCriteria
) : TransactionsInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::Transactions,
accountId,
searchCriteria).returnValue.get()
Payments
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Return a list of transactions made against this account as recorded on the vault, using the criteria given to this function.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountId
. The identifier of the account which is involved as debtor OR creditor.searchCriteria
. Optional criteria to further filter transaction search.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
PagedResponse<PaymentTransaction>
. A paged response of transactions.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class Payments(
private val accountId: PaymentAccountId,
private val searchCriteria: PaymentTransactionCriteria
) : FlowLogic<PagedResponse<PaymentTransaction>>()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::Payments,
accountId,
searchCriteria).returnValue.get()
AccountBalance
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Get the account balance for a given payment account ID.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
accountId
: String. The payment account ID.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
AccountBalance
. The balance of the requested account.
Flow signature
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
@StartableByRPC
@StartableByService
class ViewAccountBalance(
private val accountId: PaymentAccountId
): AccountBalanceInitiator()
Example
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
service.startFlow(
::ViewAccountBalance,
account.accountId).returnValue.get()
GetPaymentAgent
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
Returns the current default payments agent, if it has been set. The default payments agent can be set through CorDapp config.
Parameters
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
None.
Return type
data:image/s3,"s3://crabby-images/f0690/f06909cc0f359b21c57da0604ad01a7b76de5f22" alt="Click to copy the section link. heading-link-icon"
AbstractParty
.
Was this page helpful?
Thanks for your feedback!
Chat with us
Chat with us on our #docs channel on slack. You can also join a lot of other slack channels there and have access to 1-on-1 communication with members of the R3 team and the online community.
Propose documentation improvements directly
Help us to improve the docs by contributing directly. It's simple - just fork this repository and raise a PR of your own - R3's Technical Writers will review it and apply the relevant suggestions.
We're sorry this page wasn't helpful. Let us know how we can make it better!
Chat with us
Chat with us on our #docs channel on slack. You can also join a lot of other slack channels there and have access to 1-on-1 communication with members of the R3 team and the online community.
Create an issue
Create a new GitHub issue in this repository - submit technical feedback, draw attention to a potential documentation bug, or share ideas for improvement and general feedback.
Propose documentation improvements directly
Help us to improve the docs by contributing directly. It's simple - just fork this repository and raise a PR of your own - R3's Technical Writers will review it and apply the relevant suggestions.