corda/samples/bank-of-corda-demo
Patrick Kuo 80b3411fa5 Explorer advertising service fix (#1576)
* WIP
added a helper method to convert ObservableValue<List> to ObservableList

(cherry picked from commit 75306aa)

* Fix for cash explorer after advertising service removal

(cherry picked from commit 59d0278)

* remove unused changes

* address PR issues

* fixup after rebase

* fix CashState name rendering issue
added flow permission to gradle config
2017-09-21 13:27:05 +01:00
..
src CORDA-577: FlowSession porting (#1530) 2017-09-21 12:12:25 +01:00
build.gradle Explorer advertising service fix (#1576) 2017-09-21 13:27:05 +01:00
README.md Introduce full legal names for test parties 2017-04-24 15:18:21 +01:00

Bank of Corda demo

Please see docs/build/html/running-the-demos.html

This program simulates the role of an asset issuing authority (eg. central bank for cash) by accepting requests from third parties to issue some quantity of an asset and transfer that ownership to the requester. The issuing authority accepts requests via the [IssuerFlow] flow, self-issues the asset and transfers ownership to the issue requester. Notarisation and signing form part of the flow.

The requesting party can be a CorDapp (running locally or remotely to the Bank of Corda node), a remote RPC client or a Web Client.

Prerequisites

You will need to have JDK 8 installed and available on your path.

Getting Started

  1. Launch the Bank of Corda node (and associated Notary) by running: [BankOfCordaDriver] --role ISSUER (to validate your Node is running you can try navigating to this sample link: http://localhost:10005/api/bank/date)

Each of the following commands will launch a separate Node called Big Corporation which will become the owner of some Cash following an issue request:

  1. Run the Bank of Corda Client driver (to simulate a web issue requester) by running: [BankOfCordaDriver] --role ISSUE_CASH_WEB This demonstrates a remote application acting on behalf of the Big Corporation and communicating directly with the Bank of Corda node via HTTP to request issuance of some cash.

  2. Run the Bank of Corda Client driver (to simulate an RPC issue requester) by running: [BankOfCordaDriver] --role ISSUE_CASH_RPC Similar to 3 above, but using RPC as the remote communications mechanism.

Developer notes

Testing of the Bank of Corda application is demonstrated at two levels:

  1. Unit testing the flow uses the [LedgerDSL] and [MockServices]. Please see [IssuerFlowTest] The IssuerFlow is one of several reusable flows defined in the finance package.
  2. Integration testing via RPC and HTTP uses the [Driver] DSL to launch standalone node instances

Security The RPC API requires a client to pass in user credentials: client.start("bankUser","test") which are validated on the Bank of Corda node against those configured at node startup: User("bankUser", "test", permissions = setOf(startFlowPermission<IssuerFlow.IssuanceRequester>())) startNode(BOC.name, rpcUsers = listOf(user))

Notary We are using a [SimpleNotaryService] in this example, but could easily switch to a [ValidatingNotaryService]

Integration with other Demos and Tools

The Bank of Corda issuer node concept has been integrated into the Explorer tool (simulation nodes) and Trader Demo.

Further Reading

Tutorials and developer docs for Cordapps and Corda are here.