2018-01-12 10:20:24 +00:00
|
|
|
|
Upgrading a CorDapp to a new platform version
|
|
|
|
|
=============================================
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2017-11-22 17:33:40 +00:00
|
|
|
|
These notes provide instructions for upgrading your CorDapps from previous versions, starting with the upgrade from our
|
|
|
|
|
first public Beta (:ref:`Milestone 12 <changelog_m12>`), to :ref:`V1.0 <changelog_v1>`.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2017-11-22 17:33:40 +00:00
|
|
|
|
.. contents::
|
|
|
|
|
:depth: 3
|
|
|
|
|
|
|
|
|
|
General rules
|
|
|
|
|
-------------
|
2018-01-13 11:00:01 +00:00
|
|
|
|
Always remember to update the version identifiers in your project gradle file. For example, Corda V1.0 uses:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
ext.corda_release_version = '1.0.0'
|
2018-01-13 11:00:01 +00:00
|
|
|
|
ext.corda_release_distribution = 'net.corda'
|
2017-10-03 16:32:11 +00:00
|
|
|
|
ext.corda_gradle_plugins_version = '1.0.0'
|
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
It may be necessary to update the version of major dependencies. Corda V1.0 uses:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
ext.kotlin_version = '1.1.4'
|
|
|
|
|
ext.quasar_version = '0.7.9'
|
2018-01-13 11:00:01 +00:00
|
|
|
|
ext.junit_version = '4.12'
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Please consult the relevant release notes of the release in question. If not specified, you may assume the
|
|
|
|
|
versions you are currently using are still in force.
|
|
|
|
|
|
|
|
|
|
We also strongly recommend cross referencing with the :doc:`changelog` to confirm changes.
|
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
V1.0 and V2.0 to R3 Corda V3.0 Developer Preview
|
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
|
|
|
|
Build
|
|
|
|
|
^^^^^
|
|
|
|
|
|
|
|
|
|
* Update the version identifiers in your project gradle file(s):
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
ext.corda_release_version = 'R3.CORDA-3.0.0-DEV-PREVIEW' // "CORDA-3.0.0-DEV-PREVIEW" (Open Source)
|
|
|
|
|
ext.corda_gradle_plugins_version = '3.0.3'
|
|
|
|
|
|
|
|
|
|
* Add a new release identifier to specify the R3 release of corda:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
ext.corda_release_distribution = 'com.r3.corda' // "net.corda" for Corda (Open Source)
|
|
|
|
|
|
|
|
|
|
* Add an additional repository entry to point to the location of the R3 Corda distribution:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
repositories {
|
|
|
|
|
maven {
|
|
|
|
|
credentials {
|
|
|
|
|
username "r3-corda-dev-preview"
|
|
|
|
|
password "XXXXX"
|
|
|
|
|
}
|
|
|
|
|
url 'https://ci-artifactory.corda.r3cev.com/artifactory/r3-corda-releases'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
* Corda plugins have been modularised further so the following additional gradle entries are necessary:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
dependencies {
|
|
|
|
|
classpath "net.corda.plugins:cordapp:$corda_gradle_plugins_version"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
apply plugin: 'net.corda.plugins.cordapp'
|
|
|
|
|
|
|
|
|
|
The plugin needs to be applied in all gradle build files where there is a dependency on Corda using any of:
|
|
|
|
|
cordaCompile, cordaRuntime, cordapp
|
|
|
|
|
|
|
|
|
|
* Corda Gradle plugins require Gradle version 4.1 or above
|
|
|
|
|
|
|
|
|
|
* All gradle compile, test, and run-time dependencies (except gradle plugins) to Corda artifacts should now use the
|
|
|
|
|
``corda_release_distribution`` variable (was previously hardcoded to use ``net.corda``):
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
dependencies {
|
|
|
|
|
|
|
|
|
|
// Corda integration dependencies
|
|
|
|
|
cordaCompile "$corda_release_distribution:corda-core:$corda_release_version"
|
|
|
|
|
cordaCompile "$corda_release_distribution:corda-finance:$corda_release_version"
|
|
|
|
|
cordaCompile "$corda_release_distribution:corda-jackson:$corda_release_version"
|
|
|
|
|
cordaCompile "$corda_release_distribution:corda-rpc:$corda_release_version"
|
|
|
|
|
cordaCompile "$corda_release_distribution:corda-node-api:$corda_release_version"
|
|
|
|
|
cordaCompile "$corda_release_distribution:corda-webserver-impl:$corda_release_version"
|
|
|
|
|
cordaRuntime "$corda_release_distribution:corda:$corda_release_version"
|
|
|
|
|
cordaRuntime "$corda_release_distribution:corda-webserver:$corda_release_version"
|
|
|
|
|
|
|
|
|
|
testCompile "$corda_release_distribution:corda-node-driver:$corda_release_version"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
* For existing contract ORM schemas that extend from `CommonSchemaV1.LinearState` or `CommonSchemaV1.FungibleState`,
|
|
|
|
|
you will need to explicitly map the `participants` collection to a database table. Previously this mapping was done in the
|
|
|
|
|
superclass, but that makes it impossible to properly configure the table name.
|
|
|
|
|
The required change is to add the ``override var participants: MutableSet<AbstractParty>? = null`` field to your class, and
|
|
|
|
|
add JPA mappings. For ex., see this example:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
@Entity
|
|
|
|
|
@Table(name = "cash_states_v2",
|
|
|
|
|
indexes = arrayOf(Index(name = "ccy_code_idx2", columnList = "ccy_code")))
|
|
|
|
|
class PersistentCashState(
|
|
|
|
|
|
|
|
|
|
@ElementCollection
|
|
|
|
|
@Column(name = "participants")
|
|
|
|
|
@CollectionTable(name="cash_states_v2_participants", joinColumns = arrayOf(
|
|
|
|
|
JoinColumn(name = "output_index", referencedColumnName = "output_index"),
|
|
|
|
|
JoinColumn(name = "transaction_id", referencedColumnName = "transaction_id")))
|
|
|
|
|
override var participants: MutableSet<AbstractParty>? = null,
|
|
|
|
|
|
|
|
|
|
Configuration
|
|
|
|
|
^^^^^^^^^^^^^
|
|
|
|
|
Applies to both gradle deployNodes tasks and/or corda node configuration (node.conf).
|
|
|
|
|
|
|
|
|
|
* Remove any references to ``networkMap``.
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
networkMap "O=Agent,L=Dallas,C=US"
|
|
|
|
|
|
|
|
|
|
* Remove any references to ``advertisedServices`` (including notaries).
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
advertisedServices = ["corda.notary.validating"]
|
|
|
|
|
|
|
|
|
|
* Add an explicit notary definition in the Notary node configuration only:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
|
|
|
|
notary = [validating : true]
|
2017-10-19 14:06:51 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* For existing contract ORM schemas that extend from ``CommonSchemaV1.LinearState`` or ``CommonSchemaV1.FungibleState``,
|
|
|
|
|
you will need to explicitly map the ``participants`` collection to a database table. Previously this mapping was done
|
|
|
|
|
in the superclass, but that makes it impossible to properly configure the table name. The required changes are to:
|
2018-01-10 11:42:08 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Add the ``override var participants: MutableSet<AbstractParty>? = null`` field to your class, and
|
|
|
|
|
* Add JPA mappings
|
2018-01-10 11:42:08 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
For example:
|
2018-01-10 11:42:08 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
@Entity
|
|
|
|
|
@Table(name = "cash_states_v2",
|
|
|
|
|
indexes = arrayOf(Index(name = "ccy_code_idx2", columnList = "ccy_code")))
|
|
|
|
|
class PersistentCashState(
|
|
|
|
|
|
|
|
|
|
@ElementCollection
|
|
|
|
|
@Column(name = "participants")
|
|
|
|
|
@CollectionTable(name="cash_states_v2_participants", joinColumns = arrayOf(
|
|
|
|
|
JoinColumn(name = "output_index", referencedColumnName = "output_index"),
|
|
|
|
|
JoinColumn(name = "transaction_id", referencedColumnName = "transaction_id")))
|
|
|
|
|
override var participants: MutableSet<AbstractParty>? = null,
|
2018-01-10 11:42:08 +00:00
|
|
|
|
|
2018-04-04 17:01:35 +00:00
|
|
|
|
* Shell - to use Shell ensure ``rpcSettings.address`` and ``rpcSettings.adminAddress`` settings are present.
|
|
|
|
|
|
2017-10-19 14:06:51 +00:00
|
|
|
|
Testing
|
2018-01-13 11:00:01 +00:00
|
|
|
|
^^^^^^^
|
|
|
|
|
|
|
|
|
|
Contract tests
|
|
|
|
|
~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
|
|
* You must now create a ``MockServices`` object.
|
|
|
|
|
|
|
|
|
|
``MockServices`` provides a mock identity, key and storage service. ``MockServices`` takes as its first argument a
|
|
|
|
|
list of the CorDapp packages to scan:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
private val ledgerServices = MockServices(listOf("net.corda.examples.obligation", "net.corda.testing.contracts"))
|
|
|
|
|
|
|
|
|
|
``MockServices`` replaces the use of ``setCordappPackages`` and ``unsetCordappPackages``.
|
|
|
|
|
|
|
|
|
|
* ``ledger`` is now defined as a ``MockServices`` method. This means that:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
ledger {
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
ledgerServices.ledger {
|
|
|
|
|
|
|
|
|
|
* Within a mock ledger transaction, ``ContractState`` instances are passed to ``input`` and ``output`` as objects
|
|
|
|
|
rather than lambdas. For example:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
ledgerServices.ledger {
|
|
|
|
|
transaction {
|
|
|
|
|
input(OBLIGATION_CONTRACT_ID, DummyState())
|
|
|
|
|
output(OBLIGATION_CONTRACT_ID, oneDollarObligation)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
* Within a mock ledger transaction, ``CommandData`` instances are passed to ``input`` and ``output`` as objects
|
|
|
|
|
rather than lambdas, and the public keys must be passed as a list if there is more than one. For example:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
ledgerServices.ledger {
|
|
|
|
|
transaction {
|
|
|
|
|
command(alice.publicKey, ObligationContract.Commands.Issue())
|
|
|
|
|
command(listOf(alice.publicKey, bob.publicKey), ObligationContract.Commands.Issue())
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
* The predefined test identities (e.g. ``ALICE`` and ``MINI_CORP``) have been removed.
|
|
|
|
|
|
|
|
|
|
You must now define the test identities explicitly. For example:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
val alice = TestIdentity(CordaX500Name(organisation = "Alice", locality = "TestLand", country = "GB"))
|
|
|
|
|
|
|
|
|
|
``TestIdentity`` exposes methods to get the ``name``, ``keyPair``, ``publicKey``, ``party`` and ``identity`` of the
|
|
|
|
|
underlying ``TestIdentity``
|
|
|
|
|
|
|
|
|
|
* Explicit invocation of transaction transformation (ie. using ``TransactionBuilder``) requires serialization engine
|
|
|
|
|
to be initialized. In unit test this can be achieved by using the following jUnit rule:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
@Rule
|
|
|
|
|
@JvmField
|
|
|
|
|
val testSerialization = SerializationEnvironmentRule()
|
|
|
|
|
|
|
|
|
|
Flow tests
|
|
|
|
|
~~~~~~~~~~
|
2017-10-19 14:06:51 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* The registration mechanism for CorDapps in ``MockNetwork`` unit tests has changed:
|
2017-10-19 14:06:51 +00:00
|
|
|
|
|
2018-01-25 17:51:13 +00:00
|
|
|
|
* CorDapp registration is now done via the ``cordappPackages`` constructor parameter of MockNetwork.
|
|
|
|
|
This parameter
|
|
|
|
|
is a list of ``String`` values which should be the
|
|
|
|
|
package names of the CorDapps containing the contract verification code you wish to load
|
|
|
|
|
*The ``unsetCordappPackages`` method is now redundant and has been removed
|
2017-10-19 14:06:51 +00:00
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
* Creation of Notaries in ``MockNetwork`` unit tests has changed.
|
|
|
|
|
|
|
|
|
|
Previously the API call ``createNotaryNode(legalName = CordaX500ame(...))`` would be used to create a notary:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
val notary = mockNetwork.createNotaryNode(legalName = CordaX500Name("Notary", "London", "UK"))
|
|
|
|
|
|
|
|
|
|
Notaries are now defined as part of ``MockNetwork`` creation using ``notarySpecs``, as in the following example:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
mockNetwork = MockNetwork(notarySpecs = listOf(MockNetwork.NotarySpec(CordaX500Name("Notary","London","UK"))))
|
|
|
|
|
|
|
|
|
|
* A notary is no longer specified when creating a standard node using the ``createPartyNode`` API call.
|
|
|
|
|
|
|
|
|
|
Previously:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
mockNetwork.createPartyNode(notary.network.myAddress, CordaX500Name("Node", "Madrid", "ES"))
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
mockNetwork.createPartyNode(CordaX500Name("Node", "Madrid", "ES"))
|
|
|
|
|
|
|
|
|
|
* Utility node creation API method ``createSomeNodes(...)`` has been removed, and nodes must be created individually.
|
|
|
|
|
|
|
|
|
|
Previously:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: java
|
|
|
|
|
|
|
|
|
|
MockNetwork.BasketOfNodes nodes = net.createSomeNodes(3);
|
|
|
|
|
nodeA = nodes.getPartyNodes().get(0);
|
|
|
|
|
nodeB = nodes.getPartyNodes().get(1);
|
|
|
|
|
nodeC = nodes.getPartyNodes().get(2);
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: java
|
|
|
|
|
|
|
|
|
|
nodeA = net.createNode(new MockNodeParameters());
|
|
|
|
|
nodeB = net.createNode(new MockNodeParameters());
|
|
|
|
|
nodeC = net.createNode(new MockNodeParameters());
|
|
|
|
|
List<StartedNode<MockNode>> nodes = Arrays.asList(nodeA, nodeB, nodeC);
|
|
|
|
|
|
|
|
|
|
* Flow framework instantiation of a flow has a slight variation in start syntax:
|
|
|
|
|
|
|
|
|
|
Previously:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: java
|
|
|
|
|
|
|
|
|
|
CordaFuture<SignedTransaction> future = nodeA.getServices().startFlow(flow).getResultFuture();
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: java
|
|
|
|
|
|
|
|
|
|
CordaFuture<SignedTransaction> future = startFlow(nodeA.getServices(), flow).getResultFuture();
|
|
|
|
|
|
|
|
|
|
* ``StartedNodeServices.startFlow`` must now be imported from ``net.corda.testing.node``
|
|
|
|
|
|
|
|
|
|
* Do not use ``node.internals`` to register flows:
|
|
|
|
|
|
|
|
|
|
Previous code would often look as follows:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
protected fun registerFlowsAndServices(node: StartedNode<MockNetwork.MockNode>) {
|
|
|
|
|
val mockNode = node.internals
|
|
|
|
|
mockNode.registerInitiatedFlow(MyCustomFlow::class.java)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
protected fun registerFlowsAndServices(mockNode: StartedNode<MockNetwork.MockNode>) {
|
|
|
|
|
mockNode.registerInitiatedFlow(MyCustomFlow::class.java)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
* Do not use ``node.internals`` to register Corda services
|
|
|
|
|
|
|
|
|
|
Previously:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
node.internals.installCordaService(CustomService::class.java)
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
node.services.cordaService(CustomService::class.java)
|
|
|
|
|
|
|
|
|
|
Better yet, use node factory to organize both register flows and services, for example, create class as follows:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
class PrimesOracleNode(args: MockNodeArgs) : MockNetwork.MockNode(args) {
|
|
|
|
|
override fun start() = super.start().apply {
|
|
|
|
|
registerInitiatedFlow(QueryHandler::class.java)
|
|
|
|
|
registerInitiatedFlow(SignHandler::class.java)
|
|
|
|
|
services.cordaService(net.corda.examples.oracle.service.service.Oracle::class.java)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
and then pass it to ``createNode``:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
val oracle = mockNet.createNode(MockNodeParameters(legalName = CordaX500Name("Oracle", "New York", "US")), ::PrimesOracleNode)
|
|
|
|
|
|
|
|
|
|
Node driver
|
|
|
|
|
~~~~~~~~~~~
|
|
|
|
|
|
|
|
|
|
* ``User`` has been moved from ``net.corda.nodeapi.User`` to ``net.corda.nodeapi.internal.config.User``
|
|
|
|
|
|
|
|
|
|
* Notaries are defined by passing a list of ``NotarySpec`` objects to ``driver`` using the ``notarySpecs`` argument,
|
|
|
|
|
instead of being defined manually in the driver block.
|
|
|
|
|
|
|
|
|
|
``notarySpecs`` defaults to providing a single validating notary
|
|
|
|
|
|
|
|
|
|
* The ``waitForAllNodesToFinish`` function has been removed. It has been replaced with a ``waitForAllNodesToFinish``
|
|
|
|
|
argument to ``driver``
|
|
|
|
|
|
|
|
|
|
* No longer specify advertised services to the ``DriverDSL`` when starting nodes:
|
|
|
|
|
|
|
|
|
|
Previously:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
driver {
|
|
|
|
|
startNode(providedName = CordaX500Name("Controller", "London", "GB"), advertisedServices = setOf(ServiceInfo(ValidatingNotaryService.type)))
|
|
|
|
|
|
|
|
|
|
Becomes:
|
|
|
|
|
|
|
|
|
|
.. sourcecode:: kotlin
|
|
|
|
|
|
|
|
|
|
driver {
|
|
|
|
|
startNode(providedName = CordaX500Name("Controller", "London", "GB")),
|
|
|
|
|
|
|
|
|
|
Finance
|
|
|
|
|
^^^^^^^
|
|
|
|
|
|
|
|
|
|
* ``CASH_PROGRAM_ID`` has been moved to ``Cash.PROGRAM_ID``, where ``Cash`` is defined in the
|
|
|
|
|
``import net.corda.finance.contracts.asset`` package
|
|
|
|
|
|
2017-11-22 17:33:40 +00:00
|
|
|
|
V1.0 to V2.0
|
2017-10-03 16:32:11 +00:00
|
|
|
|
------------
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You need to update the ``corda_release_version`` identifier in your project gradle file. The
|
|
|
|
|
corda_gradle_plugins_version should remain at 1.0.0:
|
2017-11-22 17:33:40 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
.. sourcecode:: shell
|
2017-11-22 17:33:40 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
ext.corda_release_version = '2.0.0'
|
|
|
|
|
ext.corda_gradle_plugins_version = '1.0.0'
|
2017-11-22 17:33:40 +00:00
|
|
|
|
|
|
|
|
|
Public Beta (M12) to V1.0
|
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
|
|
:ref:`From Milestone 14 <changelog_m14>`
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
|
|
Build
|
2017-10-03 16:32:11 +00:00
|
|
|
|
^^^^^
|
|
|
|
|
|
|
|
|
|
* MockNetwork has moved.
|
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
A new test driver module dependency needs to be including in your project: ``corda-node-driver``. To continue using the
|
2017-10-03 16:32:11 +00:00
|
|
|
|
mock network for testing, add the following entry to your gradle build file:
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
.. sourcecode:: shell
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-25 17:51:13 +00:00
|
|
|
|
testCompile "$corda_release_distribution:corda-node-driver:$corda_release_version"
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-25 17:51:13 +00:00
|
|
|
|
.. note:: You may only need ``testCompile "$corda_release_distribution:corda-test-utils:$corda_release_version"`` if not using the Driver
|
2018-01-18 11:10:52 +00:00
|
|
|
|
DSL
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Configuration
|
|
|
|
|
^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``CordaPluginRegistry`` has been removed:
|
|
|
|
|
|
|
|
|
|
* The one remaining configuration item ``customizeSerialisation``, which defined a optional whitelist of types for
|
|
|
|
|
use in object serialization, has been replaced with the ``SerializationWhitelist`` interface which should be
|
|
|
|
|
implemented to define a list of equivalent whitelisted classes
|
|
|
|
|
|
|
|
|
|
* You will need to rename your services resource file. 'resources/META-INF/services/net.corda.core.node.CordaPluginRegistry'
|
|
|
|
|
becomes 'resources/META-INF/services/net.corda.core.serialization.SerializationWhitelist'
|
|
|
|
|
|
|
|
|
|
* ``MockNode.testPluginRegistries`` was renamed to ``MockNode.testSerializationWhitelists``
|
|
|
|
|
|
|
|
|
|
* In general, the ``@CordaSerializable`` annotation is the preferred method for whitelisting, as described in
|
|
|
|
|
:doc:`serialization`
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Missing imports
|
|
|
|
|
^^^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
Use IntelliJ's automatic imports feature to intelligently resolve the new imports:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Missing imports for contract types:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* CommercialPaper and Cash are now contained within the ``finance`` module, as are associated helpers functions. For
|
|
|
|
|
example:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
CommercialPaper and Cash are now contained within the ``finance`` module, as are associated helpers functions.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
For example:
|
|
|
|
|
``import net.corda.contracts.ICommercialPaperState`` becomes ``import net.corda.finance.contracts.ICommercialPaperState``
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.contracts.asset.sumCashBy`` becomes ``import net.corda.finance.utils.sumCashBy``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.core.contracts.DOLLARS`` becomes ``import net.corda.finance.DOLLARS``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.core.contracts.issued by`` becomes ``import net.corda.finance.issued by``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.contracts.asset.Cash`` becomes ``import net.corda.finance.contracts.asset.Cash``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Missing imports for utility functions:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Many common types and helper methods have been consolidated into ``net.corda.core.utilities`` package. For example:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.core.crypto.commonName`` becomes ``import net.corda.core.utilities.commonName``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.core.crypto.toBase58String`` becomes ``import net.corda.core.utilities.toBase58String``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``import net.corda.core.getOrThrow`` becomes ``import net.corda.core.utilities.getOrThrow``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Missing flow imports:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* In general, all reusable library flows are contained within the **core** API ``net.corda.core.flows`` package
|
|
|
|
|
|
|
|
|
|
* Financial domain library flows are contained within the **finance** module ``net.corda.finance.flows`` package
|
|
|
|
|
|
|
|
|
|
* Other flows that have moved include ``import net.corda.core.flows.ResolveTransactionsFlow``, which becomes
|
|
|
|
|
``import net.corda.core.internal.ResolveTransactionsFlow``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Core data structures
|
|
|
|
|
^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Missing ``Contract`` override:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``Contract.legalContractReference`` has been removed, and replaced by the optional annotation
|
|
|
|
|
``@LegalProseReference(uri = "<URI>")``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Unresolved reference:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``AuthenticatedObject`` was renamed to ``CommandWithParties``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Overrides nothing:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``LinearState.isRelevant`` was removed. Whether a node stores a ``LinearState`` in its vault depends on whether the
|
|
|
|
|
node is one of the state's ``participants``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``txBuilder.toLedgerTransaction`` now requires a ``ServiceHub`` parameter. This is used by the new Contract
|
|
|
|
|
Constraints functionality to validate and resolve attachments
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Flow framework
|
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``FlowLogic`` communication has been upgraded to use explicit ``FlowSession`` instances to communicate between nodes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``FlowLogic.send``/``FlowLogic.receive``/``FlowLogic.sendAndReceive`` has been replaced by ``FlowSession.send``/
|
|
|
|
|
``FlowSession.receive``/``FlowSession.sendAndReceive``. The replacement functions do not take a destination
|
|
|
|
|
parameter, as this is defined implictly by the session used
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
* Initiated flows now take in a ``FlowSession`` instead of ``Party`` in their constructor. If you need to access the
|
2018-01-18 11:10:52 +00:00
|
|
|
|
counterparty identity, it is in the ``counterparty`` property of the flow session
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
* ``FinalityFlow`` now returns a single ``SignedTransaction``, instead of a ``List<SignedTransaction>``
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``TransactionKeyFlow`` was renamed to ``SwapIdentitiesFlow``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``SwapIdentitiesFlow`` must be imported from the *confidential-identities* package ``net.corda.confidential``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Node services (ServiceHub)
|
2017-11-22 17:33:40 +00:00
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
* VaultQueryService: unresolved reference to ``vaultQueryService``.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Replace all references to ``<services>.vaultQueryService`` with ``<services>.vaultService``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Previously there were two vault APIs. Now there is a single unified API with the same functions: ``VaultService``.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``FlowLogic.ourIdentity`` has been introduced as a shortcut for retrieving our identity in a flow
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``serviceHub.myInfo.legalIdentity`` no longer exists
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``getAnyNotary`` has been removed. Use ``serviceHub.networkMapCache.notaryIdentities[0]`` instead
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
* ``ServiceHub.networkMapUpdates`` is replaced by ``ServiceHub.networkMapFeed``
|
|
|
|
|
|
|
|
|
|
* ``ServiceHub.partyFromX500Name`` is replaced by ``ServiceHub.wellKnownPartyFromX500Name``
|
2018-01-18 11:10:52 +00:00
|
|
|
|
|
|
|
|
|
* A "well known" party is one that isn't anonymous. This change was motivated by the confidential identities work
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
RPC Client
|
|
|
|
|
^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Missing API methods on the ``CordaRPCOps`` interface:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``verifiedTransactionsFeed`` has been replaced by ``internalVerifiedTransactionsFeed``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``verifiedTransactions`` has been replaced by ``internalVerifiedTransactionsSnapshot``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
* Accessing the ``networkMapCache`` via ``services.nodeInfo().legalIdentities`` returns a list of identities.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
The first element in the list is the Party object referring to a node's single identity.
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Accessing the ``networkMapCache`` via ``services.nodeInfo().legalIdentities`` returns a list of identities
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* This change is in preparation for allowing a node to host multiple separate identities in the future
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Testing
|
|
|
|
|
^^^^^^^
|
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
Please note that ``Clauses`` have been removed completely as of V1.0.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
We will be revisiting this capability in a future release.
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* CorDapps must be explicitly registered in ``MockNetwork`` unit tests:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
This is done by calling ``setCordappPackages``, an extension helper function in the ``net.corda.testing`` package,
|
2018-01-13 11:00:01 +00:00
|
|
|
|
on the first line of your ``@Before`` method. This takes a variable number of ``String`` arguments which should be the
|
2017-10-03 16:32:11 +00:00
|
|
|
|
package names of the CorDapps containing the contract verification code you wish to load.
|
2018-01-13 11:00:01 +00:00
|
|
|
|
You should unset CorDapp packages in your ``@After`` method by using ``unsetCordappPackages()`` after ``stopNodes()``.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* CorDapps must be explicitly registered in ``DriverDSL`` and ``RPCDriverDSL`` integration tests:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You must register package names of the CorDapps containing the contract verification code you wish to load using
|
|
|
|
|
the ``extraCordappPackagesToScan: List<String>`` constructor parameter of the driver DSL
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Finance
|
|
|
|
|
^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``FungibleAsset`` interface simplification:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
The following errors may be reported:
|
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
* override nothing (FungibleAsset): ``move``
|
|
|
|
|
* not a subtype of overridden FungibleAsset: ``withNewOwner``
|
|
|
|
|
* no longer need to override ``override val contractHash: SecureHash? = null``
|
|
|
|
|
* need to override ``override val contract: Class<out Contract>? = null``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Miscellaneous
|
|
|
|
|
^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
|
|
* ``args[0].parseNetworkHostAndPort()`` becomes ``NetworkHostAndPort.parse(args[0])``
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* There is no longer a ``NodeInfo.advertisedServices`` property
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* The concept of advertised services has been removed from Corda. This is because it was vaguely defined and
|
|
|
|
|
real-world apps would not typically select random, unknown counterparties from the network map based on
|
|
|
|
|
self-declared capabilities
|
|
|
|
|
* We will introduce a replacement for this functionality, business networks, in a future release
|
|
|
|
|
* For now, services should be retrieved by legal name using ``NetworkMapCache.getNodeByLegalName``
|
2017-10-16 14:15:02 +00:00
|
|
|
|
|
2017-10-03 16:32:11 +00:00
|
|
|
|
Gotchas
|
|
|
|
|
^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Be sure to use the correct identity when issuing cash:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* The third parameter to ``CashIssueFlow`` should be the *notary* (and not the *node identity*)
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
|
2017-11-22 17:33:40 +00:00
|
|
|
|
:ref:`From Milestone 13 <changelog_m13>`
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Core data structures
|
|
|
|
|
^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``TransactionBuilder`` changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Use convenience class ``StateAndContract`` instead of ``TransactionBuilder.withItems`` for passing
|
|
|
|
|
around a state and its contract.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Transaction builder DSL changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
* now need to explicitly pass the ContractClassName into all inputs and outputs.
|
2018-01-13 11:00:01 +00:00
|
|
|
|
* ``ContractClassName`` refers to the class containing the “verifier” method.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``ContractClassName`` is the name of the ``Contract`` subclass used to verify the transaction
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Contract verify method signature change:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``override fun verify(tx: TransactionForContract)`` becomes ``override fun verify(tx: LedgerTransaction)``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You no longer need to override ``ContractState.contract`` function
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Node services (ServiceHub)
|
2017-11-22 17:33:40 +00:00
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ServiceHub API method changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``services.networkMapUpdates().justSnapshot`` becomes ``services.networkMapSnapshot()``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Configuration
|
|
|
|
|
^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* No longer need to define ``CordaPluginRegistry`` and configure ``requiredSchemas``:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Custom contract schemas are automatically detected at startup time by class path scanning
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* For testing purposes, use the ``SchemaService`` method to register new custom schemas (e.g.
|
|
|
|
|
``services.schemaService.registerCustomSchemas(setOf(YoSchemaV1))``)
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Identity
|
|
|
|
|
^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Party names are now ``CordaX500Name``, not ``X500Name``:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``CordaX500Name`` specifies a predefined set of mandatory (organisation, locality, country) and optional fields
|
|
|
|
|
(common name, organisation unit, state) with validation checking
|
|
|
|
|
* Use new builder ``CordaX500Name.build(X500Name(target))`` or explicitly define the X500Name parameters using the
|
|
|
|
|
``CordaX500Name`` constructors
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Testing
|
|
|
|
|
^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* MockNetwork testing:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Mock nodes in node tests are now of type ``StartedNode<MockNode>``, rather than ``MockNode``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``MockNetwork`` now returns a ``BasketOf(<StartedNode<MockNode>>)``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You must call internals on ``StartedNode`` to get ``MockNode`` (e.g. ``a = nodes.partyNodes[0].internals``)
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Host and port changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Use string helper function ``parseNetworkHostAndPort`` to parse a URL on startup (e.g.
|
|
|
|
|
``val hostAndPort = args[0].parseNetworkHostAndPort()``)
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Node driver parameter changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* The node driver parameters for starting a node have been reordered
|
|
|
|
|
* The node’s name needs to be given as an ``CordaX500Name``, instead of using ``getX509Name``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2017-11-22 17:33:40 +00:00
|
|
|
|
:ref:`From Milestone 12 (First Public Beta) <changelog_m12>`
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Core data structures
|
|
|
|
|
^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Transaction building:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You no longer need to specify the type of a ``TransactionBuilder`` as ``TransactionType.General``
|
|
|
|
|
* ``TransactionType.General.Builder(notary)`` becomes ``TransactionBuilder(notary)``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Build
|
|
|
|
|
^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Gradle dependency reference changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Module names have changed to include ``corda`` in the artifacts' JAR names:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
.. sourcecode:: shell
|
|
|
|
|
|
2018-01-13 11:00:01 +00:00
|
|
|
|
compile "$corda_release_distribution:core:$corda_release_version" -> compile "$corda_release_distribution:corda-core:$corda_release_version"
|
|
|
|
|
compile "$corda_release_distribution:finance:$corda_release_version" -> compile "$corda_release_distribution:corda-finance:$corda_release_version"
|
|
|
|
|
compile "$corda_release_distribution:jackson:$corda_release_version" -> compile "$corda_release_distribution:corda-jackson:$corda_release_version"
|
|
|
|
|
compile "$corda_release_distribution:node:$corda_release_version" -> compile "$corda_release_distribution:corda-node:$corda_release_version"
|
|
|
|
|
compile "$corda_release_distribution:rpc:$corda_release_version" -> compile "$corda_release_distribution:corda-rpc:$corda_release_version"
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Node services (ServiceHub)
|
2017-11-22 17:33:40 +00:00
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``ServiceHub`` API changes:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``services.networkMapUpdates`` becomes ``services.networkMapFeed``
|
|
|
|
|
|
|
|
|
|
* ``services.getCashBalances`` becomes a helper method in the *finance* module contracts package
|
|
|
|
|
(``net.corda.finance.contracts.getCashBalances``)
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
Finance
|
|
|
|
|
^^^^^^^
|
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Financial asset contracts (``Cash``, ``CommercialPaper``, ``Obligations``) are now a standalone CorDapp within the
|
|
|
|
|
``finance`` module:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You need to import them from their respective packages within the ``finance`` module (e.g.
|
|
|
|
|
``net.corda.finance.contracts.asset.Cash``)
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* You need to import the associated asset flows from their respective packages within ``finance`` module. For
|
|
|
|
|
example:
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* ``net.corda.finance.flows.CashIssueFlow``
|
|
|
|
|
* ``net.corda.finance.flows.CashIssueAndPaymentFlow``
|
|
|
|
|
* ``net.corda.finance.flows.CashExitFlow``
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
|
|
|
|
This may require adjusting imports of Cash flow references and also of ``StartFlow`` permission in ``gradle.build`` files.
|
2018-01-13 11:00:01 +00:00
|
|
|
|
Associated flows (``Cash*Flow``, ``TwoPartyTradeFlow``, ``TwoPartyDealFlow``) must now be imported from this package.
|
2017-10-03 16:32:11 +00:00
|
|
|
|
|
2018-01-18 11:10:52 +00:00
|
|
|
|
* Adjust imports of Cash flow references
|
|
|
|
|
* Adjust the ``StartFlow`` permission in ``gradle.build`` files
|
|
|
|
|
* Adjust imports of the associated flows (``Cash*Flow``, ``TwoPartyTradeFlow``, ``TwoPartyDealFlow``)
|