bitcore/lib/Address.js

171 lines
4.5 KiB
JavaScript
Raw Normal View History

2014-05-03 12:52:39 -07:00
// Address
// =======
//
// Handles a bitcoin address
//
//
// Synopsis
// --------
// ```
// var address = new Address('1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa');
// if (address.isValid()) {
// //...
// }
//
// // Also an address can be created from
// // public keys
// var address = Address.fromPubKey(myPubkey);
//
// // Or from a ScriptPubKey (from a transaction output)
// var address = Address.fromScriptPubKey(scriptPubKey);
//
// // Multisig address p2sh handling
// var myPukeys = [pubkey0, pubkey1, pubkey2];
// var p2shAddress = Address.fromPubKeys(2, myPubkeys);
// if (p2shAddress.isScript()) { //true
// }
//
//
// ```
'use strict';
var imports = require('soop').imports();
2014-04-13 13:28:42 -07:00
var coinUtil = imports.coinUtil || require('../util');
var parent = imports.parent || require('../util/VersionedData');
var networks = imports.networks || require('../networks');
var Script = imports.Script || require('./Script');
2013-07-07 11:02:00 -07:00
function Address() {
Address.super(this, arguments);
}
2013-07-07 11:02:00 -07:00
Address.parent = parent;
parent.applyEncodingsTo(Address);
2013-07-07 11:02:00 -07:00
// create a pubKeyHash address
Address.fromPubKey = function(pubKey, network) {
if (!network)
network = 'livenet';
if (pubKey.length !== 33 && pubKey.length !== 65)
throw new Error('Invalid public key');
var version = networks[network].addressVersion;
var hash = coinUtil.sha256ripe160(pubKey);
return new Address(version, hash);
};
// create an address from a Key object
2014-04-29 07:48:59 -07:00
Address.fromKey = function(key, network) {
return Address.fromPubKey(key.public, network);
};
2014-05-03 12:52:39 -07:00
// create a p2sh m-of-n multisig address
Address.fromPubKeys = function(mReq, pubKeys, network, opts) {
if (!network)
network = 'livenet';
for (var i in pubKeys) {
var pubKey = pubKeys[i];
if (pubKey.length != 33 && pubKey.length != 65)
throw new Error('Invalid public key');
}
var script = Script.createMultisig(mReq, pubKeys, opts);
return Address.fromScript(script, network);
};
//create a p2sh address from redeemScript
Address.fromScript = function(script, network) {
if (!network)
network = 'livenet';
if (typeof script === 'string') {
script = new Script(new Buffer(script,'hex'));
}
var version = networks[network].P2SHVersion;
var buf = script.getBuffer();
var hash = coinUtil.sha256ripe160(buf);
return new Address(version, hash);
};
//extract and address from scriptPubKey
Address.fromScriptPubKey = function(scriptPubKey, network) {
if (typeof scriptPubKey === 'string') {
scriptPubKey = new Script(new Buffer(scriptPubKey,'hex'));
}
if (!network)
network = 'livenet';
var ret=[], version;
var payload = scriptPubKey.capture();
if (payload) {
var txType = scriptPubKey.classify();
switch (txType) {
case Script.TX_PUBKEY:
payload[0] = coinUtil.sha256ripe160(payload[0]);
version = networks[network].addressVersion;
break;
case Script.TX_PUBKEYHASH:
version = networks[network].addressVersion;
break;
case Script.TX_MULTISIG:
version = networks[network].addressVersion;
for(var i in payload)
payload[i] = coinUtil.sha256ripe160(payload[i]);
break;
case Script.TX_SCRIPTHASH:
version = networks[network].P2SHVersion;
break;
}
for(var i in payload)
ret.push(new Address(version,payload[i]));
}
return ret;
};
2014-05-03 12:52:39 -07:00
// validates the address
Address.prototype.validate = function() {
this.doAsBinary(function() {
Address.super(this, 'validate', arguments);
if(this.data.length !== 21) throw new Error('invalid data length');
});
2014-03-19 14:44:24 -07:00
if (typeof this.network() === 'undefined') throw new Error('invalid network');
};
Address.prototype.isValid = function() {
var answer = Address.super(this, 'isValid', arguments);
2014-03-11 06:21:26 -07:00
return answer;
};
2013-07-07 11:02:00 -07:00
2014-05-03 12:52:39 -07:00
// returns the network information (livenet or testnet, as described on networks.js) of the address
2014-03-14 23:27:06 -07:00
Address.prototype.network = function() {
var version = this.version();
var livenet = networks.livenet;
var testnet = networks.testnet;
var answer;
2014-04-07 14:30:49 -07:00
if (version === livenet.addressVersion || version === livenet.P2SHVersion)
2014-03-14 23:27:06 -07:00
answer = livenet;
2014-04-07 14:30:49 -07:00
else if (version === testnet.addressVersion || version === testnet.P2SHVersion)
2014-03-14 23:27:06 -07:00
answer = testnet;
return answer;
};
2014-05-03 12:52:39 -07:00
// returns true is the address is a pay-to-script (P2SH) address type.
2014-03-19 12:20:41 -07:00
Address.prototype.isScript = function() {
2014-04-07 14:30:49 -07:00
return this.isValid() && this.version() === this.network().P2SHVersion;
2014-03-19 12:20:41 -07:00
};
module.exports = require('soop')(Address);