2017-06-07 16:14:01 +01:00
|
|
|
Transaction tear-offs
|
|
|
|
=====================
|
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
Suppose we want to construct a transaction that includes commands containing interest rate fix data as in
|
|
|
|
:doc:`oracles`. Before sending the transaction to the oracle to obtain its signature, we need to filter out every part
|
|
|
|
of the transaction except for the ``Fix`` commands.
|
2017-06-07 16:14:01 +01:00
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
To do so, we need to create a filtering function that specifies which fields of the transaction should be included.
|
|
|
|
Each field will only be included if the filtering function returns `true` when the field is passed in as input.
|
2017-06-07 16:14:01 +01:00
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
.. container:: codeset
|
2017-06-07 16:14:01 +01:00
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
.. literalinclude:: ../../docs/source/example-code/src/main/kotlin/net/corda/docs/tutorial/tearoffs/TutorialTearOffs.kt
|
|
|
|
:language: kotlin
|
|
|
|
:start-after: DOCSTART 1
|
|
|
|
:end-before: DOCEND 1
|
|
|
|
:dedent: 4
|
2017-06-07 16:14:01 +01:00
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
We can now use our filtering function to construct a ``FilteredTransaction``:
|
2017-06-07 16:14:01 +01:00
|
|
|
|
|
|
|
.. container:: codeset
|
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
.. literalinclude:: ../../docs/source/example-code/src/main/kotlin/net/corda/docs/tutorial/tearoffs/TutorialTearOffs.kt
|
|
|
|
:language: kotlin
|
|
|
|
:start-after: DOCSTART 2
|
|
|
|
:end-before: DOCEND 2
|
|
|
|
:dedent: 4
|
2017-06-07 16:14:01 +01:00
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
In the Oracle example this step takes place in ``RatesFixFlow`` by overriding the ``filtering`` function. See
|
2017-06-07 16:14:01 +01:00
|
|
|
:ref:`filtering_ref`.
|
|
|
|
|
|
|
|
``FilteredTransaction`` holds ``filteredLeaves`` (data that we wanted to reveal) and Merkle branch for them.
|
|
|
|
|
|
|
|
.. container:: codeset
|
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
.. literalinclude:: ../../docs/source/example-code/src/main/kotlin/net/corda/docs/tutorial/tearoffs/TutorialTearOffs.kt
|
|
|
|
:language: kotlin
|
|
|
|
:start-after: DOCSTART 3
|
|
|
|
:end-before: DOCEND 3
|
|
|
|
:dedent: 4
|
2017-06-07 16:14:01 +01:00
|
|
|
|
2017-10-02 10:11:33 +01:00
|
|
|
The following code snippet is taken from ``NodeInterestRates.kt`` and implements a signing part of an Oracle.
|
2017-06-07 16:14:01 +01:00
|
|
|
|
|
|
|
.. literalinclude:: ../../samples/irs-demo/src/main/kotlin/net/corda/irs/api/NodeInterestRates.kt
|
|
|
|
:language: kotlin
|
|
|
|
:start-after: DOCSTART 1
|
|
|
|
:end-before: DOCEND 1
|
2017-10-02 10:11:33 +01:00
|
|
|
:dedent: 8
|
2017-06-07 16:14:01 +01:00
|
|
|
|
|
|
|
.. note:: The way the ``FilteredTransaction`` is constructed ensures that after signing of the root hash it's impossible to add or remove
|
|
|
|
leaves. However, it can happen that having transaction with multiple commands one party reveals only subset of them to the Oracle.
|
|
|
|
As signing is done now over the Merkle root hash, the service signs all commands of given type, even though it didn't see
|
2017-10-02 10:11:33 +01:00
|
|
|
all of them. This issue will be handled after implementing partial signatures.
|