2017-08-26 16:38:36 +02:00
|
|
|
BigchainDB JavaScript Driver
|
|
|
|
============================
|
|
|
|
|
|
|
|
.. image:: https://img.shields.io/npm/v/bigchaindb-driver.svg
|
|
|
|
:target: https://www.npmjs.com/package/bigchaindb-driver
|
|
|
|
|
|
|
|
.. image:: https://codecov.io/gh/bigchaindb/js-bigchaindb-driver/branch/master/graph/badge.svg
|
|
|
|
:target: https://codecov.io/gh/bigchaindb/js-bigchaindb-driver
|
|
|
|
|
|
|
|
.. image:: https://img.shields.io/badge/js-ascribe-39BA91.svg
|
|
|
|
:target: https://github.com/ascribe/javascript
|
|
|
|
|
|
|
|
.. image:: https://travis-ci.org/bigchaindb/js-bigchaindb-driver.svg?branch=master
|
|
|
|
:target: https://travis-ci.org/bigchaindb/js-bigchaindb-driver
|
|
|
|
|
|
|
|
.. image:: https://badges.greenkeeper.io/bigchaindb/js-bigchaindb-driver.svg
|
|
|
|
:target: https://greenkeeper.io/
|
|
|
|
|
|
|
|
Features
|
|
|
|
--------
|
|
|
|
|
|
|
|
* Support for preparing, fulfilling, and sending transactions to a BigchainDB
|
|
|
|
node.
|
|
|
|
* Retrieval of transactions by id.
|
|
|
|
* Getting status of a transaction by id.
|
|
|
|
|
|
|
|
Compatibility Matrix
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
+-----------------------+----------------------------------+
|
|
|
|
| **BigchainDB Server** | **BigchainDB Javascript Driver** |
|
|
|
|
+=======================+==================================+
|
|
|
|
| ``0.10`` | ``0.1.x`` |
|
|
|
|
+-----------------------+----------------------------------+
|
|
|
|
| ``1.0`` | ``0.3.x`` |
|
|
|
|
+-----------------------+----------------------------------+
|
2017-12-20 11:32:34 +01:00
|
|
|
| ``1.3`` | ``3.x.x`` |
|
2017-12-19 16:56:16 +01:00
|
|
|
+-----------------------+----------------------------------+
|
2018-03-27 09:07:31 +02:00
|
|
|
| ``2.0`` | ``4.x.x`` |
|
|
|
|
+-----------------------+----------------------------------+
|
|
|
|
|
2017-12-19 16:56:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
Older versions
|
|
|
|
--------------------
|
2018-03-27 09:07:31 +02:00
|
|
|
|
2018-03-28 17:03:26 +02:00
|
|
|
#### Versions 4.x.x
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-03-27 09:07:31 +02:00
|
|
|
As part of the changes in the BigchainDB 2.0 server, some endpoint were
|
2018-03-28 17:03:26 +02:00
|
|
|
modified. In order to be consistent with them, the JS driver does not have
|
2018-03-27 09:07:31 +02:00
|
|
|
anymore the `pollStatusAndFetchTransaction()` method as there are three
|
|
|
|
different ways of posting a transaction.
|
|
|
|
- `async` using the `postTransaction`: the response will return immediately and not wait to see if the transaction is valid.
|
|
|
|
- `sync` using the `postTransactionSync`: the response will return after the transaction is validated.
|
|
|
|
- `commit` using the `postTransactionCommit`: the response will return after the transaction is committed to a block.
|
|
|
|
|
|
|
|
By default in the docs we will use the `postTransactionCommit` as is way of
|
2018-03-28 17:03:26 +02:00
|
|
|
being sure that the transaction is validated and commited to a block, so
|
2018-03-27 09:07:31 +02:00
|
|
|
there will not be any issue if you try to transfer the asset immediately.
|
|
|
|
|
|
|
|
|
2018-03-28 17:03:26 +02:00
|
|
|
#### Versions 3.2.x
|
|
|
|
|
2017-12-20 11:32:34 +01:00
|
|
|
For versions below 3.2, a transfer transaction looked like:
|
2017-12-19 16:56:16 +01:00
|
|
|
|
|
|
|
.. code-block:: js
|
|
|
|
|
|
|
|
const createTranfer = BigchainDB.Transaction.makeTransferTransaction(
|
|
|
|
txCreated,
|
|
|
|
metadata, [BigchainDB.Transaction.makeOutput(
|
|
|
|
BigchainDB.Transaction.makeEd25519Condition(alice.publicKey))],
|
|
|
|
0
|
|
|
|
)
|
|
|
|
|
2017-12-20 15:07:23 +01:00
|
|
|
const signedTransfer = BigchainDB.Transaction.signTransaction(createTranfer,
|
|
|
|
keypair.privateKey)
|
2017-12-20 11:32:34 +01:00
|
|
|
|
|
|
|
|
2017-12-20 15:07:23 +01:00
|
|
|
In order to upgrade and do it compatible with the new driver version, this
|
|
|
|
transaction should be now:
|
2017-12-20 11:32:34 +01:00
|
|
|
|
|
|
|
.. code-block:: js
|
|
|
|
|
|
|
|
const createTranfer = BigchainDB.Transaction.makeTransferTransaction(
|
|
|
|
[{ tx: txCreated, output_index: 0 }],
|
2018-01-18 11:35:02 +01:00
|
|
|
[BigchainDB.Transaction.makeOutput(
|
|
|
|
BigchainDB.Transaction.makeEd25519Condition(alice.publicKey))],
|
2017-12-20 11:32:34 +01:00
|
|
|
metaData
|
|
|
|
)
|
|
|
|
|
2017-12-20 15:07:23 +01:00
|
|
|
const signedTransfer = BigchainDB.Transaction.signTransaction(createTranfer,
|
|
|
|
keypair.privateKey)
|
2017-12-20 11:32:34 +01:00
|
|
|
|
|
|
|
|
2017-12-20 15:07:23 +01:00
|
|
|
The upgrade allows to create transfer transaction spending outputs that belong
|
2018-03-28 17:03:26 +02:00
|
|
|
to different transactions. So for instance is now possible to create a transfer
|
2017-12-20 15:07:23 +01:00
|
|
|
transaction spending two outputs from two different create transactions:
|
2017-12-20 11:32:34 +01:00
|
|
|
|
|
|
|
|
|
|
|
.. code-block:: js
|
|
|
|
|
|
|
|
const createTranfer = BigchainDB.Transaction.makeTransferTransaction(
|
2017-12-20 15:07:23 +01:00
|
|
|
[{ tx: txCreated1, output_index: 0 },
|
2018-02-21 10:33:47 +01:00
|
|
|
{ tx: txCreated2, output_index: 0}],
|
2018-01-18 11:35:02 +01:00
|
|
|
[BigchainDB.Transaction.makeOutput(
|
|
|
|
BigchainDB.Transaction.makeEd25519Condition(alice.publicKey))],
|
2017-12-20 11:32:34 +01:00
|
|
|
metaData
|
|
|
|
)
|
|
|
|
|
2017-12-20 15:07:23 +01:00
|
|
|
const signedTransfer = BigchainDB.Transaction.signTransaction(createTranfer,
|
|
|
|
keypair.privateKey)
|