corda/docs/source/hello-world-template.rst

68 lines
2.4 KiB
ReStructuredText
Raw Normal View History

2017-06-16 14:05:52 +01:00
.. highlight:: kotlin
.. raw:: html
<script type="text/javascript" src="_static/jquery.js"></script>
<script type="text/javascript" src="_static/codesets.js"></script>
The CorDapp Template
====================
When writing a new CorDapp, youll generally want to base it on the
`Java Cordapp Template <https://github.com/corda/cordapp-template-java>`_ or the equivalent
`Kotlin Cordapp Template <https://github.com/corda/cordapp-template-kotlin>`_. The Cordapp Template allows you to
quickly deploy your CorDapp onto a local test network of dummy nodes to evaluate its functionality.
2017-06-16 14:05:52 +01:00
Note that there's no need to download and install Corda itself. As long as you're working from a stable Milestone
branch, the required libraries will be downloaded automatically from an online repository.
If you do wish to work from the latest snapshot, please follow the instructions
`here <https://docs.corda.net/tutorial-cordapp.html#using-a-snapshot-release>`_.
Downloading the template
------------------------
Open a terminal window in the directory where you want to download the CorDapp template, and run the following commands:
.. code-block:: text
# Clone the template from GitHub:
2017-08-16 08:36:00 +01:00
git clone https://github.com/corda/cordapp-template-java.git ; cd cordapp-template-java
*or*
2017-08-16 08:36:00 +01:00
git clone https://github.com/corda/cordapp-template-kotlin.git ; cd cordapp-template-kotlin
2017-06-16 14:05:52 +01:00
# Retrieve a list of the stable Milestone branches using:
git branch -a --list *release-M*
# Check out the Milestone branch with the latest version number:
2017-07-06 14:23:52 +01:00
git checkout release-M[*version number*] ; git pull
2017-06-16 14:05:52 +01:00
Template structure
------------------
2017-08-16 08:36:00 +01:00
We can write our CorDapp in either Java or Kotlin, and will be providing the code in both languages throughout. To
2017-08-17 12:02:44 +01:00
implement our IOU CorDapp in Java, we'll need to modify three files. For Kotlin, we'll simply be modifying the
``App.kt`` file:
2017-06-16 14:05:52 +01:00
.. container:: codeset
.. code-block:: java
// 1. The state
2017-08-17 12:02:44 +01:00
src/main/java/com/template/state/TemplateState.java
2017-06-16 14:05:52 +01:00
// 2. The contract
2017-08-17 12:02:44 +01:00
src/main/java/com/template/contract/TemplateContract.java
2017-06-16 14:05:52 +01:00
// 3. The flow
2017-08-17 12:02:44 +01:00
src/main/java/com/template/flow/TemplateFlow.java
2017-06-16 14:05:52 +01:00
2017-08-17 12:02:44 +01:00
.. code-block:: kotlin
src/main/kotlin/com/template/App.kt
2017-06-16 14:05:52 +01:00
Progress so far
---------------
We now have a template that we can build upon to define our IOU CorDapp.
2017-07-06 14:23:52 +01:00
We'll begin writing the CorDapp proper by writing the definition of the ``IOUState``.