2017-11-16 15:31:52 +00:00
|
|
|
Hello, World! Pt.2 - Contract constraints
|
|
|
|
=========================================
|
2017-07-17 12:23:14 +01:00
|
|
|
|
2017-11-16 15:31:52 +00:00
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 1
|
2017-07-17 12:23:14 +01:00
|
|
|
|
2017-11-16 15:31:52 +00:00
|
|
|
tut-two-party-contract
|
|
|
|
tut-two-party-flow
|
|
|
|
|
|
|
|
.. note:: This tutorial extends the CorDapp built during the :doc:`Hello, World tutorial <hello-world-introduction>`.
|
|
|
|
|
|
|
|
In the Hello, World tutorial, we built a CorDapp allowing us to model IOUs on ledger. Our CorDapp was made up of two
|
2017-07-17 12:23:14 +01:00
|
|
|
elements:
|
|
|
|
|
|
|
|
* An ``IOUState``, representing IOUs on the ledger
|
|
|
|
* An ``IOUFlow``, orchestrating the process of agreeing the creation of an IOU on-ledger
|
|
|
|
|
2017-11-16 15:31:52 +00:00
|
|
|
However, our CorDapp did not impose any constraints on the evolution of IOUs on the ledger over time. Anyone was free
|
|
|
|
to create IOUs of any value, between any party.
|
2017-07-17 12:23:14 +01:00
|
|
|
|
2017-11-16 15:31:52 +00:00
|
|
|
In this tutorial, we'll write a contract to imposes rules on how an ``IOUState`` can change over time. In turn, this
|
|
|
|
will require some small changes to the flow we defined in the previous tutorial.
|
2017-07-17 12:23:14 +01:00
|
|
|
|
2017-11-16 15:31:52 +00:00
|
|
|
We'll start by writing the contract.
|