@bsv/wallet-toolbox-mobile 1.5.0 → 1.5.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/out/src/CWIStyleWalletManager.d.ts.map +1 -1
  2. package/out/src/CWIStyleWalletManager.js +40 -5
  3. package/out/src/CWIStyleWalletManager.js.map +1 -1
  4. package/out/src/WalletPermissionsManager.d.ts.map +1 -1
  5. package/out/src/WalletPermissionsManager.js +10 -29
  6. package/out/src/WalletPermissionsManager.js.map +1 -1
  7. package/out/src/monitor/tasks/TaskReviewStatus.d.ts +1 -1
  8. package/out/src/monitor/tasks/TaskReviewStatus.js +1 -1
  9. package/out/src/services/chaintracker/{BhsChainTracker.d.ts → BHServiceClient.d.ts} +12 -16
  10. package/out/src/services/chaintracker/BHServiceClient.d.ts.map +1 -0
  11. package/out/src/services/chaintracker/BHServiceClient.js +163 -0
  12. package/out/src/services/chaintracker/BHServiceClient.js.map +1 -0
  13. package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.d.ts +140 -0
  14. package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.d.ts.map +1 -0
  15. package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.js +467 -0
  16. package/out/src/services/chaintracker/chaintracks/util/blockHeaderUtilities.js.map +1 -0
  17. package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.d.ts +20 -0
  18. package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.d.ts.map +1 -0
  19. package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.js +31 -0
  20. package/out/src/services/chaintracker/chaintracks/util/dirtyHashes.js.map +1 -0
  21. package/out/src/services/chaintracker/index.d.ts +1 -1
  22. package/out/src/services/chaintracker/index.js +1 -1
  23. package/out/src/services/createDefaultWalletServicesOptions.d.ts +1 -1
  24. package/out/src/services/createDefaultWalletServicesOptions.d.ts.map +1 -1
  25. package/out/src/services/createDefaultWalletServicesOptions.js +10 -7
  26. package/out/src/services/createDefaultWalletServicesOptions.js.map +1 -1
  27. package/out/src/storage/WalletStorageManager.d.ts +19 -25
  28. package/out/src/storage/WalletStorageManager.d.ts.map +1 -1
  29. package/out/src/storage/WalletStorageManager.js +64 -69
  30. package/out/src/storage/WalletStorageManager.js.map +1 -1
  31. package/out/src/storage/methods/createAction.d.ts.map +1 -1
  32. package/out/src/storage/methods/createAction.js +9 -4
  33. package/out/src/storage/methods/createAction.js.map +1 -1
  34. package/out/src/storage/methods/processAction.js +1 -1
  35. package/out/src/storage/methods/processAction.js.map +1 -1
  36. package/out/src/utility/utilityHelpers.buffer.d.ts +18 -0
  37. package/out/src/utility/utilityHelpers.buffer.d.ts.map +1 -0
  38. package/out/src/utility/utilityHelpers.buffer.js +45 -0
  39. package/out/src/utility/utilityHelpers.buffer.js.map +1 -0
  40. package/package.json +5 -5
  41. package/out/src/SetupClient.mobile.d.ts +0 -90
  42. package/out/src/SetupClient.mobile.d.ts.map +0 -1
  43. package/out/src/SetupClient.mobile.js +0 -183
  44. package/out/src/SetupClient.mobile.js.map +0 -1
  45. package/out/src/SetupWallet.mobile.d.ts +0 -93
  46. package/out/src/SetupWallet.mobile.d.ts.map +0 -1
  47. package/out/src/SetupWallet.mobile.js +0 -3
  48. package/out/src/SetupWallet.mobile.js.map +0 -1
  49. package/out/src/services/chaintracker/BhsChainTracker.d.ts.map +0 -1
  50. package/out/src/services/chaintracker/BhsChainTracker.js +0 -84
  51. package/out/src/services/chaintracker/BhsChainTracker.js.map +0 -1
  52. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.d.ts +0 -98
  53. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.d.ts.map +0 -1
  54. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.js +0 -38
  55. package/out/src/services/chaintracker/chaintracks/BlockHeaderApi.js.map +0 -1
