quantumcoin 6.14.2 → 6.14.4
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/README.md +12 -22
- package/dist/README.md +1 -1
- package/lib.commonjs/_version.js +1 -1
- package/lib.commonjs/crypto/signing-key.d.ts +1 -1
- package/lib.commonjs/crypto/signing-key.d.ts.map +1 -1
- package/lib.commonjs/crypto/signing-key.js +14 -8
- package/lib.commonjs/crypto/signing-key.js.map +1 -1
- package/lib.commonjs/quantumcoin.d.ts +2 -0
- package/lib.commonjs/quantumcoin.d.ts.map +1 -1
- package/lib.commonjs/quantumcoin.js +11 -5
- package/lib.commonjs/quantumcoin.js.map +1 -1
- package/lib.commonjs/transaction/address.d.ts.map +1 -1
- package/lib.commonjs/transaction/address.js +8 -3
- package/lib.commonjs/transaction/address.js.map +1 -1
- package/lib.commonjs/wallet/json-keystore.d.ts.map +1 -1
- package/lib.commonjs/wallet/json-keystore.js +7 -7
- package/lib.commonjs/wallet/json-keystore.js.map +1 -1
- package/lib.commonjs/wallet/wallet.d.ts.map +1 -1
- package/lib.commonjs/wallet/wallet.js +2 -2
- package/lib.commonjs/wallet/wallet.js.map +1 -1
- package/lib.esm/_version.js +1 -1
- package/lib.esm/crypto/signing-key.d.ts +1 -1
- package/lib.esm/crypto/signing-key.d.ts.map +1 -1
- package/lib.esm/crypto/signing-key.js +15 -8
- package/lib.esm/crypto/signing-key.js.map +1 -1
- package/lib.esm/quantumcoin.d.ts +2 -0
- package/lib.esm/quantumcoin.d.ts.map +1 -1
- package/lib.esm/quantumcoin.js +6 -0
- package/lib.esm/quantumcoin.js.map +1 -1
- package/lib.esm/transaction/address.d.ts.map +1 -1
- package/lib.esm/transaction/address.js +8 -2
- package/lib.esm/transaction/address.js.map +1 -1
- package/lib.esm/wallet/json-keystore.d.ts.map +1 -1
- package/lib.esm/wallet/json-keystore.js +11 -5
- package/lib.esm/wallet/json-keystore.js.map +1 -1
- package/lib.esm/wallet/wallet.d.ts.map +1 -1
- package/lib.esm/wallet/wallet.js +3 -1
- package/lib.esm/wallet/wallet.js.map +1 -1
- package/package.json +6 -5
- package/src.ts/_version.ts +1 -1
- package/src.ts/crypto/signing-key.ts +14 -9
- package/src.ts/quantumcoin.ts +10 -2
- package/src.ts/transaction/address.ts +7 -3
- package/src.ts/wallet/json-keystore.ts +8 -6
- package/src.ts/wallet/wallet.ts +2 -3
- package/dist/quantumcoin.js +0 -21137
- package/dist/quantumcoin.js.map +0 -1
- package/dist/quantumcoin.min.js +0 -1
- package/dist/quantumcoin.min.js'.gz' +0 -0
- package/dist/quantumcoin.umd.js +0 -21316
- package/dist/quantumcoin.umd.js.map +0 -1
- package/dist/quantumcoin.umd.min.js +0 -1
- package/dist/quantumcoin.umd.min.js'.gz' +0 -0
- package/dist/wordlists-extra.js +0 -1500
- package/dist/wordlists-extra.js.map +0 -1
- package/dist/wordlists-extra.min.js +0 -1
- package/dist/wordlists-extra.min.js'.gz' +0 -0
- package/lib.commonjs/providers/provider-alchemy.d.ts +0 -50
- package/lib.commonjs/providers/provider-alchemy.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-alchemy.js +0 -151
- package/lib.commonjs/providers/provider-alchemy.js.map +0 -1
- package/lib.commonjs/providers/provider-ankr.d.ts +0 -61
- package/lib.commonjs/providers/provider-ankr.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-ankr.js +0 -137
- package/lib.commonjs/providers/provider-ankr.js.map +0 -1
- package/lib.commonjs/providers/provider-blockscout.d.ts +0 -59
- package/lib.commonjs/providers/provider-blockscout.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-blockscout.js +0 -145
- package/lib.commonjs/providers/provider-blockscout.js.map +0 -1
- package/lib.commonjs/providers/provider-chainstack.d.ts +0 -46
- package/lib.commonjs/providers/provider-chainstack.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-chainstack.js +0 -102
- package/lib.commonjs/providers/provider-chainstack.js.map +0 -1
- package/lib.commonjs/providers/provider-cloudflare.d.ts +0 -14
- package/lib.commonjs/providers/provider-cloudflare.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-cloudflare.js +0 -26
- package/lib.commonjs/providers/provider-cloudflare.js.map +0 -1
- package/lib.commonjs/providers/provider-etherscan.d.ts +0 -147
- package/lib.commonjs/providers/provider-etherscan.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-etherscan.js +0 -587
- package/lib.commonjs/providers/provider-etherscan.js.map +0 -1
- package/lib.commonjs/providers/provider-infura.d.ts +0 -101
- package/lib.commonjs/providers/provider-infura.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-infura.js +0 -206
- package/lib.commonjs/providers/provider-infura.js.map +0 -1
- package/lib.commonjs/providers/provider-pocket.d.ts +0 -54
- package/lib.commonjs/providers/provider-pocket.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-pocket.js +0 -109
- package/lib.commonjs/providers/provider-pocket.js.map +0 -1
- package/lib.commonjs/providers/provider-quicknode.d.ts +0 -59
- package/lib.commonjs/providers/provider-quicknode.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-quicknode.js +0 -163
- package/lib.commonjs/providers/provider-quicknode.js.map +0 -1
- package/lib.commonjs/wallet/hdwallet.d.ts +0 -248
- package/lib.commonjs/wallet/hdwallet.d.ts.map +0 -1
- package/lib.commonjs/wallet/hdwallet.js +0 -505
- package/lib.commonjs/wallet/hdwallet.js.map +0 -1
- package/lib.commonjs/wallet/json-crowdsale.d.ts +0 -27
- package/lib.commonjs/wallet/json-crowdsale.d.ts.map +0 -1
- package/lib.commonjs/wallet/json-crowdsale.js +0 -60
- package/lib.commonjs/wallet/json-crowdsale.js.map +0 -1
- package/lib.commonjs/wallet/mnemonic.d.ts +0 -65
- package/lib.commonjs/wallet/mnemonic.d.ts.map +0 -1
- package/lib.commonjs/wallet/mnemonic.js +0 -169
- package/lib.commonjs/wallet/mnemonic.js.map +0 -1
- package/lib.commonjs/wallet/seedwallet.d.ts +0 -4
- package/lib.commonjs/wallet/seedwallet.d.ts.map +0 -1
- package/lib.commonjs/wallet/seedwallet.js +0 -8
- package/lib.commonjs/wallet/seedwallet.js.map +0 -1
- package/lib.esm/providers/provider-alchemy.d.ts +0 -50
- package/lib.esm/providers/provider-alchemy.d.ts.map +0 -1
- package/lib.esm/providers/provider-alchemy.js +0 -147
- package/lib.esm/providers/provider-alchemy.js.map +0 -1
- package/lib.esm/providers/provider-ankr.d.ts +0 -61
- package/lib.esm/providers/provider-ankr.d.ts.map +0 -1
- package/lib.esm/providers/provider-ankr.js +0 -133
- package/lib.esm/providers/provider-ankr.js.map +0 -1
- package/lib.esm/providers/provider-blockscout.d.ts +0 -59
- package/lib.esm/providers/provider-blockscout.d.ts.map +0 -1
- package/lib.esm/providers/provider-blockscout.js +0 -141
- package/lib.esm/providers/provider-blockscout.js.map +0 -1
- package/lib.esm/providers/provider-chainstack.d.ts +0 -46
- package/lib.esm/providers/provider-chainstack.d.ts.map +0 -1
- package/lib.esm/providers/provider-chainstack.js +0 -98
- package/lib.esm/providers/provider-chainstack.js.map +0 -1
- package/lib.esm/providers/provider-cloudflare.d.ts +0 -14
- package/lib.esm/providers/provider-cloudflare.d.ts.map +0 -1
- package/lib.esm/providers/provider-cloudflare.js +0 -22
- package/lib.esm/providers/provider-cloudflare.js.map +0 -1
- package/lib.esm/providers/provider-etherscan.d.ts +0 -147
- package/lib.esm/providers/provider-etherscan.d.ts.map +0 -1
- package/lib.esm/providers/provider-etherscan.js +0 -584
- package/lib.esm/providers/provider-etherscan.js.map +0 -1
- package/lib.esm/providers/provider-infura.d.ts +0 -101
- package/lib.esm/providers/provider-infura.d.ts.map +0 -1
- package/lib.esm/providers/provider-infura.js +0 -201
- package/lib.esm/providers/provider-infura.js.map +0 -1
- package/lib.esm/providers/provider-pocket.d.ts +0 -54
- package/lib.esm/providers/provider-pocket.d.ts.map +0 -1
- package/lib.esm/providers/provider-pocket.js +0 -105
- package/lib.esm/providers/provider-pocket.js.map +0 -1
- package/lib.esm/providers/provider-quicknode.d.ts +0 -59
- package/lib.esm/providers/provider-quicknode.d.ts.map +0 -1
- package/lib.esm/providers/provider-quicknode.js +0 -159
- package/lib.esm/providers/provider-quicknode.js.map +0 -1
- package/lib.esm/wallet/hdwallet.d.ts +0 -248
- package/lib.esm/wallet/hdwallet.d.ts.map +0 -1
- package/lib.esm/wallet/hdwallet.js +0 -498
- package/lib.esm/wallet/hdwallet.js.map +0 -1
- package/lib.esm/wallet/json-crowdsale.d.ts +0 -27
- package/lib.esm/wallet/json-crowdsale.d.ts.map +0 -1
- package/lib.esm/wallet/json-crowdsale.js +0 -55
- package/lib.esm/wallet/json-crowdsale.js.map +0 -1
- package/lib.esm/wallet/mnemonic.d.ts +0 -65
- package/lib.esm/wallet/mnemonic.d.ts.map +0 -1
- package/lib.esm/wallet/mnemonic.js +0 -165
- package/lib.esm/wallet/mnemonic.js.map +0 -1
- package/lib.esm/wallet/seedwallet.d.ts +0 -4
- package/lib.esm/wallet/seedwallet.d.ts.map +0 -1
- package/lib.esm/wallet/seedwallet.js +0 -4
- package/lib.esm/wallet/seedwallet.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"address.js","sourceRoot":"","sources":["../../src.ts/transaction/address.ts"],"names":[],"mappings":"AAAA,mDAAmD;AACnD,aAAa;AACb,OAAO,EAAC,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAG/C,OAAO,EAAY,QAAQ,EAAC,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"address.js","sourceRoot":"","sources":["../../src.ts/transaction/address.ts"],"names":[],"mappings":"AAAA,mDAAmD;AACnD,aAAa;AACb,OAAO,EAAC,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAG/C,OAAO,EAAY,QAAQ,EAAC,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAC,oBAAoB,EAAC,MAAM,qBAAqB,CAAC;AAEzD;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAAC,GAAwB;IACnD,IAAI,MAAc,CAAC;IACnB,IAAI,OAAM,CAAC,GAAG,CAAC,KAAK,QAAQ,EAAE;QAC1B,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACtB,MAAM,GAAG,UAAU,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;SAC7C;aAAM;YACH,MAAM,GAAG,UAAU,CAAC,gBAAgB,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;SACpD;KACJ;SAAM;QACH,MAAM,GAAG,GAAG,CAAC,SAAS,CAAC;KAC1B;IACD,IAAI,WAAW,GAAQ,QAAQ,CAAC,MAAM,CAAC,CAAC;IACxC,OAAO,oBAAoB,CAAC,WAAW,CAAC,CAAC;AAC7C,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,cAAc,CAAC,MAAiB,EAAE,SAAwB;IACtE,OAAO,cAAc,CAAC,UAAU,CAAC,gBAAgB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;AAC1E,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"json-keystore.d.ts","sourceRoot":"","sources":["../../src.ts/wallet/json-keystore.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;
|
|
1
|
+
{"version":3,"file":"json-keystore.d.ts","sourceRoot":"","sources":["../../src.ts/wallet/json-keystore.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AA8BH;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAOpD;AAED;;;;;;;GAOG;AACH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,UAAU,GAAG,eAAe,CAiBrG;AAED;;;;;;;GAOG;AACH,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,MAAM,CAYvG"}
|
|
@@ -15,7 +15,13 @@
|
|
|
15
15
|
//import { computeAddress } from "../transaction/index.js";
|
|
16
16
|
//concat, assert, assertArgument,
|
|
17
17
|
import { getBytes, hexlify, toUtf8String } from "../utils/index.js";
|
|
18
|
-
import { SigningKey } from "../crypto/signing-key";
|
|
18
|
+
import { SigningKey } from "../crypto/signing-key.js";
|
|
19
|
+
//zpad
|
|
20
|
+
//import { spelunk } from "./utils.js";
|
|
21
|
+
//import type { ProgressCallback } from "../crypto/index.js";
|
|
22
|
+
//import {Wallet} from "quantum-coin-js-sdk";
|
|
23
|
+
//import type { BytesLike } from "../utils/index.js";
|
|
24
|
+
import { Wallet, deserializeEncryptedWallet, serializeEncryptedWallet } from "quantum-coin-js-sdk";
|
|
19
25
|
/**
|
|
20
26
|
* Returns true if %%json%% is a valid JSON Keystore Wallet.
|
|
21
27
|
*/
|
|
@@ -46,7 +52,7 @@ export function decryptKeystoreJsonSync(json, _password) {
|
|
|
46
52
|
else {
|
|
47
53
|
pass = toUtf8String(_password);
|
|
48
54
|
}
|
|
49
|
-
let wal =
|
|
55
|
+
let wal = deserializeEncryptedWallet(json, pass);
|
|
50
56
|
let privKey = wal.privateKey;
|
|
51
57
|
let ks = {
|
|
52
58
|
address: wal.address,
|
|
@@ -66,13 +72,13 @@ export function encryptKeystoreJsonSync(account, password) {
|
|
|
66
72
|
const signingKey = new SigningKey(account.privateKey);
|
|
67
73
|
const privateKey = getBytes(signingKey.privateKey);
|
|
68
74
|
const publicKey = getBytes(signingKey.publicKey);
|
|
69
|
-
const wal = new
|
|
75
|
+
const wal = new Wallet(account.address, privateKey, publicKey);
|
|
70
76
|
if (typeof password === 'string') {
|
|
71
|
-
return
|
|
77
|
+
return serializeEncryptedWallet(wal, password);
|
|
72
78
|
}
|
|
73
79
|
else {
|
|
74
80
|
let passPhrase = toUtf8String(password);
|
|
75
|
-
return
|
|
81
|
+
return serializeEncryptedWallet(wal, passPhrase);
|
|
76
82
|
}
|
|
77
83
|
}
|
|
78
84
|
//# sourceMappingURL=json-keystore.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"json-keystore.js","sourceRoot":"","sources":["../../src.ts/wallet/json-keystore.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,+BAA+B;AAE/B,mDAAmD;AACnD,yCAAyC;AACzC,kDAAkD;AAClD,2DAA2D;AAC3D,iCAAiC;AACjC,OAAO,EACH,QAAQ,EAAE,OAAO,EAAE,YAAY,EAClC,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EAAC,UAAU,EAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"json-keystore.js","sourceRoot":"","sources":["../../src.ts/wallet/json-keystore.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,+BAA+B;AAE/B,mDAAmD;AACnD,yCAAyC;AACzC,kDAAkD;AAClD,2DAA2D;AAC3D,iCAAiC;AACjC,OAAO,EACH,QAAQ,EAAE,OAAO,EAAE,YAAY,EAClC,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EAAC,UAAU,EAAC,MAAM,0BAA0B,CAAA;AAEnD,MAAM;AACN,uCAAuC;AAEvC,6DAA6D;AAC7D,6CAA6C;AAC7C,qDAAqD;AACrD,OAAO,EAAC,MAAM,EAAE,0BAA0B,EAAE,wBAAwB,EAAC,MAAM,qBAAqB,CAAC;AAiBjG;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,IAAY;IACvC,IAAI;QACA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,IAAI,OAAO,KAAK,CAAC,EAAE;YAAE,OAAO,IAAI,CAAC;SAAE;KACtC;IAAC,OAAO,KAAK,EAAE,GAAG;IACnB,OAAO,KAAK,CAAC;AACjB,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,uBAAuB,CAAC,IAAY,EAAE,SAA8B;IAChF,IAAI,IAAY,CAAC;IACjB,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE;QAC/B,IAAI,GAAG,SAAS,CAAC;KACpB;SAAM;QACH,IAAI,GAAI,YAAY,CAAC,SAAS,CAAC,CAAC;KACnC;IAED,IAAI,GAAG,GAAG,0BAA0B,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACjD,IAAI,OAAO,GAAQ,GAAG,CAAC,UAAU,CAAC;IAElC,IAAI,EAAE,GAAoB;QACtB,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,UAAU,EAAE,OAAO,CAAC,OAAO,CAAC;KAC/B,CAAC;IAEF,OAAO,EAAE,CAAC;AACd,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,uBAAuB,CAAC,OAAwB,EAAE,QAA6B;IAC3F,MAAM,UAAU,GAAe,IAAI,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAClE,MAAM,UAAU,GAAQ,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IACxD,MAAM,SAAS,GAAQ,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IACtD,MAAM,GAAG,GAAG,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;IAE/D,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;QAC9B,OAAO,wBAAwB,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;KAClD;SAAM;QACH,IAAI,UAAU,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;QACxC,OAAO,wBAAwB,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;KACpD;AACL,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../src.ts/wallet/wallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGhD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../src.ts/wallet/wallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGhD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAU9C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAKtD;;;;;;;;;GASG;AACH,qBAAa,MAAO,SAAQ,UAAU;;IAElC;;;OAGG;gBACS,GAAG,EAAE,MAAM,GAAG,UAAU,EAAE,QAAQ,CAAC,EAAE,IAAI,GAAG,QAAQ;IAShE,OAAO,CAAC,QAAQ,EAAE,IAAI,GAAG,QAAQ,GAAG,MAAM;IAI1C;;;;;;OAMG;IACG,OAAO,CAAC,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAK7D;;;;;;;;;OASG;IACH,WAAW,CAAC,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,MAAM;IAgBlD;;;OAGG;WACU,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAU5F;;;;;;OAMG;IACH,MAAM,CAAC,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,MAAM;IAWjF;;;;;OAKG;IACH,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,IAAI,GAAG,QAAQ,GAAG,MAAM;CAc1D"}
|
package/lib.esm/wallet/wallet.js
CHANGED
|
@@ -3,6 +3,8 @@ import { assertArgument, hexlify } from "../utils/index.js";
|
|
|
3
3
|
import { BaseWallet } from "./base-wallet.js";
|
|
4
4
|
//import { decryptCrowdsaleJson, isCrowdsaleJson } from "./json-crowdsale.js";
|
|
5
5
|
import { decryptKeystoreJsonSync, encryptKeystoreJsonSync, isKeystoreJson } from "./json-keystore.js";
|
|
6
|
+
//import { Mnemonic } from "./mnemonic.js";
|
|
7
|
+
import { newWallet } from "quantum-coin-js-sdk";
|
|
6
8
|
//import {newWallet} from "quantum-coin-js-sdk";
|
|
7
9
|
/**
|
|
8
10
|
* A **Wallet** manages a single private key which is used to sign
|
|
@@ -95,7 +97,7 @@ export class Wallet extends BaseWallet {
|
|
|
95
97
|
* If there is no crytographic random source, this will throw.
|
|
96
98
|
*/
|
|
97
99
|
static createRandom(provider) {
|
|
98
|
-
let wal =
|
|
100
|
+
let wal = newWallet();
|
|
99
101
|
let privKey = wal.privateKey;
|
|
100
102
|
return new Wallet(hexlify(privKey));
|
|
101
103
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../src.ts/wallet/wallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAC,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE3D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,+EAA+E;AAC/E,OAAO,EACH,uBAAuB,EACvB,uBAAuB,EACvB,cAAc,EACjB,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../src.ts/wallet/wallet.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -25,8 +25,8 @@
|
|
|
25
25
|
"@types/semver": "7.5.8",
|
|
26
26
|
"c8": "7.12.0",
|
|
27
27
|
"mocha": "10.7.3",
|
|
28
|
+
"quantum-coin-js-sdk": "1.0.23",
|
|
28
29
|
"quantum-coin-pqc-js-sdk": "^1.0.5",
|
|
29
|
-
"quantum-coin-js-sdk": "^1.0.20",
|
|
30
30
|
"rollup": "4.24.0",
|
|
31
31
|
"semver": "7.6.3",
|
|
32
32
|
"typescript": "5.0.4",
|
|
@@ -85,7 +85,7 @@
|
|
|
85
85
|
"default": "./lib.commonjs/wordlists/index.js"
|
|
86
86
|
}
|
|
87
87
|
},
|
|
88
|
-
"gitHead": "
|
|
88
|
+
"gitHead": "ede6a5a650a591b064e783c828fd5297e4e186dc",
|
|
89
89
|
"homepage": "https://QuantumCoin.org",
|
|
90
90
|
"keywords": [
|
|
91
91
|
"ethereum",
|
|
@@ -108,13 +108,14 @@
|
|
|
108
108
|
},
|
|
109
109
|
"scripts": {
|
|
110
110
|
"_build-dist": "rollup -c && uglifyjs ./dist/quantumcoin.js -o ./dist/quantumcoin.min.js && uglifyjs ./dist/quantumcoin.umd.js -o ./dist/quantumcoin.umd.min.js && uglifyjs ./dist/wordlists-extra.js -o ./dist/wordlists-extra.min.js",
|
|
111
|
-
"_dist-stats": "gzip -k9f -S
|
|
111
|
+
"_dist-stats": "gzip -k9f -S .gz ./dist/quantumcoin.min.js && gzip -k9f -S .gz ./dist/quantumcoin.umd.min.js && gzip -k9f -S .gz ./dist/wordlists-extra.min.js",
|
|
112
112
|
"auto-build": "npm run build -- -w",
|
|
113
113
|
"build": "tsc --project tsconfig.esm.json",
|
|
114
114
|
"build-all": "npm run build && npm run build-commonjs",
|
|
115
|
-
"build-clean": "npm run clean && npm run build &&
|
|
115
|
+
"build-clean": "npm run clean && npm run build && npm run build-all && npm run _build-dist && npm run _dist-stats",
|
|
116
116
|
"build-commonjs": "tsc --project tsconfig.commonjs.json",
|
|
117
117
|
"build-dist": "npm run build && npm run _build-dist && npm run _dist-stats",
|
|
118
|
+
"build-new": "npm run build && npm run build-all && npm run _build-dist && npm run _dist-stats",
|
|
118
119
|
"clean": "rm -rf dist lib.esm lib.commonjs && cp -r misc/basedirs/* .",
|
|
119
120
|
"postpublish": "node lib.esm/_admin/create-release.js",
|
|
120
121
|
"stats": "echo 'Dependencies' && npm ls --all --omit=dev",
|
|
@@ -125,5 +126,5 @@
|
|
|
125
126
|
"test-esm": "mocha --trace-warnings --reporter ./reporter.cjs ./lib.esm/_tests/test-*.js"
|
|
126
127
|
},
|
|
127
128
|
"sideEffects": false,
|
|
128
|
-
"version": "6.14.
|
|
129
|
+
"version": "6.14.4"
|
|
129
130
|
}
|
package/src.ts/_version.ts
CHANGED
|
@@ -5,12 +5,12 @@
|
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
7
|
import pqc = require('quantum-coin-pqc-js-sdk');
|
|
8
|
-
import
|
|
8
|
+
import {combinePublicKeySignature, publicKeyFromPrivateKey, publicKeyFromSignature} from "quantum-coin-js-sdk";
|
|
9
9
|
|
|
10
10
|
import {
|
|
11
11
|
getBytes,
|
|
12
12
|
dataLength, getBytesCopy, hexlify,
|
|
13
|
-
assertArgument
|
|
13
|
+
assertArgument,
|
|
14
14
|
} from "../utils/index.js";
|
|
15
15
|
|
|
16
16
|
import { Signature } from "./signature.js";
|
|
@@ -21,7 +21,7 @@ import type { SignatureLike } from "./index.js";
|
|
|
21
21
|
|
|
22
22
|
const CRYPTO_MESSAGE_LENGTH = 32;
|
|
23
23
|
const CRYPTO_SECRETKEY_BYTES = 64 + 2560 + 1312 + 128;
|
|
24
|
-
|
|
24
|
+
const CRYPTO_PUBLICKEY_BYTES = 32 + 1312 + 64;
|
|
25
25
|
|
|
26
26
|
/**
|
|
27
27
|
* A **SigningKey** provides high-level access to cryptography operations and key management.
|
|
@@ -56,7 +56,7 @@ export class SigningKey {
|
|
|
56
56
|
|
|
57
57
|
const sig: any = pqc.cryptoSign(getBytesCopy(digest), getBytesCopy(this.#privateKey));
|
|
58
58
|
const pubBytes: any = getBytes(this.publicKey);
|
|
59
|
-
const combinedSig =
|
|
59
|
+
const combinedSig = combinePublicKeySignature(pubBytes, sig);
|
|
60
60
|
|
|
61
61
|
return Signature.from({
|
|
62
62
|
r: this.publicKey,
|
|
@@ -66,7 +66,7 @@ export class SigningKey {
|
|
|
66
66
|
}
|
|
67
67
|
|
|
68
68
|
/**
|
|
69
|
-
* Compute the public key for a private %%key%%.
|
|
69
|
+
* Compute the public key for a private %%key%%. If a publicKey is passed, it is returned as is. for backward compatibility.
|
|
70
70
|
*
|
|
71
71
|
*
|
|
72
72
|
* @example:
|
|
@@ -77,11 +77,16 @@ export class SigningKey {
|
|
|
77
77
|
* //_result:
|
|
78
78
|
*/
|
|
79
79
|
static computePublicKey(key: BytesLike): string {
|
|
80
|
-
|
|
81
|
-
let
|
|
80
|
+
let keyBytes: any = getBytes(key, "key");
|
|
81
|
+
let pubKey: any;
|
|
82
82
|
|
|
83
|
-
|
|
83
|
+
if (keyBytes.length == CRYPTO_SECRETKEY_BYTES) {
|
|
84
|
+
pubKey = publicKeyFromPrivateKey(keyBytes);
|
|
85
|
+
} else if(keyBytes.length == CRYPTO_PUBLICKEY_BYTES) {
|
|
86
|
+
pubKey = keyBytes;
|
|
87
|
+
}
|
|
84
88
|
|
|
89
|
+
assertArgument(pubKey !== null && pubKey !== undefined, "invalid key", "key", "[REDACTED]");
|
|
85
90
|
return pubKey;
|
|
86
91
|
}
|
|
87
92
|
|
|
@@ -110,7 +115,7 @@ export class SigningKey {
|
|
|
110
115
|
let sigBytes: any = getBytes(sig.s);
|
|
111
116
|
let digestBytes: any = digest;
|
|
112
117
|
|
|
113
|
-
let publicKey =
|
|
118
|
+
let publicKey = publicKeyFromSignature(digestBytes, sigBytes);
|
|
114
119
|
|
|
115
120
|
return publicKey;
|
|
116
121
|
}
|
package/src.ts/quantumcoin.ts
CHANGED
|
@@ -1,10 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
1
|
/////////////////////////////
|
|
4
2
|
//
|
|
3
|
+
import {initialize, Config} from "quantum-coin-js-sdk";
|
|
4
|
+
|
|
5
|
+
async function initQuantum() {
|
|
6
|
+
let clientConfigVal = new Config("https://sdk.readrelay.quantumcoinapi.com", "https://sdk.writerelay.quantumcoinapi.com", 123123, "", ""); //Mainnet
|
|
7
|
+
return await initialize(clientConfigVal);
|
|
8
|
+
}
|
|
5
9
|
|
|
6
10
|
export { version } from "./_version.js";
|
|
7
11
|
|
|
12
|
+
export {
|
|
13
|
+
initQuantum,
|
|
14
|
+
}
|
|
15
|
+
|
|
8
16
|
export {
|
|
9
17
|
decodeBytes32String, encodeBytes32String,
|
|
10
18
|
|
|
@@ -4,7 +4,7 @@ import {SigningKey } from "../crypto/index.js";
|
|
|
4
4
|
|
|
5
5
|
import type { SignatureLike } from "../crypto/index.js";
|
|
6
6
|
import {BytesLike, getBytes} from "../utils/index.js";
|
|
7
|
-
import
|
|
7
|
+
import {addressFromPublicKey} from "quantum-coin-js-sdk";
|
|
8
8
|
|
|
9
9
|
/**
|
|
10
10
|
* Returns the address for the %%key%%.
|
|
@@ -14,12 +14,16 @@ import qcsdk = require('quantum-coin-js-sdk');
|
|
|
14
14
|
export function computeAddress(key: string | SigningKey): string {
|
|
15
15
|
let pubkey: string;
|
|
16
16
|
if (typeof(key) === "string") {
|
|
17
|
-
|
|
17
|
+
if (key.startsWith("0x")) {
|
|
18
|
+
pubkey = SigningKey.computePublicKey(key);
|
|
19
|
+
} else {
|
|
20
|
+
pubkey = SigningKey.computePublicKey("0x" + key);
|
|
21
|
+
}
|
|
18
22
|
} else {
|
|
19
23
|
pubkey = key.publicKey;
|
|
20
24
|
}
|
|
21
25
|
let pubKeyBytes: any = getBytes(pubkey);
|
|
22
|
-
return
|
|
26
|
+
return addressFromPublicKey(pubKeyBytes);
|
|
23
27
|
}
|
|
24
28
|
|
|
25
29
|
/**
|
|
@@ -20,7 +20,7 @@ import {
|
|
|
20
20
|
getBytes, hexlify, toUtf8String
|
|
21
21
|
} from "../utils/index.js";
|
|
22
22
|
|
|
23
|
-
import {SigningKey} from "../crypto/signing-key"
|
|
23
|
+
import {SigningKey} from "../crypto/signing-key.js"
|
|
24
24
|
|
|
25
25
|
//zpad
|
|
26
26
|
//import { spelunk } from "./utils.js";
|
|
@@ -28,7 +28,9 @@ import {SigningKey} from "../crypto/signing-key"
|
|
|
28
28
|
//import type { ProgressCallback } from "../crypto/index.js";
|
|
29
29
|
//import {Wallet} from "quantum-coin-js-sdk";
|
|
30
30
|
//import type { BytesLike } from "../utils/index.js";
|
|
31
|
-
import
|
|
31
|
+
import {Wallet, deserializeEncryptedWallet, serializeEncryptedWallet} from "quantum-coin-js-sdk";
|
|
32
|
+
|
|
33
|
+
|
|
32
34
|
|
|
33
35
|
//import { version } from "../_version.js";
|
|
34
36
|
|
|
@@ -71,7 +73,7 @@ export function decryptKeystoreJsonSync(json: string, _password: string | Uint8A
|
|
|
71
73
|
pass = toUtf8String(_password);
|
|
72
74
|
}
|
|
73
75
|
|
|
74
|
-
let wal =
|
|
76
|
+
let wal = deserializeEncryptedWallet(json, pass);
|
|
75
77
|
let privKey: any = wal.privateKey;
|
|
76
78
|
|
|
77
79
|
let ks: KeystoreAccount = {
|
|
@@ -94,13 +96,13 @@ export function encryptKeystoreJsonSync(account: KeystoreAccount, password: Uint
|
|
|
94
96
|
const signingKey: SigningKey = new SigningKey(account.privateKey);
|
|
95
97
|
const privateKey: any = getBytes(signingKey.privateKey);
|
|
96
98
|
const publicKey: any = getBytes(signingKey.publicKey);
|
|
97
|
-
const wal = new
|
|
99
|
+
const wal = new Wallet(account.address, privateKey, publicKey);
|
|
98
100
|
|
|
99
101
|
if (typeof password === 'string') {
|
|
100
|
-
return
|
|
102
|
+
return serializeEncryptedWallet(wal, password);
|
|
101
103
|
} else {
|
|
102
104
|
let passPhrase = toUtf8String(password);
|
|
103
|
-
return
|
|
105
|
+
return serializeEncryptedWallet(wal, passPhrase);
|
|
104
106
|
}
|
|
105
107
|
}
|
|
106
108
|
|
package/src.ts/wallet/wallet.ts
CHANGED
|
@@ -10,8 +10,7 @@ import {
|
|
|
10
10
|
isKeystoreJson
|
|
11
11
|
} from "./json-keystore.js";
|
|
12
12
|
//import { Mnemonic } from "./mnemonic.js";
|
|
13
|
-
import
|
|
14
|
-
|
|
13
|
+
import {newWallet} from "quantum-coin-js-sdk";
|
|
15
14
|
import type { Provider } from "../providers/index.js";
|
|
16
15
|
|
|
17
16
|
import type { KeystoreAccount } from "./json-keystore.js";
|
|
@@ -123,7 +122,7 @@ export class Wallet extends BaseWallet {
|
|
|
123
122
|
* If there is no crytographic random source, this will throw.
|
|
124
123
|
*/
|
|
125
124
|
static createRandom(provider?: null | Provider): Wallet {
|
|
126
|
-
let wal =
|
|
125
|
+
let wal = newWallet();
|
|
127
126
|
let privKey: any = wal.privateKey;
|
|
128
127
|
return new Wallet(hexlify(privKey));
|
|
129
128
|
}
|