2.7 KiB
bitmessage
JavaScript Bitmessage library for both browserify and node. The goal of this project is to implement Bitmessage protocol v3 for both platforms at the maximum possible level (we still can't create TCP connections or listen for incoming connections in the Browser but the Proof of work and crypto is fully doable).
Public library API is currently in alpha stage, breaking changes are very likely to happen.
API documentation is available here.
References
Feature matrix (both Browser and Node)
- Crypto
- SHA-1
- SHA-256
- SHA-512
- RIPEMD-160
- PRNG
- ECC keys manipulation
- ECDSA
- ECDH
- ECIES
- AES-256-CBC
- HMAC-SHA-256
- Common structures
- message
- object
- var_int
- var_str
- var_int_list
- net_addr
- inv_vect
- encrypted
- service features
- pubkey features
- Message types
- version
- verack
- addr
- inv
- getdata
- error
- Object types
- getpubkey
- pubkey
- msg
- broadcast
- WIF
- POW
- High-level classes
- Address
- UserAgent
- Parse PyBitmessage configs
- keys.dat
- knownnodes.dat
- messages.dat
Feature matrix (Node.js only)
- Network
- Bootstrap
- Connect to the network
- Accept connections
Usage
Address
var Address = require("bitmessage").Address;
// Generate a new random Bitmessage identity.
var addr1 = Address.fromRandom();
console.log("New random Bitmessage address:", addr1.encode());
// Or create it from passphrase.
var addr2 = Address.fromPassphrase("test");
console.log("Deterministic Bitmessage address:", addr2.encode());
License
bitmessage - JavaScript Bitmessage library
Written in 2014 by Kagami Hiiragi kagami@genshiken.org
To the extent possible under law, the author(s) have dedicated all copyright and related and neighboring rights to this software to the public domain worldwide. This software is distributed without any warranty.
You should have received a copy of the CC0 Public Domain Dedication along with this software. If not, see http://creativecommons.org/publicdomain/zero/1.0/.