@@ -0,0 +1,140 @@
1
+ import { BigNumber } from '@bsv/sdk';
2
+ import { BaseBlockHeader, BlockHeader } from '../Api/BlockHeaderApi';
3
+ import { Chain } from '../../../../sdk/types';
4
+ /**
5
+ * Computes sha256 hash of file contents read as bytes with no encoding.
6
+ * @param filepath Full filepath to file.
7
+ * @param bufferSize Optional read buffer size to use. Defaults to 80,000 bytes.
8
+ * @returns `{hash, length}` where `hash` is base64 string form of file hash and `length` is file length in bytes.
9
+ */
10
+ /**
11
+ * Validate headers contained in an array of bytes. The headers must be consecutive block headers, 80 bytes long,
12
+ * where the hash of each header equals the previousHash of the following header.
13
+ * @param buffer Buffer of headers to be validated.
14
+ * @param previousHash Expected previousHash of first header.
15
+ * @param offset Optional starting offset within `buffer`.
16
+ * @param count Optional number of headers to validate. Validates to end of buffer if missing.
17
+ * @returns Header hash of last header validated or previousHash if there where none.
18
+ */
19
+ export declare function validateBufferOfHeaders(buffer: number[], previousHash: string, offset?: number, count?: number): string;
20
+ /**
21
+ * @param work chainWork as a BigNumber
22
+ * @returns Converted chainWork value from BN to hex string of 32 bytes.
23
+ */
24
+ export declare function workBNtoBuffer(work: BigNumber): string;
25
+ /**
26
+ * Returns true if work1 is more work (greater than) work2
27
+ */
28
+ export declare function isMoreWork(work1: string, work2: string): boolean;
29
+ /**
30
+ * Add two Buffer encoded chainwork values
31
+ * @returns Sum of work1 + work2 as Buffer encoded chainWork value
32
+ */
33
+ export declare function addWork(work1: string, work2: string): string;
34
+ /**
35
+ * Subtract Buffer encoded chainwork values
36
+ * @returns work1 - work2 as Buffer encoded chainWork value
37
+ */
38
+ export declare function subWork(work1: string, work2: string): string;
39
+ /**
40
+ * Computes "target" value for 4 byte Bitcoin block header "bits" value.
41
+ * @param bits number or converted from Buffer using `readUint32LE`
42
+ * @returns 32 byte Buffer with "target" value
43
+ */
44
+ export declare function convertBitsToTarget(bits: number | number[]): BigNumber;
45
+ /**
46
+ * Computes "chainWork" value for 4 byte Bitcoin block header "bits" value.
47
+ * @param bits number or converted from Buffer using `readUint32LE`
48
+ * @returns 32 byte Buffer with "chainWork" value
49
+ */
50
+ export declare function convertBitsToWork(bits: number | number[]): string;
51
+ export declare function deserializeBaseBlockHeaders(buffer: number[], offset?: number, count?: number | undefined): BaseBlockHeader[];
52
+ export declare function deserializeBlockHeaders(firstHeight: number, buffer: number[], offset?: number, count?: number | undefined): BlockHeader[];
53
+ /**
54
+ * Extract an array of block hashes and of merkleRoots from a buffer of serialized block headers.
55
+ * @param buffer
56
+ */
57
+ export declare function extractHashesAndRoots(buffer: Buffer): {
58
+ hashes: Buffer[];
59
+ merkleRoots: Buffer[];
60
+ };
61
+ /**
62
+ * Given a block header, ensures that its format is correct. This does not
63
+ * check its difficulty or validity relative to the chain of headers.
64
+ *
65
+ * Throws on format errors.
66
+ *
67
+ * @param The header to validate
68
+ *
69
+ * @returns true if the header is correctly formatted
70
+ */
71
+ export declare function validateHeaderFormat(header: BlockHeader): void;
72
+ /**
73
+ * Ensures that a header has a valid proof-of-work
74
+ * Requires chain is 'main'
75
+ *
76
+ * @param header The header to validate
77
+ *
78
+ * @returns true if the header is valid
79
+ */
80
+ export declare function validateHeaderDifficulty(hash: Buffer, bits: number): boolean;
81
+ /**
82
+ * Computes double sha256 hash of bitcoin block header
83
+ * bytes are reversed to bigendian order
84
+ *
85
+ * If header is a Buffer, it is required to 80 bytes long
86
+ * and in standard block header serialized encoding.
87
+ *
88
+ * @returns doule sha256 hash of header bytes reversed
89
+ * @publicbody
90
+ */
91
+ export declare function blockHash(header: BaseBlockHeader | number[]): string;
92
+ /**
93
+ * Serializes a block header as an 80 byte Buffer.
94
+ * The exact serialized format is defined in the Bitcoin White Paper
95
+ * such that computing a double sha256 hash of the buffer computes
96
+ * the block hash for the header.
97
+ * @returns 80 byte Buffer
98
+ * @publicbody
99
+ */
100
+ export declare function serializeBlockHeader(header: BaseBlockHeader, buffer?: number[], offset?: number): number[];
101
+ /**
102
+ * Deserialize a block header from an 80 byte buffer
103
+ * @publicbody
104
+ */
105
+ export declare function deserializeBlockHeader(buffer: number[], offset?: number): BaseBlockHeader;
106
+ /**
107
+ * Returns the genesis block for the specified chain.
108
+ * @publicbody
109
+ */
110
+ export declare function genesisHeader(chain: Chain): BlockHeader;
111
+ /**
112
+ * Returns the genesis block for the specified chain.
113
+ * @publicbody
114
+ */
115
+ export declare function genesisBuffer(chain: Chain): number[];
116
+ /**
117
+ * Returns a copy of a Buffer with byte order reversed.
118
+ * @returns new buffer with byte order reversed.
119
+ * @publicbody
120
+ */
121
+ export declare function swapByteOrder(buffer: number[]): number[];
122
+ /**
123
+ * @param num a number value in the Uint32 value range
124
+ * @param littleEndian true for little-endian byte order in Buffer
125
+ * @returns four byte buffer with Uint32 number encoded
126
+ * @publicbody
127
+ */
128
+ export declare function convertUint32ToBuffer(n: number, littleEndian?: boolean): number[];
129
+ export declare function writeUInt32LE(n: number, a: number[], offset: number): number;
130
+ export declare function writeUInt32BE(n: number, a: number[], offset: number): number;
131
+ export declare function readUInt32LE(a: number[], offset: number): number;
132
+ export declare function readUInt32BE(a: number[], offset: number): number;
133
+ /**
134
+ * @param buffer four byte buffer with Uint32 number encoded
135
+ * @param littleEndian true for little-endian byte order in Buffer
136
+ * @returns a number value in the Uint32 value range
137
+ * @publicbody
138
+ */
139
+ export declare function convertBufferToUint32(buffer: number[], littleEndian?: boolean): number;
140
+ //# sourceMappingURL=blockHeaderUtilities.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blockHeaderUtilities.d.ts","sourceRoot":"","sources":["../../../../../../../src/services/chaintracker/chaintracks/util/blockHeaderUtilities.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAe,MAAM,UAAU,CAAA;AAIjD,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACpE,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAA;AAE7C;;;;;GAKG;AA4BH;;;;;;;;GAQG;AACH,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,SAAI,EAAE,KAAK,SAAK,GAAG,MAAM,CAoB9G;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,SAAS,GAAG,MAAM,CAEtD;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAEhE;AAED;;;GAGG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAG5D;AAED;;;GAGG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAG5D;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CActE;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,CAOjE;AAED,wBAAgB,2BAA2B,CACzC,MAAM,EAAE,MAAM,EAAE,EAChB,MAAM,SAAI,EACV,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,GACzB,eAAe,EAAE,CAOnB;AAED,wBAAgB,uBAAuB,CACrC,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,EAAE,EAChB,MAAM,SAAI,EACV,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,GACzB,WAAW,EAAE,CAef;AAED;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG;IAAE,MAAM,EAAE,MAAM,EAAE,CAAC;IAAC,WAAW,EAAE,MAAM,EAAE,CAAA;CAAE,CAWjG;AAED;;;;;;;;;GASG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI,CAmH9D;AAED;;;;;;;GAOG;AACH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,WAQlE;AAED;;;;;;;;;GASG;AACH,wBAAgB,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,MAAM,EAAE,GAAG,MAAM,CAIpE;AAED;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAc1G;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,SAAI,GAAG,eAAe,CAWpF;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,KAAK,GAAG,WAAW,CAsBvD;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,EAAE,CAEpD;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAExD;AAED;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,CAAC,EAAE,MAAM,EAAE,YAAY,UAAO,GAAG,MAAM,EAAE,CAQ9E;AAED,wBAAgB,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAM5E;AAED,wBAAgB,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAM5E;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAEhE;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAEhE;AAED;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,YAAY,UAAO,GAAG,MAAM,CAInF"}
@@ -0,0 +1,467 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validateBufferOfHeaders = validateBufferOfHeaders;
4
+ exports.workBNtoBuffer = workBNtoBuffer;
5
+ exports.isMoreWork = isMoreWork;
6
+ exports.addWork = addWork;
7
+ exports.subWork = subWork;
8
+ exports.convertBitsToTarget = convertBitsToTarget;
9
+ exports.convertBitsToWork = convertBitsToWork;
10
+ exports.deserializeBaseBlockHeaders = deserializeBaseBlockHeaders;
11
+ exports.deserializeBlockHeaders = deserializeBlockHeaders;
12
+ exports.extractHashesAndRoots = extractHashesAndRoots;
13
+ exports.validateHeaderFormat = validateHeaderFormat;
14
+ exports.validateHeaderDifficulty = validateHeaderDifficulty;
15
+ exports.blockHash = blockHash;
16
+ exports.serializeBlockHeader = serializeBlockHeader;
17
+ exports.deserializeBlockHeader = deserializeBlockHeader;
18
+ exports.genesisHeader = genesisHeader;
19
+ exports.genesisBuffer = genesisBuffer;
20
+ exports.swapByteOrder = swapByteOrder;
21
+ exports.convertUint32ToBuffer = convertUint32ToBuffer;
22
+ exports.writeUInt32LE = writeUInt32LE;
23
+ exports.writeUInt32BE = writeUInt32BE;
24
+ exports.readUInt32LE = readUInt32LE;
25
+ exports.readUInt32BE = readUInt32BE;
26
+ exports.convertBufferToUint32 = convertBufferToUint32;
27
+ const dirtyHashes_1 = require("./dirtyHashes");
28
+ const sdk_1 = require("@bsv/sdk");
29
+ const utilityHelpers_buffer_1 = require("../../../../utility/utilityHelpers.buffer");
30
+ const utilityHelpers_1 = require("../../../../utility/utilityHelpers");
31
+ /**
32
+ * Computes sha256 hash of file contents read as bytes with no encoding.
33
+ * @param filepath Full filepath to file.
34
+ * @param bufferSize Optional read buffer size to use. Defaults to 80,000 bytes.
35
+ * @returns `{hash, length}` where `hash` is base64 string form of file hash and `length` is file length in bytes.
36
+ */
37
+ /*
38
+ export async function sha256HashOfBinaryFile(
39
+ filepath: string,
40
+ bufferSize = 80000
41
+ ): Promise<{ hash: string; length: number }> {
42
+ const file = await fs.open(filepath, 'r')
43
+ try {
44
+ let length = 0
45
+
46
+ const sha256 = new Hash.SHA256()
47
+ const readBuf = Buffer.alloc(bufferSize)
48
+
49
+ // eslint-disable-next-line no-constant-condition
50
+ while (true) {
51
+ const rr = await file.read(readBuf, 0, readBuf.length)
52
+ if (!rr.bytesRead) break
53
+ length += rr.bytesRead
54
+ sha256.update(asArray(rr.buffer))
55
+ }
56
+
57
+ return { hash: Utils.toBase64(sha256.digest()), length }
58
+ } finally {
59
+ await file.close()
60
+ }
61
+ }
62
+ */
63
+ /**
64
+ * Validate headers contained in an array of bytes. The headers must be consecutive block headers, 80 bytes long,
65
+ * where the hash of each header equals the previousHash of the following header.
66
+ * @param buffer Buffer of headers to be validated.
67
+ * @param previousHash Expected previousHash of first header.
68
+ * @param offset Optional starting offset within `buffer`.
69
+ * @param count Optional number of headers to validate. Validates to end of buffer if missing.
70
+ * @returns Header hash of last header validated or previousHash if there where none.
71
+ */
72
+ function validateBufferOfHeaders(buffer, previousHash, offset = 0, count = -1) {
73
+ if (count < 0)
74
+ count = Math.floor((buffer.length - offset) / 80);
75
+ count = Math.max(0, count);
76
+ let lastHeaderHash = previousHash;
77
+ for (let i = 0; i < count; i++) {
78
+ const headerStart = offset + i * 80;
79
+ const headerEnd = headerStart + 80;
80
+ if (headerEnd > buffer.length) {
81
+ throw {
82
+ message: `header ${i} missing bytes for header at offset ${headerStart} in buffer of length ${buffer.length}`
83
+ };
84
+ }
85
+ const header = buffer.slice(headerStart, headerEnd);
86
+ const hashPrev = (0, utilityHelpers_buffer_1.asString)(header.slice(4, 36).reverse());
87
+ if (lastHeaderHash !== hashPrev)
88
+ throw { message: `header ${i} invalid previousHash ${lastHeaderHash} vs ${hashPrev}` };
89
+ lastHeaderHash = (0, utilityHelpers_buffer_1.asString)((0, utilityHelpers_1.doubleSha256BE)(header));
90
+ (0, dirtyHashes_1.validateAgainstDirtyHashes)(lastHeaderHash);
91
+ }
92
+ return lastHeaderHash;
93
+ }
94
+ /**
95
+ * @param work chainWork as a BigNumber
96
+ * @returns Converted chainWork value from BN to hex string of 32 bytes.
97
+ */
98
+ function workBNtoBuffer(work) {
99
+ return work.toString(16).padStart(64, '0');
100
+ }
101
+ /**
102
+ * Returns true if work1 is more work (greater than) work2
103
+ */
104
+ function isMoreWork(work1, work2) {
105
+ return new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(work1), 16).gt(new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(work2), 16));
106
+ }
107
+ /**
108
+ * Add two Buffer encoded chainwork values
109
+ * @returns Sum of work1 + work2 as Buffer encoded chainWork value
110
+ */
111
+ function addWork(work1, work2) {
112
+ const sum = new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(work1), 16).add(new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(work2), 16));
113
+ return workBNtoBuffer(sum);
114
+ }
115
+ /**
116
+ * Subtract Buffer encoded chainwork values
117
+ * @returns work1 - work2 as Buffer encoded chainWork value
118
+ */
119
+ function subWork(work1, work2) {
120
+ const sum = new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(work1), 16).sub(new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(work2), 16));
121
+ return workBNtoBuffer(sum);
122
+ }
123
+ /**
124
+ * Computes "target" value for 4 byte Bitcoin block header "bits" value.
125
+ * @param bits number or converted from Buffer using `readUint32LE`
126
+ * @returns 32 byte Buffer with "target" value
127
+ */
128
+ function convertBitsToTarget(bits) {
129
+ if (Array.isArray(bits))
130
+ bits = readUInt32LE(bits, 0);
131
+ const shift = (bits >> 24) & 0xff;
132
+ const data = bits & 0x007fffff;
133
+ const target = new sdk_1.BigNumber(data);
134
+ if (shift <= 3) {
135
+ target.iushrn(8 * (3 - shift));
136
+ }
137
+ else {
138
+ target.iushln(8 * (shift - 3));
139
+ }
140
+ return target;
141
+ }
142
+ /**
143
+ * Computes "chainWork" value for 4 byte Bitcoin block header "bits" value.
144
+ * @param bits number or converted from Buffer using `readUint32LE`
145
+ * @returns 32 byte Buffer with "chainWork" value
146
+ */
147
+ function convertBitsToWork(bits) {
148
+ const target = convertBitsToTarget(bits);
149
+ // convert target to work
150
+ const work = target.notn(256).div(target.addn(1)).addn(1);
151
+ return work.toString(16).padStart(64, '0');
152
+ }
153
+ function deserializeBaseBlockHeaders(buffer, offset = 0, count) {
154
+ const headers = [];
155
+ while ((!count || headers.length < count) && offset + 80 <= buffer.length && offset >= 0) {
156
+ headers.push(deserializeBlockHeader(buffer, offset));
157
+ offset += 80;
158
+ }
159
+ return headers;
160
+ }
161
+ function deserializeBlockHeaders(firstHeight, buffer, offset = 0, count) {
162
+ const headers = [];
163
+ let nextHeight = firstHeight;
164
+ while ((!count || headers.length < count) && offset + 80 <= buffer.length && offset >= 0) {
165
+ const baseBuffer = buffer.slice(offset, offset + 80);
166
+ const base = deserializeBlockHeader(baseBuffer);
167
+ const header = {
168
+ ...base,
169
+ height: nextHeight++,
170
+ hash: (0, utilityHelpers_buffer_1.asString)(blockHash(baseBuffer))
171
+ };
172
+ headers.push(header);
173
+ offset += 80;
174
+ }
175
+ return headers;
176
+ }
177
+ /**
178
+ * Extract an array of block hashes and of merkleRoots from a buffer of serialized block headers.
179
+ * @param buffer
180
+ */
181
+ function extractHashesAndRoots(buffer) {
182
+ const hashes = [];
183
+ const merkleRoots = [];
184
+ for (let i = 0; i < buffer.length / 80; i++) {
185
+ const offset = i * 80;
186
+ const hash = (0, utilityHelpers_buffer_1.asBuffer)((0, utilityHelpers_1.doubleSha256LE)((0, utilityHelpers_buffer_1.asArray)(buffer.subarray(offset, 80 + offset))).reverse());
187
+ const merkleRoot = buffer.subarray(36 + offset, 68 + offset).reverse();
188
+ hashes.push(hash);
189
+ merkleRoots.push(merkleRoot);
190
+ }
191
+ return { hashes, merkleRoots };
192
+ }
193
+ /**
194
+ * Given a block header, ensures that its format is correct. This does not
195
+ * check its difficulty or validity relative to the chain of headers.
196
+ *
197
+ * Throws on format errors.
198
+ *
199
+ * @param The header to validate
200
+ *
201
+ * @returns true if the header is correctly formatted
202
+ */
203
+ function validateHeaderFormat(header) {
204
+ const ALLOWED_KEYS = {
205
+ version: true,
206
+ previousHash: true,
207
+ merkleRoot: true,
208
+ time: true,
209
+ bits: true,
210
+ nonce: true,
211
+ height: true,
212
+ hash: true
213
+ };
214
+ const UINT_MAX = 0xffffffff;
215
+ /**
216
+ * Root object checks
217
+ */
218
+ if (typeof header === 'undefined') {
219
+ throw new Error('Missing header.');
220
+ }
221
+ if (typeof header !== 'object') {
222
+ throw new Error('Header must be an object.');
223
+ }
224
+ if (!Object.keys(header).every(key => ALLOWED_KEYS[key])) {
225
+ throw new Error('Header contains extra properties.');
226
+ }
227
+ /**
228
+ * Version
229
+ */
230
+ if (typeof header.version !== 'number') {
231
+ throw new Error('Header version must be a number.');
232
+ }
233
+ if (!Number.isInteger(header.version)) {
234
+ throw new Error('Header version must be an integer.');
235
+ }
236
+ if (header.version < 0 || header.version > UINT_MAX) {
237
+ throw new Error(`Header version must be between 0 and ${UINT_MAX}.`);
238
+ }
239
+ /**
240
+ * Height
241
+ */
242
+ if (typeof header.height !== 'number') {
243
+ throw new Error('Header height must be a number.');
244
+ }
245
+ if (!Number.isInteger(header.height)) {
246
+ throw new Error('Header height must be an integer.');
247
+ }
248
+ if (header.height < 0 || header.height > UINT_MAX / 2) {
249
+ throw new Error(`Header version must be between 0 and ${UINT_MAX / 2}.`);
250
+ }
251
+ /**
252
+ * Previous hash
253
+ */
254
+ if (header.previousHash.length !== 64) {
255
+ throw new Error('Header previousHash must be 32 hex bytes.');
256
+ }
257
+ /**
258
+ * Merkle root
259
+ */
260
+ if (header.merkleRoot.length !== 64) {
261
+ throw new Error('Header merkleRoot must be 32 hex bytes.');
262
+ }
263
+ /**
264
+ * Time
265
+ */
266
+ if (typeof header.time !== 'number') {
267
+ throw new Error('Header time must be a number.');
268
+ }
269
+ if (!Number.isInteger(header.time)) {
270
+ throw new Error('Header time must be an integer.');
271
+ }
272
+ if (header.time < 0 || header.time > UINT_MAX) {
273
+ throw new Error(`Header time must be between 0 and ${UINT_MAX}.`);
274
+ }
275
+ /**
276
+ * Bits
277
+ */
278
+ if (typeof header.bits !== 'number') {
279
+ throw new Error('Header bits must be a number.');
280
+ }
281
+ if (!Number.isInteger(header.bits)) {
282
+ throw new Error('Header bits must be an integer.');
283
+ }
284
+ if (header.bits < 0 || header.bits > UINT_MAX) {
285
+ throw new Error(`Header bits must be between 0 and ${UINT_MAX}.`);
286
+ }
287
+ /**
288
+ * Nonce
289
+ */
290
+ if (typeof header.nonce !== 'number') {
291
+ throw new Error('Header nonce must be a number.');
292
+ }
293
+ if (!Number.isInteger(header.nonce)) {
294
+ throw new Error('Header nonce must be an integer.');
295
+ }
296
+ if (header.nonce < 0 || header.nonce > UINT_MAX) {
297
+ throw new Error(`Header nonce must be between 0 and ${UINT_MAX}.`);
298
+ }
299
+ /**
300
+ * Hash
301
+ */
302
+ if (header.hash.length !== 64) {
303
+ throw new Error('Header hash must be 32 hex bytes.');
304
+ }
305
+ if (header.hash !== (0, utilityHelpers_buffer_1.asString)(blockHash(header))) {
306
+ throw new Error('Header hash is invalid.');
307
+ }
308
+ }
309
+ /**
310
+ * Ensures that a header has a valid proof-of-work
311
+ * Requires chain is 'main'
312
+ *
313
+ * @param header The header to validate
314
+ *
315
+ * @returns true if the header is valid
316
+ */
317
+ function validateHeaderDifficulty(hash, bits) {
318
+ const hashBN = new sdk_1.BigNumber((0, utilityHelpers_buffer_1.asArray)(hash));
319
+ const target = convertBitsToTarget(bits);
320
+ if (hashBN.lte(target))
321
+ return true;
322
+ throw new Error('Block hash is not less than specified target.');
323
+ }
324
+ /**
325
+ * Computes double sha256 hash of bitcoin block header
326
+ * bytes are reversed to bigendian order
327
+ *
328
+ * If header is a Buffer, it is required to 80 bytes long
329
+ * and in standard block header serialized encoding.
330
+ *
331
+ * @returns doule sha256 hash of header bytes reversed
332
+ * @publicbody
333
+ */
334
+ function blockHash(header) {
335
+ const a = !Array.isArray(header) ? serializeBlockHeader(header) : header;
336
+ if (a.length !== 80)
337
+ throw new Error('Block header must be 80 bytes long.');
338
+ return (0, utilityHelpers_buffer_1.asString)((0, utilityHelpers_1.doubleSha256BE)(a));
339
+ }
340
+ /**
341
+ * Serializes a block header as an 80 byte Buffer.
342
+ * The exact serialized format is defined in the Bitcoin White Paper
343
+ * such that computing a double sha256 hash of the buffer computes
344
+ * the block hash for the header.
345
+ * @returns 80 byte Buffer
346
+ * @publicbody
347
+ */
348
+ function serializeBlockHeader(header, buffer, offset) {
349
+ const writer = new sdk_1.Utils.Writer();
350
+ writer.writeUInt32LE(header.version);
351
+ writer.write((0, utilityHelpers_buffer_1.asArray)(header.previousHash).reverse());
352
+ writer.write((0, utilityHelpers_buffer_1.asArray)(header.merkleRoot).reverse());
353
+ writer.writeUInt32LE(header.time);
354
+ writer.writeUInt32LE(header.bits);
355
+ writer.writeUInt32LE(header.nonce);
356
+ const data = writer.toArray();
357
+ if (buffer) {
358
+ offset || (offset = 0);
359
+ buffer.splice(offset, buffer.length, ...data);
360
+ }
361
+ return data;
362
+ }
363
+ /**
364
+ * Deserialize a block header from an 80 byte buffer
365
+ * @publicbody
366
+ */
367
+ function deserializeBlockHeader(buffer, offset = 0) {
368
+ const reader = new sdk_1.Utils.Reader(buffer, offset);
369
+ const header = {
370
+ version: reader.readUInt32LE(),
371
+ previousHash: (0, utilityHelpers_buffer_1.asString)(reader.read(32).reverse()),
372
+ merkleRoot: (0, utilityHelpers_buffer_1.asString)(reader.read(32).reverse()),
373
+ time: reader.readUInt32LE(),
374
+ bits: reader.readUInt32LE(),
375
+ nonce: reader.readUInt32LE()
376
+ };
377
+ return header;
378
+ }
379
+ /**
380
+ * Returns the genesis block for the specified chain.
381
+ * @publicbody
382
+ */
383
+ function genesisHeader(chain) {
384
+ return chain === 'main'
385
+ ? {
386
+ version: 1,
387
+ previousHash: '0000000000000000000000000000000000000000000000000000000000000000',
388
+ merkleRoot: '4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b',
389
+ time: 1231006505,
390
+ bits: 486604799,
391
+ nonce: 2083236893,
392
+ height: 0,
393
+ hash: '000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f'
394
+ }
395
+ : {
396
+ version: 1,
397
+ previousHash: '0000000000000000000000000000000000000000000000000000000000000000',
398
+ merkleRoot: '4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b',
399
+ time: 1296688602,
400
+ bits: 486604799,
401
+ nonce: 414098458,
402
+ height: 0,
403
+ hash: '000000000933ea01ad0ee984209779baaec3ced90fa3f408719526f8d77f4943'
404
+ };
405
+ }
406
+ /**
407
+ * Returns the genesis block for the specified chain.
408
+ * @publicbody
409
+ */
410
+ function genesisBuffer(chain) {
411
+ return serializeBlockHeader(genesisHeader(chain));
412
+ }
413
+ /**
414
+ * Returns a copy of a Buffer with byte order reversed.
415
+ * @returns new buffer with byte order reversed.
416
+ * @publicbody
417
+ */
418
+ function swapByteOrder(buffer) {
419
+ return buffer.slice().reverse();
420
+ }
421
+ /**
422
+ * @param num a number value in the Uint32 value range
423
+ * @param littleEndian true for little-endian byte order in Buffer
424
+ * @returns four byte buffer with Uint32 number encoded
425
+ * @publicbody
426
+ */
427
+ function convertUint32ToBuffer(n, littleEndian = true) {
428
+ const a = [
429
+ n & 0xff, // lowest byte
430
+ (n >> 8) & 0xff,
431
+ (n >> 16) & 0xff,
432
+ (n >> 24) & 0xff // highest byte
433
+ ];
434
+ return littleEndian ? a : a.reverse();
435
+ }
436
+ function writeUInt32LE(n, a, offset) {
437
+ a[offset++] = n & 0xff; // lowest byte
438
+ a[offset++] = (n >> 8) & 0xff;
439
+ a[offset++] = (n >> 16) & 0xff;
440
+ a[offset++] = (n >> 24) & 0xff; // highest byte
441
+ return offset;
442
+ }
443
+ function writeUInt32BE(n, a, offset) {
444
+ a[offset++] = (n >> 24) & 0xff; // highest byte
445
+ a[offset++] = (n >> 16) & 0xff;
446
+ a[offset++] = (n >> 8) & 0xff;
447
+ a[offset++] = n & 0xff; // lowest byte
448
+ return offset;
449
+ }
450
+ function readUInt32LE(a, offset) {
451
+ return a[offset++] | (a[offset++] << 8) | (a[offset++] << 16) | (a[offset++] << 24);
452
+ }
453
+ function readUInt32BE(a, offset) {
454
+ return (a[offset++] << 24) | (a[offset++] << 16) | (a[offset++] << 8) | a[offset++];
455
+ }
456
+ /**
457
+ * @param buffer four byte buffer with Uint32 number encoded
458
+ * @param littleEndian true for little-endian byte order in Buffer
459
+ * @returns a number value in the Uint32 value range
460
+ * @publicbody
461
+ */
462
+ function convertBufferToUint32(buffer, littleEndian = true) {
463
+ const a = littleEndian ? buffer : buffer.slice().reverse();
464
+ const n = a[0] | (a[1] << 8) | (a[2] << 16) | (a[3] << 24);
465
+ return n;
466
+ }
467
+ //# sourceMappingURL=blockHeaderUtilities.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blockHeaderUtilities.js","sourceRoot":"","sources":["../../../../../../../src/services/chaintracker/chaintracks/util/blockHeaderUtilities.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * These hashes are for blocks that are to known to have violated the Bitcoin
3
+ * protocol. Regardless of the amount of proof-of-work that chains built on top
4
+ * of them may have accumulated, they cannot be considered valid Bitcoin blocks.
5
+ *
6
+ * In the first instance, segregating witness data from transactions is not
7
+ * part of the design of Bitcoin.
8
+ *
9
+ * In the second instance, adding new opcodes to be used when evaluating
10
+ * scripts is also not allowed.
11
+ */
12
+ export declare const dirtyHashes: {
13
+ '00000000000000000019f112ec0a9982926f1258cdcc558dd7c3b7e5dc7fa148': string;
14
+ '0000000000000000004626ff6e3b936941d341c5932ece4357eeccac44e6d56c': string;
15
+ };
16
+ /**
17
+ * Throws Error if blockHash is in the dirtyHashes list.
18
+ */
19
+ export declare function validateAgainstDirtyHashes(blockHash: string): void;
20
+ //# sourceMappingURL=dirtyHashes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dirtyHashes.d.ts","sourceRoot":"","sources":["../../../../../../../src/services/chaintracker/chaintracks/util/dirtyHashes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AACH,eAAO,MAAM,WAAW;;;CAQvB,CAAA;AAED;;GAEG;AACH,wBAAgB,0BAA0B,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,CAIlE"}