1
1
'use strict' ;
2
2
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
3
3
exports . taggedHash =
4
+ exports . TAGGED_HASH_PREFIXES =
5
+ exports . TAGS =
4
6
exports . hash256 =
5
7
exports . hash160 =
6
8
exports . sha256 =
@@ -9,7 +11,6 @@ exports.taggedHash =
9
11
void 0 ;
10
12
const createHash = require ( 'create-hash' ) ;
11
13
const RipeMd160 = require ( 'ripemd160' ) ;
12
- const tagged_hash_prefixes_1 = require ( './tagged-hash-prefixes' ) ;
13
14
function ripemd160 ( buffer ) {
14
15
try {
15
16
return createHash ( 'rmd160' ) . update ( buffer ) . digest ( ) ;
@@ -38,14 +39,75 @@ function hash256(buffer) {
38
39
return sha256 ( sha256 ( buffer ) ) ;
39
40
}
40
41
exports . hash256 = hash256 ;
42
+ exports . TAGS = [
43
+ 'BIP0340/challenge' ,
44
+ 'BIP0340/aux' ,
45
+ 'BIP0340/nonce' ,
46
+ 'TapLeaf' ,
47
+ 'TapBranch' ,
48
+ 'TapSighash' ,
49
+ 'TapTweak' ,
50
+ 'KeyAgg list' ,
51
+ 'KeyAgg coefficient' ,
52
+ ] ;
41
53
/** An object mapping tags to their tagged hash prefix of [SHA256(tag) | SHA256(tag)] */
42
- const TAGGED_HASH_PREFIXES = Object . fromEntries (
43
- Object . keys ( tagged_hash_prefixes_1 . TAGGED_HASH_PREFIXES_HEX ) . map ( tag => [
44
- tag ,
45
- Buffer . from ( tagged_hash_prefixes_1 . TAGGED_HASH_PREFIXES_HEX [ tag ] , 'hex' ) ,
54
+ exports . TAGGED_HASH_PREFIXES = {
55
+ 'BIP0340/challenge' : Buffer . from ( [
56
+ 123 , 181 , 45 , 122 , 159 , 239 , 88 , 50 , 62 , 177 , 191 , 122 , 64 , 125 , 179 , 130 ,
57
+ 210 , 243 , 242 , 216 , 27 , 177 , 34 , 79 , 73 , 254 , 81 , 143 , 109 , 72 , 211 , 124 ,
58
+ 123 , 181 , 45 , 122 , 159 , 239 , 88 , 50 , 62 , 177 , 191 , 122 , 64 , 125 , 179 , 130 ,
59
+ 210 , 243 , 242 , 216 , 27 , 177 , 34 , 79 , 73 , 254 , 81 , 143 , 109 , 72 , 211 , 124 ,
46
60
] ) ,
47
- ) ;
61
+ 'BIP0340/aux' : Buffer . from ( [
62
+ 241 , 239 , 78 , 94 , 192 , 99 , 202 , 218 , 109 , 148 , 202 , 250 , 157 , 152 , 126 , 160 ,
63
+ 105 , 38 , 88 , 57 , 236 , 193 , 31 , 151 , 45 , 119 , 165 , 46 , 216 , 193 , 204 , 144 ,
64
+ 241 , 239 , 78 , 94 , 192 , 99 , 202 , 218 , 109 , 148 , 202 , 250 , 157 , 152 , 126 , 160 ,
65
+ 105 , 38 , 88 , 57 , 236 , 193 , 31 , 151 , 45 , 119 , 165 , 46 , 216 , 193 , 204 , 144 ,
66
+ ] ) ,
67
+ 'BIP0340/nonce' : Buffer . from ( [
68
+ 7 , 73 , 119 , 52 , 167 , 155 , 203 , 53 , 91 , 155 , 140 , 125 , 3 , 79 , 18 , 28 , 244 ,
69
+ 52 , 215 , 62 , 247 , 45 , 218 , 25 , 135 , 0 , 97 , 251 , 82 , 191 , 235 , 47 , 7 , 73 ,
70
+ 119 , 52 , 167 , 155 , 203 , 53 , 91 , 155 , 140 , 125 , 3 , 79 , 18 , 28 , 244 , 52 , 215 ,
71
+ 62 , 247 , 45 , 218 , 25 , 135 , 0 , 97 , 251 , 82 , 191 , 235 , 47 ,
72
+ ] ) ,
73
+ TapLeaf : Buffer . from ( [
74
+ 174 , 234 , 143 , 220 , 66 , 8 , 152 , 49 , 5 , 115 , 75 , 88 , 8 , 29 , 30 , 38 , 56 , 211 ,
75
+ 95 , 28 , 181 , 64 , 8 , 212 , 211 , 87 , 202 , 3 , 190 , 120 , 233 , 238 , 174 , 234 , 143 ,
76
+ 220 , 66 , 8 , 152 , 49 , 5 , 115 , 75 , 88 , 8 , 29 , 30 , 38 , 56 , 211 , 95 , 28 , 181 ,
77
+ 64 , 8 , 212 , 211 , 87 , 202 , 3 , 190 , 120 , 233 , 238 ,
78
+ ] ) ,
79
+ TapBranch : Buffer . from ( [
80
+ 25 , 65 , 161 , 242 , 229 , 110 , 185 , 95 , 162 , 169 , 241 , 148 , 190 , 92 , 1 , 247 ,
81
+ 33 , 111 , 51 , 237 , 130 , 176 , 145 , 70 , 52 , 144 , 208 , 91 , 245 , 22 , 160 , 21 , 25 ,
82
+ 65 , 161 , 242 , 229 , 110 , 185 , 95 , 162 , 169 , 241 , 148 , 190 , 92 , 1 , 247 , 33 ,
83
+ 111 , 51 , 237 , 130 , 176 , 145 , 70 , 52 , 144 , 208 , 91 , 245 , 22 , 160 , 21 ,
84
+ ] ) ,
85
+ TapSighash : Buffer . from ( [
86
+ 244 , 10 , 72 , 223 , 75 , 42 , 112 , 200 , 180 , 146 , 75 , 242 , 101 , 70 , 97 , 237 , 61 ,
87
+ 149 , 253 , 102 , 163 , 19 , 235 , 135 , 35 , 117 , 151 , 198 , 40 , 228 , 160 , 49 , 244 ,
88
+ 10 , 72 , 223 , 75 , 42 , 112 , 200 , 180 , 146 , 75 , 242 , 101 , 70 , 97 , 237 , 61 , 149 ,
89
+ 253 , 102 , 163 , 19 , 235 , 135 , 35 , 117 , 151 , 198 , 40 , 228 , 160 , 49 ,
90
+ ] ) ,
91
+ TapTweak : Buffer . from ( [
92
+ 232 , 15 , 225 , 99 , 156 , 156 , 160 , 80 , 227 , 175 , 27 , 57 , 193 , 67 , 198 , 62 , 66 ,
93
+ 156 , 188 , 235 , 21 , 217 , 64 , 251 , 181 , 197 , 161 , 244 , 175 , 87 , 197 , 233 , 232 ,
94
+ 15 , 225 , 99 , 156 , 156 , 160 , 80 , 227 , 175 , 27 , 57 , 193 , 67 , 198 , 62 , 66 , 156 ,
95
+ 188 , 235 , 21 , 217 , 64 , 251 , 181 , 197 , 161 , 244 , 175 , 87 , 197 , 233 ,
96
+ ] ) ,
97
+ 'KeyAgg list' : Buffer . from ( [
98
+ 72 , 28 , 151 , 28 , 60 , 11 , 70 , 215 , 240 , 178 , 117 , 174 , 89 , 141 , 78 , 44 , 126 ,
99
+ 215 , 49 , 156 , 89 , 74 , 92 , 110 , 199 , 158 , 160 , 212 , 153 , 2 , 148 , 240 , 72 , 28 ,
100
+ 151 , 28 , 60 , 11 , 70 , 215 , 240 , 178 , 117 , 174 , 89 , 141 , 78 , 44 , 126 , 215 , 49 ,
101
+ 156 , 89 , 74 , 92 , 110 , 199 , 158 , 160 , 212 , 153 , 2 , 148 , 240 ,
102
+ ] ) ,
103
+ 'KeyAgg coefficient' : Buffer . from ( [
104
+ 191 , 201 , 4 , 3 , 77 , 28 , 136 , 232 , 200 , 14 , 34 , 229 , 61 , 36 , 86 , 109 , 100 ,
105
+ 130 , 78 , 214 , 66 , 114 , 129 , 192 , 145 , 0 , 249 , 77 , 205 , 82 , 201 , 129 , 191 ,
106
+ 201 , 4 , 3 , 77 , 28 , 136 , 232 , 200 , 14 , 34 , 229 , 61 , 36 , 86 , 109 , 100 , 130 ,
107
+ 78 , 214 , 66 , 114 , 129 , 192 , 145 , 0 , 249 , 77 , 205 , 82 , 201 , 129 ,
108
+ ] ) ,
109
+ } ;
48
110
function taggedHash ( prefix , data ) {
49
- return sha256 ( Buffer . concat ( [ TAGGED_HASH_PREFIXES [ prefix ] , data ] ) ) ;
111
+ return sha256 ( Buffer . concat ( [ exports . TAGGED_HASH_PREFIXES [ prefix ] , data ] ) ) ;
50
112
}
51
113
exports . taggedHash = taggedHash ;
0 commit comments