1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-03 12:00:59 +00:00

Experiment - generating segwit addresses

This commit is contained in:
Karel Bilek 2017-03-31 03:38:28 +02:00 committed by Pavol Rusnak
parent 81c61ba5a4
commit 08545a15e7
5 changed files with 35 additions and 11 deletions

22
bip32.c
View File

@ -25,6 +25,7 @@
#include <string.h> #include <string.h>
#include <stdbool.h> #include <stdbool.h>
#include "address.h"
#include "bignum.h" #include "bignum.h"
#include "hmac.h" #include "hmac.h"
#include "ecdsa.h" #include "ecdsa.h"
@ -270,7 +271,7 @@ int hdnode_public_ckd(HDNode *inout, uint32_t i)
return 1; return 1;
} }
int hdnode_public_ckd_address_optimized(const curve_point *pub, const uint8_t *chain_code, uint32_t i, uint32_t version, char *addr, int addrsize) int hdnode_public_ckd_address_optimized(const curve_point *pub, const uint8_t *chain_code, uint32_t i, uint32_t version, char *addr, int addrsize, bool segwit)
{ {
uint8_t child_pubkey[33]; uint8_t child_pubkey[33];
curve_point b; curve_point b;
@ -278,8 +279,27 @@ int hdnode_public_ckd_address_optimized(const curve_point *pub, const uint8_t *c
hdnode_public_ckd_cp(&secp256k1, pub, chain_code, i, &b, NULL); hdnode_public_ckd_cp(&secp256k1, pub, chain_code, i, &b, NULL);
child_pubkey[0] = 0x02 | (b.y.val[0] & 0x01); child_pubkey[0] = 0x02 | (b.y.val[0] & 0x01);
bn_write_be(&b.x, child_pubkey + 1); bn_write_be(&b.x, child_pubkey + 1);
if (!segwit) {
ecdsa_get_address(child_pubkey, version, addr, addrsize); ecdsa_get_address(child_pubkey, version, addr, addrsize);
return 1; return 1;
} else {
uint8_t raw[32];
size_t prelen = address_prefix_bytes_len(version);
uint8_t digest[MAX_ADDR_RAW_SIZE];
raw[0] = 0; // version byte
raw[1] = 20; // push 20 bytes
ecdsa_get_pubkeyhash(child_pubkey, raw + 2);
sha256_Raw(raw, 22, digest);
address_write_prefix_bytes(version, raw);
ripemd160(digest, 32, raw + prelen);
if (!base58_encode_check(raw, prelen + 20, addr, MAX_ADDR_SIZE)) {
return 0;
}
return 1;
}
} }
#if USE_BIP32_CACHE #if USE_BIP32_CACHE

View File

@ -26,6 +26,7 @@
#include <stdint.h> #include <stdint.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdbool.h>
#include "ecdsa.h" #include "ecdsa.h"
#include "options.h" #include "options.h"
@ -57,7 +58,7 @@ int hdnode_public_ckd_cp(const ecdsa_curve *curve, const curve_point *parent, co
int hdnode_public_ckd(HDNode *inout, uint32_t i); int hdnode_public_ckd(HDNode *inout, uint32_t i);
int hdnode_public_ckd_address_optimized(const curve_point *pub, const uint8_t *chain_code, uint32_t i, uint32_t version, char *addr, int addrsize); int hdnode_public_ckd_address_optimized(const curve_point *pub, const uint8_t *chain_code, uint32_t i, uint32_t version, char *addr, int addrsize, bool segwit);
#if USE_BIP32_CACHE #if USE_BIP32_CACHE

View File

@ -51,8 +51,8 @@ function serializeNode(node) {
* @param {Number} version address version byte * @param {Number} version address version byte
* @return {String} * @return {String}
*/ */
function deriveAddress(index, version) { function deriveAddress(index, version, segwit) {
_hdnode_public_ckd_address_optimized(_pubpoint, _chaincode, index, version, _address, ADDRESS_SIZE); _hdnode_public_ckd_address_optimized(_pubpoint, _chaincode, index, version, _address, ADDRESS_SIZE, segwit);
return Pointer_stringify(_address); return Pointer_stringify(_address);
} }
@ -63,12 +63,12 @@ function deriveAddress(index, version) {
* @param {Number} version address version byte * @param {Number} version address version byte
* @return {Array<String>} * @return {Array<String>}
*/ */
function deriveAddressRange(node, firstIndex, lastIndex, version) { function deriveAddressRange(node, firstIndex, lastIndex, version, segwit) {
var addresses = []; var addresses = [];
serializeNode(node); serializeNode(node);
var i; var i;
for (i = firstIndex; i <= lastIndex; i++) { for (i = firstIndex; i <= lastIndex; i++) {
addresses.push(deriveAddress(i, version)); addresses.push(deriveAddress(i, version, segwit));
} }
return addresses; return addresses;
} }

View File

@ -13,7 +13,10 @@ var nodeStruct = {
public_key: node.keyPair.getPublicKeyBuffer() public_key: node.keyPair.getPublicKeyBuffer()
}; };
var addresses = crypto.deriveAddressRange(nodeStruct, 0, 999, 0); var addresses = crypto.deriveAddressRange(nodeStruct, 0, 999, 0, false);
// for segwit:
// var addresses = crypto.deriveAddressRange(nodeStruct, 0, 999, 5, true);
var fs = require('fs'); var fs = require('fs');
var loaded = fs.readFileSync('test-addresses.txt').toString().split("\n"); var loaded = fs.readFileSync('test-addresses.txt').toString().split("\n");

File diff suppressed because one or more lines are too long