1
0
mirror of https://github.com/bigchaindb/js-bigchaindb-driver.git synced 2025-01-01 01:27:54 +01:00
Official BigchainDB JavaScript driver for Node.js and the browser
Go to file
2017-06-07 17:08:42 +02:00
dist rebuild 2017-05-15 11:56:59 +02:00
media cleanup all the readme things 2017-06-06 16:29:28 +02:00
src Connection.req -> Connection._req 2017-05-14 20:03:54 +02:00
.babelrc proper json syntax 2017-06-06 16:23:57 +02:00
.eslintignore ignore lock files 2017-06-06 16:23:43 +02:00
.eslintrc.json ignore yarn.lock 2017-04-26 15:58:19 +02:00
.gitignore ignore yarn.lock 2017-04-26 15:58:19 +02:00
.travis.yml add Travis 2017-06-06 16:23:27 +02:00
API.md Update API.md 2017-05-14 20:06:56 +02:00
CONTRIBUTING.rst license, authors, etc 2017-05-09 20:23:11 +02:00
LICENSE license cleanup 2017-06-06 16:35:54 +02:00
package.json semi-auto npm releases 2017-06-06 16:32:43 +02:00
README.md JavaScript/Node.js/browser 2017-06-07 17:08:42 +02:00
webpack.config.js rebuild + add node dist 2017-05-10 09:36:07 +02:00

js-bigchaindb-driver

Official JavaScript driver for BigchainDB with some naive helpers to get you on your way making transactions in Node.js and the browser.

npm js bigchaindb Build Status Greenkeeper badge

Compatibility

BigchainDB Server BigchainDB JavaScript Driver
~=0.10.1 ~=0.1.0

Contents

Installation

# install from npm
npm install bigchaindb-driver

Usage

You'll probably need a babel here and a bundler there. Alternatively, use one of the bundled dist versions.

import * as driver from 'js-bigchaindb-driver';

// http(s)://<bigchaindb-API-url>/ (e.g. http://localhost:9984/api/v1/)
const API_PATH = 'http://localhost:9984/api/v1/';

// Create a new user with a public-private key pair
const alice = new driver.Ed25519Keypair();

// Create a transaction
const tx = driver.Transaction.makeCreateTransaction(
    { assetMessage: 'My very own asset...' },
    { metaDataMessage: 'wrapped in a transaction' },
    [ driver.Transaction.makeOutput(
            driver.Transaction.makeEd25519Condition(alice.publicKey))
    ],
    alice.publicKey
);

// Sign/fulfill the transaction
const txSigned = driver.Transaction.signTransaction(tx, alice.privateKey);

// Send it off to BigchainDB
let conn = new driver.Connection(PATH, { 'Content-Type': 'application/json' });
conn.postTransaction(txSigned)
    .then(() => conn.getStatus(txSigned.id))
    .then((res) => console.log('Transaction status:', res.status));

You may also be interested in some long-form tutorials with actual code.

The expected flow for making transactions:

  1. Go get yourself some key pairs. (or a whole bunch of them, nobody's counting)
    • new driver.Ed25519Keypair()
  2. Construct a transaction payload that you can send off to BigchainDB:
    • driver.Transaction.makeCreateTransaction() for creating a new asset or
    • driver.Transaction.makeTransferTransaction() for transferring an existing asset
  3. A transaction needs an output (*):
    • driver.Transaction.makeOutput() still requires a crypto-condition
    • driver.Transaction.makeEd25519Condition() should do the trick for a simple public key output.
  4. (Optional) You've got everything you need, except for an asset and metadata. Maybe define them (any JSON-serializable object will do).
  5. Ok, now you've got a transaction, but we need you to sign it cause, you know... cryptography and ¯\_(ツ)_/¯:
    • driver.Transaction.signTransaction() allows you to sign with private keys.
  6. Final step is to send the transaction off to BigchainDB:
    • driver.Connection.postTransaction()

(*) If you're not sure what any of this means (and you're as confused as I think you are right now), you might wanna go check out this and this and this first.

Speed Optimizations

This implementation plays "safe" by using JS-native (or downgradable) libraries for its crypto-related functions to keep compatibilities with the browser. If you do want some more speed, feel free to explore the following:

Warnings

Crypto-conditions

Make sure you keep using a crypto-conditions implementation that implements the older v1 draft (e.g. five-bells-condition@v3.3.1).

BigchainDB Server 0.10 does not implement the newer version of the spec and WILL fail if you try using a newer implementation of crypto-conditions.

SHA3

Make sure to use a SHA3 implementation that has been upgraded as per FIPS 202. Otherwise, the hashes you generate WILL be invalid in the eyes of the BigchainDB Server.

Ed25519

If you do end up replacing tweetnacl with chloride (or any other Ed25519 package), you might want to double check that it gives you a correct public/private (or verifying/signing, if they use that lingo) key pair.

An example BigchainDB Server-generated key pair (encoded in base58):

  • Public: DjPMHDD9JtgypDKY38mPz9f6owjAMAKhLuN1JfRAat8C
  • Private: 7Gf5YRch2hYTyeLxqNLgTY63D9K5QH2UQ7LYFeBGuKvo

Your package should be able to take in the decoded version of the private key and return you the same public key (once you encode that to base58).

npm releases

For a new patch release, execute on the machine where you're logged into your npm account:

npm run release

Command is powered by release-it package, defined in the package.json.

That's what the command does without any user interaction:

  • create release commit by updating version in package.json
  • create tag for that release commit
  • push commit & tag
  • create a new release on GitHub, with change log auto-generated from commit messages
  • publish to npm as a new release

If you want to create a minor or major release, use these commands:

npm run release-minor
npm run release-major

Authors

License

Copyright 2017 BigchainDB GmbH

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.