@witnet/sdk 1.0.0-beta.0
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.
- package/LICENSE +21 -0
- package/README.md +103 -0
- package/dist/package.json +72 -0
- package/dist/src/bin/helpers.d.ts +91 -0
- package/dist/src/bin/helpers.d.ts.map +1 -0
- package/dist/src/bin/helpers.js +816 -0
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +47 -0
- package/dist/src/lib/crypto/account.d.ts +32 -0
- package/dist/src/lib/crypto/account.d.ts.map +1 -0
- package/dist/src/lib/crypto/account.js +106 -0
- package/dist/src/lib/crypto/coinbase.d.ts +10 -0
- package/dist/src/lib/crypto/coinbase.d.ts.map +1 -0
- package/dist/src/lib/crypto/coinbase.js +28 -0
- package/dist/src/lib/crypto/index.d.ts +8 -0
- package/dist/src/lib/crypto/index.d.ts.map +1 -0
- package/dist/src/lib/crypto/index.js +30 -0
- package/dist/src/lib/crypto/interfaces.d.ts +85 -0
- package/dist/src/lib/crypto/interfaces.d.ts.map +1 -0
- package/dist/src/lib/crypto/interfaces.js +3 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts +55 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.js +339 -0
- package/dist/src/lib/crypto/payloads/StakePayload.d.ts +28 -0
- package/dist/src/lib/crypto/payloads/StakePayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/StakePayload.js +142 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts +36 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.js +154 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts +25 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +128 -0
- package/dist/src/lib/crypto/payloads.d.ts +57 -0
- package/dist/src/lib/crypto/payloads.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads.js +170 -0
- package/dist/src/lib/crypto/signer.d.ts +33 -0
- package/dist/src/lib/crypto/signer.d.ts.map +1 -0
- package/dist/src/lib/crypto/signer.js +194 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.d.ts +15 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.js +23 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts +12 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.js +17 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts +18 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +53 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts +11 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.js +16 -0
- package/dist/src/lib/crypto/transmitters.d.ts +47 -0
- package/dist/src/lib/crypto/transmitters.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters.js +416 -0
- package/dist/src/lib/crypto/types.d.ts +161 -0
- package/dist/src/lib/crypto/types.d.ts.map +1 -0
- package/dist/src/lib/crypto/types.js +273 -0
- package/dist/src/lib/crypto/utils.d.ts +21 -0
- package/dist/src/lib/crypto/utils.d.ts.map +1 -0
- package/dist/src/lib/crypto/utils.js +156 -0
- package/dist/src/lib/crypto/wallet.d.ts +120 -0
- package/dist/src/lib/crypto/wallet.d.ts.map +1 -0
- package/dist/src/lib/crypto/wallet.js +258 -0
- package/dist/src/lib/index.d.ts +5 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +44 -0
- package/dist/src/lib/radon/ccdr/eth.d.ts +160 -0
- package/dist/src/lib/radon/ccdr/eth.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/eth.js +272 -0
- package/dist/src/lib/radon/ccdr/index.d.ts +14 -0
- package/dist/src/lib/radon/ccdr/index.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/index.js +39 -0
- package/dist/src/lib/radon/ccdr/wit.d.ts +23 -0
- package/dist/src/lib/radon/ccdr/wit.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/wit.js +35 -0
- package/dist/src/lib/radon/filters.d.ts +14 -0
- package/dist/src/lib/radon/filters.d.ts.map +1 -0
- package/dist/src/lib/radon/filters.js +45 -0
- package/dist/src/lib/radon/index.d.ts +296 -0
- package/dist/src/lib/radon/index.d.ts.map +1 -0
- package/dist/src/lib/radon/index.js +707 -0
- package/dist/src/lib/radon/reducers.d.ts +29 -0
- package/dist/src/lib/radon/reducers.d.ts.map +1 -0
- package/dist/src/lib/radon/reducers.js +66 -0
- package/dist/src/lib/radon/types.d.ts +521 -0
- package/dist/src/lib/radon/types.d.ts.map +1 -0
- package/dist/src/lib/radon/types.js +936 -0
- package/dist/src/lib/radon/utils.d.ts +53 -0
- package/dist/src/lib/radon/utils.d.ts.map +1 -0
- package/dist/src/lib/radon/utils.js +153 -0
- package/dist/src/lib/rpc/index.d.ts +3 -0
- package/dist/src/lib/rpc/index.d.ts.map +1 -0
- package/dist/src/lib/rpc/index.js +19 -0
- package/dist/src/lib/rpc/nodes.d.ts +40 -0
- package/dist/src/lib/rpc/nodes.d.ts.map +1 -0
- package/dist/src/lib/rpc/nodes.js +293 -0
- package/dist/src/lib/rpc/provider.d.ts +88 -0
- package/dist/src/lib/rpc/provider.d.ts.map +1 -0
- package/dist/src/lib/rpc/provider.js +336 -0
- package/dist/src/lib/rpc/reporter.d.ts +18 -0
- package/dist/src/lib/rpc/reporter.d.ts.map +1 -0
- package/dist/src/lib/rpc/reporter.js +30 -0
- package/dist/src/lib/rpc/types.d.ts +409 -0
- package/dist/src/lib/rpc/types.d.ts.map +1 -0
- package/dist/src/lib/rpc/types.js +81 -0
- package/dist/src/lib/types.d.ts +18 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +7 -0
- package/dist/src/lib/utils.d.ts +13 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +97 -0
- package/dist/witnet/assets/index.d.ts +30 -0
- package/dist/witnet/assets/index.d.ts.map +1 -0
- package/dist/witnet/assets/index.js +6 -0
- package/dist/witnet/assets/modals/index.d.ts +18 -0
- package/dist/witnet/assets/modals/index.d.ts.map +1 -0
- package/dist/witnet/assets/modals/index.js +21 -0
- package/dist/witnet/assets/modals/web3/eth.d.ts +5 -0
- package/dist/witnet/assets/modals/web3/eth.d.ts.map +1 -0
- package/dist/witnet/assets/modals/web3/eth.js +26 -0
- package/dist/witnet/assets/modals/web3/wit.d.ts +4 -0
- package/dist/witnet/assets/modals/web3/wit.d.ts.map +1 -0
- package/dist/witnet/assets/modals/web3/wit.js +20 -0
- package/dist/witnet/assets/requests.d.ts +11 -0
- package/dist/witnet/assets/requests.d.ts.map +1 -0
- package/dist/witnet/assets/requests.js +88 -0
- package/dist/witnet/witnet.proto.json +1325 -0
- package/package.json +72 -0
- package/src/bin/cli/history.js +31 -0
- package/src/bin/cli/inspect.js +359 -0
- package/src/bin/cli/network.js +592 -0
- package/src/bin/cli/nodes.js +364 -0
- package/src/bin/cli/radon.js +814 -0
- package/src/bin/cli/wallet.js +1000 -0
- package/src/bin/helpers.js +829 -0
- package/src/bin/postinstall.js +9 -0
- package/src/bin/toolkit.js +294 -0
- package/witnet/assets/_index.js +8 -0
- package/witnet/assets/_requests.js +25 -0
- package/witnet/assets/_sources.js +36 -0
- package/witnet/assets/_templates.js +36 -0
- package/witnet/assets/index.js +4 -0
- package/witnet/assets/modals/index.js +25 -0
- package/witnet/assets/modals/web3/btc.js +0 -0
- package/witnet/assets/modals/web3/eth.js +29 -0
- package/witnet/assets/modals/web3/sol.js +0 -0
- package/witnet/assets/modals/web3/wit.js +23 -0
- package/witnet/assets/requests.js +94 -0
- package/witnet/witnet.proto.json +1325 -0
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Balance, Epoch, Hash, HexString, UtxoMetadata } from "../types";
|
|
2
|
+
export declare class Coins {
|
|
3
|
+
protected coins: bigint;
|
|
4
|
+
static fromBalance(balance: Balance): Coins;
|
|
5
|
+
static fromNanowits(nanowits: bigint): Coins;
|
|
6
|
+
static fromPedros(pedros: bigint): Coins;
|
|
7
|
+
static fromWits(wits: number): Coins;
|
|
8
|
+
static zero(): Coins;
|
|
9
|
+
constructor(pedros: bigint);
|
|
10
|
+
get pedros(): bigint;
|
|
11
|
+
get nanowits(): bigint;
|
|
12
|
+
get wits(): number;
|
|
13
|
+
toString(decimals?: number): string;
|
|
14
|
+
}
|
|
15
|
+
export type KeyPath = Array<number>;
|
|
16
|
+
export type KeyedSignature = {
|
|
17
|
+
signature: {
|
|
18
|
+
Secp256k1: {
|
|
19
|
+
der: Array<number>;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
public_key: {
|
|
23
|
+
bytes: Array<number>;
|
|
24
|
+
compressed: number;
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
export type PublicKeyHashString = HexString;
|
|
28
|
+
interface Key {
|
|
29
|
+
bytes: Uint8Array;
|
|
30
|
+
}
|
|
31
|
+
export interface PrivateKey extends Key {
|
|
32
|
+
type: "private";
|
|
33
|
+
}
|
|
34
|
+
export interface PublicKey extends Key {
|
|
35
|
+
type: "public";
|
|
36
|
+
}
|
|
37
|
+
export type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any;
|
|
38
|
+
export type TransactionParams = {
|
|
39
|
+
deadline?: Epoch;
|
|
40
|
+
fees?: TransactionPriority | Coins;
|
|
41
|
+
};
|
|
42
|
+
export declare enum TransactionPriority {
|
|
43
|
+
Stinky = "stinky",
|
|
44
|
+
Low = "low",
|
|
45
|
+
Medium = "medium",
|
|
46
|
+
High = "high",
|
|
47
|
+
Opulent = "opulent"
|
|
48
|
+
}
|
|
49
|
+
export type TransactionReceipt = {
|
|
50
|
+
authorization?: HexString;
|
|
51
|
+
blockEpoch?: Epoch;
|
|
52
|
+
blockHash?: Hash;
|
|
53
|
+
blockMiner?: PublicKeyHashString;
|
|
54
|
+
blockTimestamp?: number;
|
|
55
|
+
confirmations?: number;
|
|
56
|
+
change?: Coins;
|
|
57
|
+
droHash?: Hash;
|
|
58
|
+
error?: Error;
|
|
59
|
+
fees: Coins;
|
|
60
|
+
from?: Array<PublicKeyHashString> | PublicKeyHashString;
|
|
61
|
+
hash: Hash;
|
|
62
|
+
outputLock?: number;
|
|
63
|
+
radArgs?: any;
|
|
64
|
+
radHash?: HexString;
|
|
65
|
+
recipients?: Array<[PublicKeyHashString, Coins]>;
|
|
66
|
+
status: string;
|
|
67
|
+
timestamp: number;
|
|
68
|
+
type: string;
|
|
69
|
+
tx?: any;
|
|
70
|
+
validator?: PublicKeyHashString;
|
|
71
|
+
value?: Coins;
|
|
72
|
+
weight: number;
|
|
73
|
+
withdrawer?: PublicKeyHashString;
|
|
74
|
+
witnesses?: number | Record<PublicKeyHashString, Coins>;
|
|
75
|
+
};
|
|
76
|
+
export type TransactionStatus = "signed" | "pending" | "relayed" | "removed" | "mined" | "confirmed" | "finalized";
|
|
77
|
+
export type Transmission = {
|
|
78
|
+
bytecode?: Uint8Array;
|
|
79
|
+
hash?: Hash;
|
|
80
|
+
message: any;
|
|
81
|
+
};
|
|
82
|
+
export type Utxo = UtxoMetadata & {
|
|
83
|
+
signer: PublicKeyHashString;
|
|
84
|
+
};
|
|
85
|
+
export type UtxoCacheInfo = {
|
|
86
|
+
expendable: bigint;
|
|
87
|
+
size: number;
|
|
88
|
+
timelock: number;
|
|
89
|
+
};
|
|
90
|
+
export type UtxoPointer = {
|
|
91
|
+
transaction_id: Hash;
|
|
92
|
+
output_index: number;
|
|
93
|
+
};
|
|
94
|
+
export declare enum UtxoSelectionStrategy {
|
|
95
|
+
BigFirst = "big-first",
|
|
96
|
+
Random = "random",
|
|
97
|
+
SlimFit = "slim-fit",
|
|
98
|
+
SmallFirst = "small-first"
|
|
99
|
+
}
|
|
100
|
+
export declare class PublicKey implements Key {
|
|
101
|
+
readonly compressed: number;
|
|
102
|
+
readonly bytes: Uint8Array;
|
|
103
|
+
static fromProtobuf(protobuf: {
|
|
104
|
+
compressed: number;
|
|
105
|
+
bytes: Array<number>;
|
|
106
|
+
}): PublicKey;
|
|
107
|
+
static fromUint8Array(uint8Array: Uint8Array): PublicKey;
|
|
108
|
+
static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey;
|
|
109
|
+
constructor(compressed: number, bytes: Uint8Array);
|
|
110
|
+
equals(pubKey: PublicKey): boolean;
|
|
111
|
+
hash(): PublicKeyHash;
|
|
112
|
+
toString(): string;
|
|
113
|
+
toUint8Array(): Uint8Array;
|
|
114
|
+
}
|
|
115
|
+
export declare class PublicKeyHash {
|
|
116
|
+
static fromHash(hash: Uint8Array): PublicKeyHash;
|
|
117
|
+
static fromHexString(hash: HexString): PublicKeyHash;
|
|
118
|
+
static fromPublicKey(pk: PublicKey): PublicKeyHash;
|
|
119
|
+
static fromBech32(pkh: string): PublicKeyHash;
|
|
120
|
+
protected words: number[];
|
|
121
|
+
constructor(words: number[]);
|
|
122
|
+
toBech32(network?: string): string;
|
|
123
|
+
toBytes20(): Uint8Array;
|
|
124
|
+
toBytes32(): Uint8Array;
|
|
125
|
+
toHexString(): string;
|
|
126
|
+
}
|
|
127
|
+
export declare class Signature {
|
|
128
|
+
static fromHexString(hex: string): Signature;
|
|
129
|
+
readonly bytes: Uint8Array;
|
|
130
|
+
constructor(bytes: Uint8Array);
|
|
131
|
+
toHexString(): string;
|
|
132
|
+
}
|
|
133
|
+
export declare class RecoverableSignature extends Signature {
|
|
134
|
+
static from(recoverable: any, msg: Uint8Array): RecoverableSignature;
|
|
135
|
+
static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature;
|
|
136
|
+
readonly message: Uint8Array;
|
|
137
|
+
readonly pubKey: PublicKey;
|
|
138
|
+
readonly recoveryId: number;
|
|
139
|
+
constructor(pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array);
|
|
140
|
+
toHexString(): string;
|
|
141
|
+
toKeyedSignature(): any;
|
|
142
|
+
toProtobuf(): any;
|
|
143
|
+
}
|
|
144
|
+
declare abstract class TransactionError extends Error {
|
|
145
|
+
readonly receipt: TransactionReceipt;
|
|
146
|
+
constructor(receipt: TransactionReceipt, message?: string);
|
|
147
|
+
}
|
|
148
|
+
export declare class MempoolError extends TransactionError {
|
|
149
|
+
constructor(receipt: TransactionReceipt, message?: string);
|
|
150
|
+
}
|
|
151
|
+
export declare class TimeoutError extends TransactionError {
|
|
152
|
+
readonly msecs: number;
|
|
153
|
+
constructor(msecs: number, receipt: TransactionReceipt, message?: string);
|
|
154
|
+
}
|
|
155
|
+
export declare class TransmissionError extends Error {
|
|
156
|
+
readonly error?: any;
|
|
157
|
+
readonly inFlight: Transmission;
|
|
158
|
+
constructor(inFlight: Transmission, error?: any);
|
|
159
|
+
}
|
|
160
|
+
export {};
|
|
161
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TransmissionError = exports.TimeoutError = exports.MempoolError = exports.RecoverableSignature = exports.Signature = exports.PublicKeyHash = exports.PublicKey = exports.UtxoSelectionStrategy = exports.TransactionPriority = exports.Coins = void 0;
|
|
4
|
+
const secp256k1 = require('secp256k1');
|
|
5
|
+
const bech32_1 = require("bech32");
|
|
6
|
+
const helpers_1 = require("../../bin/helpers");
|
|
7
|
+
const utils_1 = require("./utils");
|
|
8
|
+
class Coins {
|
|
9
|
+
static fromBalance(balance) {
|
|
10
|
+
return Coins.fromPedros(balance.locked
|
|
11
|
+
+ balance.staked
|
|
12
|
+
+ balance.unlocked);
|
|
13
|
+
}
|
|
14
|
+
static fromNanowits(nanowits) {
|
|
15
|
+
return new Coins(nanowits);
|
|
16
|
+
}
|
|
17
|
+
static fromPedros(pedros) {
|
|
18
|
+
return new Coins(pedros);
|
|
19
|
+
}
|
|
20
|
+
static fromWits(wits) {
|
|
21
|
+
if (wits > Number.MAX_SAFE_INTEGER) {
|
|
22
|
+
throw new TypeError(`${this.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`);
|
|
23
|
+
}
|
|
24
|
+
return new Coins(BigInt(Math.floor(wits)) * 10n ** 9n
|
|
25
|
+
+ BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000)));
|
|
26
|
+
}
|
|
27
|
+
static zero() {
|
|
28
|
+
return new Coins(0n);
|
|
29
|
+
}
|
|
30
|
+
constructor(pedros) {
|
|
31
|
+
this.coins = pedros;
|
|
32
|
+
}
|
|
33
|
+
get pedros() {
|
|
34
|
+
return this.coins;
|
|
35
|
+
}
|
|
36
|
+
get nanowits() {
|
|
37
|
+
return this.coins;
|
|
38
|
+
}
|
|
39
|
+
get wits() {
|
|
40
|
+
const quotient = BigInt(this.coins) / 1000000000n;
|
|
41
|
+
if (Number(quotient) > Number.MAX_SAFE_INTEGER) {
|
|
42
|
+
throw new TypeError(`${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`);
|
|
43
|
+
}
|
|
44
|
+
const rest = Number(BigInt(this.coins) - quotient * 1000000000n) / 1000000000;
|
|
45
|
+
// console.log("wits() =>", this.coins.toString(), quotient.toString(), rest, Number(quotient) + rest)
|
|
46
|
+
return Number(quotient) + rest;
|
|
47
|
+
}
|
|
48
|
+
toString(decimals = 9) {
|
|
49
|
+
return (0, helpers_1.whole_wits)(this.coins, decimals);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
exports.Coins = Coins;
|
|
53
|
+
var TransactionPriority;
|
|
54
|
+
(function (TransactionPriority) {
|
|
55
|
+
TransactionPriority["Stinky"] = "stinky";
|
|
56
|
+
TransactionPriority["Low"] = "low";
|
|
57
|
+
TransactionPriority["Medium"] = "medium";
|
|
58
|
+
TransactionPriority["High"] = "high";
|
|
59
|
+
TransactionPriority["Opulent"] = "opulent";
|
|
60
|
+
})(TransactionPriority || (exports.TransactionPriority = TransactionPriority = {}));
|
|
61
|
+
var UtxoSelectionStrategy;
|
|
62
|
+
(function (UtxoSelectionStrategy) {
|
|
63
|
+
UtxoSelectionStrategy["BigFirst"] = "big-first";
|
|
64
|
+
UtxoSelectionStrategy["Random"] = "random";
|
|
65
|
+
UtxoSelectionStrategy["SlimFit"] = "slim-fit";
|
|
66
|
+
UtxoSelectionStrategy["SmallFirst"] = "small-first";
|
|
67
|
+
})(UtxoSelectionStrategy || (exports.UtxoSelectionStrategy = UtxoSelectionStrategy = {}));
|
|
68
|
+
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
69
|
+
/// EXPORTED CLASSES
|
|
70
|
+
/// ===================================================================================================================
|
|
71
|
+
class PublicKey {
|
|
72
|
+
static fromProtobuf(protobuf) {
|
|
73
|
+
return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes));
|
|
74
|
+
}
|
|
75
|
+
static fromUint8Array(uint8Array) {
|
|
76
|
+
return new PublicKey(uint8Array[0], uint8Array.slice(1));
|
|
77
|
+
}
|
|
78
|
+
static recoverFrom(recoverable, msg) {
|
|
79
|
+
let bytes;
|
|
80
|
+
if ((0, helpers_1.isHexString)(recoverable)) {
|
|
81
|
+
bytes = (0, helpers_1.fromHexString)(recoverable);
|
|
82
|
+
}
|
|
83
|
+
else if (recoverable instanceof Buffer) {
|
|
84
|
+
bytes = Uint8Array.from(recoverable.buffer);
|
|
85
|
+
}
|
|
86
|
+
else if (recoverable instanceof Uint8Array) {
|
|
87
|
+
bytes = recoverable;
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`);
|
|
91
|
+
}
|
|
92
|
+
if (bytes.length !== 65) {
|
|
93
|
+
throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${(0, helpers_1.toHexString)(bytes)}`);
|
|
94
|
+
}
|
|
95
|
+
const [recoveryId, signature] = [bytes[0], bytes.slice(1)];
|
|
96
|
+
return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg));
|
|
97
|
+
}
|
|
98
|
+
constructor(compressed, bytes) {
|
|
99
|
+
this.compressed = compressed;
|
|
100
|
+
this.bytes = bytes;
|
|
101
|
+
}
|
|
102
|
+
equals(pubKey) {
|
|
103
|
+
return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes);
|
|
104
|
+
}
|
|
105
|
+
hash() {
|
|
106
|
+
return PublicKeyHash.fromPublicKey(this);
|
|
107
|
+
}
|
|
108
|
+
toString() {
|
|
109
|
+
return (0, helpers_1.toHexString)([this.compressed, ...this.bytes]);
|
|
110
|
+
}
|
|
111
|
+
toUint8Array() {
|
|
112
|
+
return Uint8Array.from([this.compressed, ...this.bytes]);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
exports.PublicKey = PublicKey;
|
|
116
|
+
;
|
|
117
|
+
/// ===================================================================================================================
|
|
118
|
+
class PublicKeyHash {
|
|
119
|
+
static fromHash(hash) {
|
|
120
|
+
return new PublicKeyHash(bech32_1.bech32.toWords(hash));
|
|
121
|
+
}
|
|
122
|
+
static fromHexString(hash) {
|
|
123
|
+
return PublicKeyHash.fromHash((0, helpers_1.fromHexString)(hash));
|
|
124
|
+
}
|
|
125
|
+
static fromPublicKey(pk) {
|
|
126
|
+
return PublicKeyHash.fromHash((0, utils_1.sha256)(Buffer.from([pk.compressed, ...pk.bytes])).subarray(0, 20));
|
|
127
|
+
}
|
|
128
|
+
static fromBech32(pkh) {
|
|
129
|
+
try {
|
|
130
|
+
pkh = pkh.toLowerCase();
|
|
131
|
+
if (pkh.startsWith('wit')) {
|
|
132
|
+
return new PublicKeyHash(bech32_1.bech32.decode(pkh, 66).words);
|
|
133
|
+
}
|
|
134
|
+
else if (pkh.startsWith('twit')) {
|
|
135
|
+
return new PublicKeyHash(bech32_1.bech32.decode(pkh, 67).words);
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
catch {
|
|
142
|
+
throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
constructor(words) {
|
|
146
|
+
this.words = words;
|
|
147
|
+
}
|
|
148
|
+
toBech32(network = "mainnet") {
|
|
149
|
+
return network === "mainnet" ? bech32_1.bech32.encode('wit', this.words, 66) : bech32_1.bech32.encode('twit', this.words, 67);
|
|
150
|
+
}
|
|
151
|
+
toBytes20() {
|
|
152
|
+
return Uint8Array.from(bech32_1.bech32.fromWords(this.words).slice(0, 20));
|
|
153
|
+
}
|
|
154
|
+
toBytes32() {
|
|
155
|
+
return Uint8Array.from([
|
|
156
|
+
...bech32_1.bech32.fromWords(this.words).slice(0, 20),
|
|
157
|
+
...new Array(12).fill(0),
|
|
158
|
+
]);
|
|
159
|
+
}
|
|
160
|
+
toHexString() {
|
|
161
|
+
return (0, helpers_1.toHexString)(this.toBytes20());
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
exports.PublicKeyHash = PublicKeyHash;
|
|
165
|
+
/// ===================================================================================================================
|
|
166
|
+
class Signature {
|
|
167
|
+
static fromHexString(hex) {
|
|
168
|
+
return new Signature((0, helpers_1.fromHexString)(hex));
|
|
169
|
+
}
|
|
170
|
+
constructor(bytes) {
|
|
171
|
+
this.bytes = bytes;
|
|
172
|
+
}
|
|
173
|
+
toHexString() {
|
|
174
|
+
return (0, helpers_1.toHexString)(this.bytes);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
exports.Signature = Signature;
|
|
178
|
+
/// ===================================================================================================================
|
|
179
|
+
class RecoverableSignature extends Signature {
|
|
180
|
+
static from(recoverable, msg) {
|
|
181
|
+
let bytes;
|
|
182
|
+
if ((0, helpers_1.isHexString)(recoverable)) {
|
|
183
|
+
bytes = (0, helpers_1.fromHexString)(recoverable).slice(1);
|
|
184
|
+
}
|
|
185
|
+
else if (recoverable instanceof Buffer) {
|
|
186
|
+
bytes = Uint8Array.from(recoverable.buffer).slice(1);
|
|
187
|
+
}
|
|
188
|
+
else if (recoverable instanceof Uint8Array) {
|
|
189
|
+
bytes = recoverable.slice(1);
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`);
|
|
193
|
+
}
|
|
194
|
+
if (bytes.length !== 64) {
|
|
195
|
+
throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${(0, helpers_1.toHexString)(bytes)}`);
|
|
196
|
+
}
|
|
197
|
+
return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg);
|
|
198
|
+
}
|
|
199
|
+
static fromKeyedSignature(ks, msg) {
|
|
200
|
+
return new RecoverableSignature(PublicKey.fromProtobuf(ks.public_key), secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)), msg);
|
|
201
|
+
}
|
|
202
|
+
constructor(pubKey, bytes, msg) {
|
|
203
|
+
super(bytes);
|
|
204
|
+
const pubKeyRaw = pubKey.toUint8Array();
|
|
205
|
+
let recoveryId;
|
|
206
|
+
for (recoveryId = 0; recoveryId < 4; recoveryId++) {
|
|
207
|
+
let recovered;
|
|
208
|
+
try {
|
|
209
|
+
recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg);
|
|
210
|
+
if (matchingUint8Arrays(recovered, pubKeyRaw))
|
|
211
|
+
break;
|
|
212
|
+
}
|
|
213
|
+
catch { }
|
|
214
|
+
}
|
|
215
|
+
this.message = msg;
|
|
216
|
+
this.pubKey = pubKey;
|
|
217
|
+
this.recoveryId = recoveryId;
|
|
218
|
+
}
|
|
219
|
+
toHexString() {
|
|
220
|
+
return (0, helpers_1.toHexString)([this.recoveryId, ...this.bytes]);
|
|
221
|
+
}
|
|
222
|
+
toKeyedSignature() {
|
|
223
|
+
return {
|
|
224
|
+
signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) } },
|
|
225
|
+
public_key: {
|
|
226
|
+
bytes: Array.from(this.pubKey.bytes),
|
|
227
|
+
compressed: this.pubKey.compressed,
|
|
228
|
+
}
|
|
229
|
+
};
|
|
230
|
+
}
|
|
231
|
+
toProtobuf() {
|
|
232
|
+
return {
|
|
233
|
+
signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) } },
|
|
234
|
+
publicKey: { publicKey: Array.from([this.pubKey.compressed, ...this.pubKey.bytes]) },
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
exports.RecoverableSignature = RecoverableSignature;
|
|
239
|
+
/// ===================================================================================================================
|
|
240
|
+
class TransactionError extends Error {
|
|
241
|
+
constructor(receipt, message) {
|
|
242
|
+
super(message);
|
|
243
|
+
this.receipt = receipt;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
class MempoolError extends TransactionError {
|
|
247
|
+
constructor(receipt, message) {
|
|
248
|
+
super(receipt, message);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
exports.MempoolError = MempoolError;
|
|
252
|
+
class TimeoutError extends TransactionError {
|
|
253
|
+
constructor(msecs, receipt, message) {
|
|
254
|
+
super(receipt, message);
|
|
255
|
+
this.msecs = msecs;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
exports.TimeoutError = TimeoutError;
|
|
259
|
+
class TransmissionError extends Error {
|
|
260
|
+
constructor(inFlight, error) {
|
|
261
|
+
super(JSON.stringify(error));
|
|
262
|
+
delete error?.stack;
|
|
263
|
+
this.error = error;
|
|
264
|
+
this.inFlight = inFlight;
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
exports.TransmissionError = TransmissionError;
|
|
268
|
+
/// -------------------------------------------------------------------------------------------------------------------
|
|
269
|
+
/// --- Internal functions
|
|
270
|
+
function matchingUint8Arrays(a, b) {
|
|
271
|
+
return a.length === b.length && a.every((value, index) => value === b[index]);
|
|
272
|
+
}
|
|
273
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require('secp256k1')\r\nimport { bech32 } from 'bech32'\r\nimport { Balance, Epoch, Hash, HexString, UtxoMetadata } from \"../types\"\r\n\r\nimport { fromHexString, isHexString, toHexString, whole_wits } from \"../../bin/helpers\"\r\nimport { sha256 } from \"./utils\"\r\n\r\nexport class Coins {\r\n    protected coins: bigint;\r\n    public static fromBalance(balance: Balance): Coins {\r\n        return Coins.fromPedros(\r\n            balance.locked\r\n                + balance.staked\r\n                + balance.unlocked\r\n        )\r\n    }\r\n    public static fromNanowits(nanowits: bigint): Coins {\r\n        return new Coins(nanowits)\r\n    }\r\n    public static fromPedros(pedros: bigint): Coins {\r\n        return new Coins(pedros)\r\n    }\r\n    public static fromWits(wits: number): Coins {\r\n        if (wits > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        return new Coins(\r\n            BigInt(Math.floor(wits)) * 10n ** 9n\r\n                + BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000))\r\n        )\r\n    }\r\n    public static zero(): Coins {\r\n        return new Coins(0n)\r\n    }\r\n    constructor (pedros: bigint) {\r\n        this.coins = pedros\r\n    }\r\n    public get pedros(): bigint {\r\n        return this.coins\r\n    }\r\n    public get nanowits(): bigint {\r\n        return this.coins\r\n    }\r\n    public get wits(): number {\r\n        const quotient = BigInt(this.coins) / 1000000000n\r\n        if (Number(quotient) > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        const rest = Number(BigInt(this.coins) - quotient * 1000000000n) / 1000000000\r\n        // console.log(\"wits() =>\", this.coins.toString(), quotient.toString(), rest, Number(quotient) + rest)\r\n        return Number(quotient) + rest\r\n    }\r\n    public toString(decimals = 9): string {\r\n        return whole_wits(this.coins, decimals)\r\n    }\r\n}\r\n\r\nexport type KeyPath = Array<number>\r\n\r\nexport type KeyedSignature = {\r\n    signature: { Secp256k1: { der: Array<number> }},\r\n    public_key: {\r\n        bytes: Array<number>;\r\n        compressed: number,\r\n    },\r\n};\r\n\r\nexport type PublicKeyHashString = HexString\r\n\r\ninterface Key {\r\n    bytes: Uint8Array;\r\n}\r\n\r\nexport interface PrivateKey extends Key {\r\n    type: \"private\";\r\n}\r\n\r\nexport interface PublicKey extends Key {\r\n    type: \"public\";\r\n}\r\n\r\nexport type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any\r\n\r\nexport type TransactionParams = {\r\n    deadline?: Epoch,\r\n    fees?: TransactionPriority | Coins,\r\n}\r\n\r\nexport enum TransactionPriority {\r\n    Stinky = \"stinky\",\r\n    Low = \"low\",\r\n    Medium = \"medium\",\r\n    High = \"high\",\r\n    Opulent = \"opulent\",\r\n}\r\n\r\nexport type TransactionReceipt = {\r\n    authorization?: HexString;\r\n    blockEpoch?: Epoch,\r\n    blockHash?: Hash,\r\n    blockMiner?: PublicKeyHashString,\r\n    blockTimestamp?: number,\r\n    confirmations?: number;\r\n    change?: Coins;\r\n    droHash?: Hash;\r\n    error?: Error,\r\n    fees: Coins;\r\n    from?: Array<PublicKeyHashString> | PublicKeyHashString;\r\n    hash: Hash;\r\n    outputLock?: number;\r\n    radArgs?: any;\r\n    radHash?: HexString;\r\n    recipients?: Array<[PublicKeyHashString, Coins]>;\r\n    status: string;\r\n    timestamp: number;\r\n    type: string;\r\n    tx?: any;\r\n    validator?: PublicKeyHashString;\r\n    value?: Coins;\r\n    weight: number;\r\n    withdrawer?: PublicKeyHashString;\r\n    witnesses?: number | Record<PublicKeyHashString, Coins>;\r\n}\r\n\r\nexport type TransactionStatus = \"signed\" | \"pending\" | \"relayed\" | \"removed\" | \"mined\" | \"confirmed\" | \"finalized\";\r\n\r\nexport type Transmission = {\r\n    bytecode?: Uint8Array,\r\n    hash?: Hash;\r\n    message: any;\r\n}\r\n\r\nexport type Utxo = UtxoMetadata & { signer: PublicKeyHashString }\r\n\r\nexport type UtxoCacheInfo = {\r\n    // total amount of expendable funds with currently cached UTXOs\r\n    expendable: bigint, \r\n    // number of cached UTXOs\r\n    size: number, \r\n    // earliest of all timelocks in the caché\r\n    timelock: number,\r\n}\r\n\r\nexport type UtxoPointer = {\r\n    // transaction identifier\r\n    transaction_id: Hash;\r\n    // output index within referred transaction\r\n    output_index: number;\r\n};\r\n\r\nexport enum UtxoSelectionStrategy {\r\n    BigFirst = \"big-first\",\r\n    Random = \"random\",\r\n    SlimFit = \"slim-fit\",\r\n    SmallFirst = \"small-first\",\r\n}\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n/// EXPORTED CLASSES \r\n\r\n/// ===================================================================================================================\r\nexport class PublicKey implements Key {\r\n    \r\n    public readonly compressed: number;\r\n    public readonly bytes: Uint8Array;\r\n\r\n    static fromProtobuf(protobuf: { compressed: number, bytes: Array<number> }): PublicKey {\r\n        return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes))\r\n    }\r\n\r\n    static fromUint8Array(uint8Array: Uint8Array): PublicKey {\r\n        return new PublicKey(\r\n            uint8Array[0],\r\n            uint8Array.slice(1),\r\n        );\r\n    }\r\n\r\n    static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable\r\n        } else {\r\n            throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 65) {\r\n            throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        const [ recoveryId, signature ] = [ bytes[0], bytes.slice(1) ]\r\n        return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg))\r\n    }\r\n\r\n    constructor(compressed: number, bytes: Uint8Array) {\r\n        this.compressed = compressed\r\n        this.bytes = bytes\r\n    }\r\n\r\n    public equals(pubKey: PublicKey): boolean {\r\n        return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes)\r\n    }\r\n\r\n    public hash(): PublicKeyHash {\r\n        return PublicKeyHash.fromPublicKey(this)\r\n    }\r\n\r\n    public toString(): string {\r\n        return toHexString([this.compressed, ...this.bytes])\r\n    }\r\n\r\n    public toUint8Array(): Uint8Array {\r\n        return Uint8Array.from([this.compressed, ...this.bytes])\r\n    }\r\n};\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class PublicKeyHash {\r\n\r\n    static fromHash(hash: Uint8Array): PublicKeyHash {\r\n        return new PublicKeyHash(bech32.toWords(hash));\r\n    }\r\n\r\n    static fromHexString(hash: HexString): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(fromHexString(hash))\r\n    }\r\n    \r\n    static fromPublicKey(pk: PublicKey): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(\r\n            sha256(\r\n                Buffer.from([pk.compressed, ...pk.bytes])\r\n            ).subarray(0, 20)\r\n        );\r\n    }\r\n    \r\n    static fromBech32(pkh: string): PublicKeyHash {\r\n        try {\r\n            pkh = pkh.toLowerCase()\r\n            if (pkh.startsWith('wit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 66).words)\r\n            } else if (pkh.startsWith('twit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 67).words)\r\n            } else {\r\n                throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n            }\r\n        } catch {\r\n            throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n        }\r\n    }\r\n\r\n    protected words: number[];\r\n    \r\n    constructor(words: number[]) {\r\n        this.words = words\r\n    }\r\n\r\n    public toBech32(network = \"mainnet\"): string {\r\n        return network === \"mainnet\" ? bech32.encode('wit', this.words, 66) : bech32.encode('twit', this.words, 67);\r\n    }\r\n\r\n    public toBytes20(): Uint8Array {\r\n        return Uint8Array.from(bech32.fromWords(this.words).slice(0, 20))\r\n    }\r\n\r\n    public toBytes32(): Uint8Array {\r\n        return Uint8Array.from([\r\n            ...bech32.fromWords(this.words).slice(0, 20),\r\n            ...new Array(12).fill(0),\r\n        ]);\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString(this.toBytes20())\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class Signature {\r\n\r\n    static fromHexString(hex: string): Signature {\r\n        return new Signature(fromHexString(hex))\r\n    }\r\n\r\n    public readonly bytes: Uint8Array;\r\n\r\n    constructor (bytes: Uint8Array) {\r\n        this.bytes = bytes\r\n    }\r\n    \r\n    public toHexString(): string {\r\n        return toHexString(this.bytes)\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class RecoverableSignature extends Signature {\r\n\r\n    static from(recoverable: any, msg: Uint8Array): RecoverableSignature {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable).slice(1)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer).slice(1)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable.slice(1)\r\n        } else {\r\n            throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 64) {\r\n            throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg)\r\n    }\r\n\r\n    static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature {\r\n        return new RecoverableSignature(\r\n            PublicKey.fromProtobuf(ks.public_key),\r\n            secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)),\r\n            msg\r\n        )   \r\n    }\r\n\r\n    public readonly message: Uint8Array\r\n    public readonly pubKey: PublicKey\r\n    public readonly recoveryId: number\r\n    \r\n    constructor (pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array) {\r\n        super(bytes)\r\n        const pubKeyRaw = pubKey.toUint8Array()\r\n        let recoveryId: number;\r\n        for (recoveryId = 0; recoveryId < 4; recoveryId ++) {\r\n            let recovered \r\n            try {\r\n              recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg)\r\n              if (matchingUint8Arrays(recovered, pubKeyRaw)) break;\r\n            } catch {}\r\n        }\r\n        this.message = msg\r\n        this.pubKey = pubKey\r\n        this.recoveryId = recoveryId\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString([this.recoveryId, ...this.bytes])\r\n    }\r\n\r\n    public toKeyedSignature(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            public_key: {\r\n                bytes: Array.from(this.pubKey.bytes),\r\n                compressed: this.pubKey.compressed,\r\n            }\r\n        }\r\n    }\r\n\r\n    public toProtobuf(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            publicKey: { publicKey: Array.from([ this.pubKey.compressed, ...this.pubKey.bytes ]) },\r\n        }\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\n\r\nabstract class TransactionError extends Error {\r\n    readonly receipt: TransactionReceipt\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(message)\r\n        this.receipt = receipt\r\n    }\r\n}\r\nexport class MempoolError extends TransactionError {\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n    }\r\n}\r\n\r\nexport class TimeoutError extends TransactionError {\r\n    readonly msecs: number;\r\n    constructor (msecs: number, receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n        this.msecs = msecs\r\n    }\r\n}\r\n    \r\n\r\nexport class TransmissionError extends Error {\r\n    readonly error?: any;\r\n    readonly inFlight: Transmission;\r\n    constructor(inFlight: Transmission, error?: any) {\r\n        super(JSON.stringify(error))\r\n        delete error?.stack\r\n        this.error = error\r\n        this.inFlight = inFlight\r\n    }\r\n}\r\n\r\n\r\n/// -------------------------------------------------------------------------------------------------------------------\r\n/// --- Internal functions \r\n\r\nfunction matchingUint8Arrays(a: Uint8Array, b: Uint8Array) {\r\n    return a.length === b.length && a.every((value, index) => value === b[index])\r\n}\r\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Balance } from '../types';
|
|
2
|
+
import { Coins, Utxo, UtxoSelectionStrategy } from './types';
|
|
3
|
+
export { bech32 } from 'bech32';
|
|
4
|
+
export { PrivateKey, PublicKey, PublicKeyHash, KeyedSignature, RecoverableSignature, Signature } from "./types";
|
|
5
|
+
export declare const BigMath: {
|
|
6
|
+
max(value: bigint, ...values: bigint[]): bigint;
|
|
7
|
+
};
|
|
8
|
+
export declare function decipherXprv(slip32: string, passwd: string): string;
|
|
9
|
+
export declare const parseXprv: (slip32: string) => {
|
|
10
|
+
chainCode: Uint8Array;
|
|
11
|
+
keyPath: Array<number>;
|
|
12
|
+
privateKey: Uint8Array;
|
|
13
|
+
};
|
|
14
|
+
export declare function selectUtxos(specs: {
|
|
15
|
+
utxos: Array<Utxo>;
|
|
16
|
+
value?: Coins;
|
|
17
|
+
strategy?: UtxoSelectionStrategy;
|
|
18
|
+
}): Array<Utxo>;
|
|
19
|
+
export declare function sha256(buffer: any): Buffer<ArrayBufferLike>;
|
|
20
|
+
export declare function totalCoins(balance: Balance): Coins;
|
|
21
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAClC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAE5D,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAE/B,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAE/G,eAAO,MAAM,OAAO;eACL,MAAM,aAAa,MAAM,EAAE,GAAG,MAAM;CAKlD,CAAA;AAqBD,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAcnE;AAED,eAAO,MAAM,SAAS,WAAY,MAAM,KAAG;IACvC,SAAS,EAAE,UAAU,CAAC;IACtB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAyD1B,CAAC;AAEF,wBAAgB,WAAW,CAAC,KAAK,EAAE;IAC/B,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,QAAQ,CAAC,EAAE,qBAAqB,CAAC;CACpC,GAAG,KAAK,CAAC,IAAI,CAAC,CA6Cd;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,GAAG,2BAIjC;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK,CAMlD"}
|