0.2.2 • Published 8 years ago

easy-bitcoin-js v0.2.2

Weekly downloads
53
License
AGPL-3.0
Repository
github
Last release
8 years ago

easy-bitcoin-js

A simple module with basic Bitcoin operations using bitcoinjs-lib and Blockchain.info API.

Build Status

npm package

Super simple to use

var easyBtc = require('easy-bitcoin-js');

Development status

Some features are in alpha. This means some operations, even if they are complete, are under development and were not tested. Tested features are documented with Done and tested icon.

There is a milestone of pending tasks until we release it as a stable v1.

Features

newWallet() Done and tested

Creates a random new wallet.

Returns
  • Object $$ecPair: bitcoinjs keyPair object
  • String wif: private key in WIF format
  • String address: public key (address)

getWallet(address) Done and tested

Gets information from an address in the blockchain.

Arguments
  • String address: the address of the wallet.
Returns
  • Promise A Q promise with the HTTP result. JSON result is resolved to resolved.data.

Tip: the returned final_balance property of the transaction JSON contains the wallet's balance.

newTransaction(fromWIF, txHashOrigin, toAddress, value)

Creates a transaction.

Arguments
  • String fromWIF: private key in WIF format of the origin wallet.
  • String txHashOrigin: the last transaction hash to the origin wallet.
  • String toAddress: the public key (address) of the destination wallet.
  • Number, int value: the amount to transfer in uBTC (microbitcoins).
Returns
  • Object $$tx: bitcoinjs transaction object.
  • String hex: the transaction hex script to push into the blockchain.

pushTransaction(hexTx)

Pushes a transaction to the blockchain.

Arguments
  • String hexTx: the transaction hex script to push into the blockchain.
Returns
  • Promise A Q promise with the HTTP result.

getTransaction(txHash)

Gets a transaction from the blockchain.

Arguments
  • String hexTx: the transaction hex script to push into the blockchain.
Returns
  • Promise A Q promise with the HTTP result. JSON result is resolved to resolved.data.

Tip: the returned block_height property of the transaction JSON is present and greater than zero if the transaction is already confirmed. If this property is not present in the JSON or equal to or less than zero, the transaction was not already confirmed.

Under development

THE FOLLOWING OPERATIONS ARE UNDER DEVELOPMENT. This means they are incomplete, not working or unstable.

decodeTransaction(hex)

Decodes a transaction from its hex script.

Status: need to parse Blockchain.info HTML reponse and extract transaction JSON from a <pre> tag.

createPushAndConfirmTransaction(fromWIF, txHashOrigin, toAddress, value, opt_timeout, opt_interval)

Creates, pushes and awaits for a transaction confirmation.

Status: Done, just waiting for the decodeTransaction method to be completed.