Upon dynamically loading configured Cash Selection algorithms declared in META-INF/services
this method determines whether the loaded implementation is compatible and usable with the currently
loaded JDBC driver.
Note: the first loaded implementation to pass this check will be used at run-time.

Field Detail

Companion

Constructor Detail

CashSelectionPostgreSQLImpl

public CashSelectionPostgreSQLImpl()

Method Detail

isCompatible

public boolean isCompatible(java.sql.DatabaseMetaData metadata)

Upon dynamically loading configured Cash Selection algorithms declared in META-INF/services
this method determines whether the loaded implementation is compatible and usable with the currently
loaded JDBC driver.
Note: the first loaded implementation to pass this check will be used at run-time.

A vendor specific query(ies) to gather Cash states that are available.

Parameters:

amount - The amount of currency desired (ignoring issues, but specifying the currency)

lockId - The FlowLogic.runId.uuid of the flow, which is used to soft reserve the states.
Also, previous outputs of the flow will be eligible as they are implicitly locked with this id until the flow completes.

notary - If null the notary source is ignored, if specified then only states marked
with this notary are included.

onlyFromIssuerParties - Optional issuer parties to match against.

withIssuerRefs - Optional issuer references to match against.

withResultSet - Function that contains the business logic. The JDBC ResultSet with the matching states that were found. If sufficient funds were found these will be locked,
otherwise what is available is returned unlocked for informational purposes.