Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/blocktrail/blocktrail-sdk-nodejs
BlockTrail's Developer Friendly NodeJS SDK for the BlockTrail API
https://github.com/blocktrail/blocktrail-sdk-nodejs
Last synced: about 2 months ago
JSON representation
BlockTrail's Developer Friendly NodeJS SDK for the BlockTrail API
- Host: GitHub
- URL: https://github.com/blocktrail/blocktrail-sdk-nodejs
- Owner: blocktrail
- License: mit
- Created: 2014-10-08T11:50:05.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2022-03-09T10:45:58.000Z (almost 3 years ago)
- Last Synced: 2024-11-03T03:07:46.636Z (2 months ago)
- Language: JavaScript
- Size: 18.8 MB
- Stars: 39
- Watchers: 11
- Forks: 26
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-bitcoin - BlockTrail SDK NodeJS
README
BlockTrail NodeJS SDK
=====================
This is the BlockTrail NodeJS SDK. This SDK contains methods for easily interacting with the BlockTrail API.
Below are examples to get you started. For additional examples, please see our official documentation
at https://www.blocktrail.com/api/docs/lang/nodejs[![Latest Stable Version](https://badge.fury.io/js/blocktrail-sdk.svg)](https://www.npmjs.org/package/blocktrail-sdk)
[![Build Status](https://travis-ci.org/blocktrail/blocktrail-sdk-nodejs.png?branch=master)](https://travis-ci.org/blocktrail/blocktrail-sdk-nodejs)
[![Sauce Test Status](https://saucelabs.com/buildstatus/team_blocktrail)](https://saucelabs.com/u/team_blocktrail)[![Sauce Test Status](https://saucelabs.com/browser-matrix/team_blocktrail.svg)](https://saucelabs.com/u/team_blocktrail)
The Blocktrail SDK is tested against;
- NodeJS:
- 0.11
- 0.12
- 5.11
- 6.3.0
- 7.1.0
- Browser:
- Google Chrome 48 / latest
- Firefox 49 / latest
- Safari 10.0 / latest
- Edge 14.14393
- IE 11.103
- Android 4.4
- Android 5.0
- iPhone OS X 10.10Upgrading from v3.x to v3.4.0
-----------------------------
We've seperated out the backup PDF generator because it contained a lot of dependencies while barely anyone uses it.
If you do want to use it, see the `blocktrail-sdk-backup-generator` package.Upgrading from v2.x to v3.0.0
-----------------------------
**IMPORTANT** `v3.0.0` introduces a new **DEFAULT** wallet encryption, please make sure you upgrade the SDK everywhere you're using it!!Upgrading from v1.x to v2.0.0
-----------------------------
**IMPORTANT** `v2.0.0` has a few BC breaks, please check [docs/CHANGELOG.md](docs/CHANGELOG.md)!!IMPORTANT! FLOATS ARE EVIL!!
----------------------------
As is best practice with financial data, The API returns all values as an integer, the Bitcoin value in Satoshi's.
**In Javascript even more than in other languages it's really easy to make mistakes when converting from float to integer etc!**The BlockTrail SDK has some easy to use functions to do this for you, we recommend using these
and we also **strongly** recommend doing all Bitcoin calculation and storing of data in integers
and only convert to/from Bitcoin float values for displaying it to the user.```javascript
var blocktrail = require('blocktrail-sdk');console.log("123456789 Satoshi to BTC: ", blocktrail.toBTC(123456789));
console.log("1.23456789 BTC to Satoshi: ", blocktrail.toSatoshi(1.23456789));
```A bit more about this can be found [in our documentation](https://dev.btc.com/docs/js).
Installation
------------
You can install the package through NPM (https://www.npmjs.org/package/blocktrail-sdk).
```
npm install blocktrail-sdk
```Usage
-----
Please visit our official documentation at https://dev.btc.com/docs/php#getting-started for the usage.Promises vs Callbacks
---------------------
Personally we prefer good old callbacks over promises,
but to make everyone happy the SDK functions accept a callback argument and return a (Q)promise object, so you can use whatever you prefer!Support and Feedback
--------------------
Be sure to visit the BlockTrail API official [documentation website](https://dev.btc.com/docs/js)
for additional information about our API.If you find a bug, please submit the issue in Github directly.
[BlockTrail-NodeJS-SDK Issues](https://github.com/blocktrail/blocktrail-sdk-nodejs/issues)As always, if you need additional assistance, drop us a note at
[[email protected]](mailto:[email protected]).Unit Tests
----------
Unit Tests are created with Mocha and can be ran with `npm test` (or `mocha`)We also run jshint and jscs, these are automatically ran by [travis-ci](https://travis-ci.org/blocktrail/blocktrail-sdk-nodejs) for every commit and pull request.
```
jshint main.js lib/ test/
```
```
jscs main.js lib/ test/
```Browserify
----------
The BlockTrail NodeJS SDK can be browserified to use it in the browser, which we use ourselves for wallet actions from our webapp.
If you want to test or develop on the SDK in the browser you can use `grunt build` (and `grunt watch`) to build the browserify version.You need to pull the git submodules before you can build the browserify version:
`git submodule update --init --recursive`Files in `./build` are:
- `blocktrail-sdk.js` (and `blocktrail-sdk.min.js`) the blocktrailSDK browserified
- `jsPDF.js` (and `jsPDF.min.js`) dependancy for generating the backup PDF
- `blocktrail-sdk-full.js` (and `blocktrail-sdk-full.min.js`) the blocktrailSDK browserified + jsPDF bundledIf you use these browserified versions of our SDK it will be accessible as `window.blocktrailSDK` or plain `blocktrailSDK`.
Known Supported and Tested Browsers:
- Android 4.3+ (Use Crosswalk for lower versions if neccesary)
- iOS6+
- IE9+For the following any modern version will work just fine:
- Chrome
- FireFox
- SafariWebworker
---------
To defer encryption/decryption/keyderivation to webworkers in the browser it's neccesary to make create the following function in the global scope:
```
function onLoadWorkerLoadAsmCrypto(worker) {
worker.postMessage({
method: 'importScripts',
script: document.location.protocol + '//' + document.location.host + '/build/asmcrypto.min.js'
});
}
```This will get called as the onLoad of the webworker and will trigger importing the `asmcrypto.min.js`.
We had to seperate `asmcrypto.js` from the main browserify bundle because uglify was killing the ASM.js.Uglify
------
If you're planning to uglify/minify the javascript yourself, make sure to exclude the following variable names from being mangled:
`['Buffer', 'BitInteger', 'Point', 'Script', 'ECPubKey', 'ECKey']`License
-------
The BlockTrail NodeJS SDK is released under the terms of the MIT license. See LICENCE.md for more information or see http://opensource.org/licenses/MIT.