quantumcoin 7.0.10 → 7.0.12

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 (171) hide show
  1. package/README-SDK.md +16 -5
  2. package/README.md +14 -3
  3. package/config.js +10 -2
  4. package/examples/example.js +0 -5
  5. package/examples/example.ts +0 -5
  6. package/examples/node_modules/.bin/esbuild +16 -0
  7. package/examples/node_modules/.bin/esbuild.cmd +17 -0
  8. package/examples/node_modules/.bin/esbuild.ps1 +28 -0
  9. package/examples/node_modules/.bin/sdkgen +16 -0
  10. package/examples/node_modules/.bin/sdkgen.cmd +17 -0
  11. package/examples/node_modules/.bin/sdkgen.ps1 +28 -0
  12. package/examples/node_modules/.bin/tsx +16 -0
  13. package/examples/node_modules/.bin/tsx.cmd +17 -0
  14. package/examples/node_modules/.bin/tsx.ps1 +28 -0
  15. package/examples/node_modules/.package-lock.json +144 -0
  16. package/examples/node_modules/@esbuild/win32-x64/README.md +3 -0
  17. package/examples/node_modules/@esbuild/win32-x64/esbuild.exe +0 -0
  18. package/examples/node_modules/@esbuild/win32-x64/package.json +20 -0
  19. package/examples/node_modules/esbuild/LICENSE.md +21 -0
  20. package/examples/node_modules/esbuild/README.md +3 -0
  21. package/examples/node_modules/esbuild/bin/esbuild +223 -0
  22. package/examples/node_modules/esbuild/install.js +289 -0
  23. package/examples/node_modules/esbuild/lib/main.d.ts +716 -0
  24. package/examples/node_modules/esbuild/lib/main.js +2532 -0
  25. package/examples/node_modules/esbuild/package.json +49 -0
  26. package/examples/node_modules/get-tsconfig/LICENSE +21 -0
  27. package/examples/node_modules/get-tsconfig/README.md +235 -0
  28. package/examples/node_modules/get-tsconfig/dist/index.cjs +7 -0
  29. package/examples/node_modules/get-tsconfig/dist/index.d.cts +2088 -0
  30. package/examples/node_modules/get-tsconfig/dist/index.d.mts +2088 -0
  31. package/examples/node_modules/get-tsconfig/dist/index.mjs +7 -0
  32. package/examples/node_modules/get-tsconfig/package.json +46 -0
  33. package/examples/node_modules/quantum-coin-js-sdk/LICENSE +21 -0
  34. package/examples/node_modules/quantum-coin-js-sdk/LICENSE-wasm_exec.js.txt +30 -0
  35. package/examples/node_modules/quantum-coin-js-sdk/README.md +1675 -0
  36. package/examples/node_modules/quantum-coin-js-sdk/example/README.md +14 -0
  37. package/examples/node_modules/quantum-coin-js-sdk/example/conversion-example.js +19 -0
  38. package/examples/node_modules/quantum-coin-js-sdk/example/example-create-contract.js +396 -0
  39. package/examples/node_modules/quantum-coin-js-sdk/example/example-encode-decode-rlp.js +225 -0
  40. package/examples/node_modules/quantum-coin-js-sdk/example/example-event-pack-unpack.js +391 -0
  41. package/examples/node_modules/quantum-coin-js-sdk/example/example-misc.js +101 -0
  42. package/examples/node_modules/quantum-coin-js-sdk/example/example-rpc-send-signRawTransaction.js +318 -0
  43. package/examples/node_modules/quantum-coin-js-sdk/example/example-rpc-send.js +116 -0
  44. package/examples/node_modules/quantum-coin-js-sdk/example/example-send.js +70 -0
  45. package/examples/node_modules/quantum-coin-js-sdk/example/example-token-pack-unpack.js +961 -0
  46. package/examples/node_modules/quantum-coin-js-sdk/example/example-wallet-version4.js +35 -0
  47. package/examples/node_modules/quantum-coin-js-sdk/example/example-wallet.js +43 -0
  48. package/examples/node_modules/quantum-coin-js-sdk/example/example.js +405 -0
  49. package/examples/node_modules/quantum-coin-js-sdk/example/package-lock.json +134 -0
  50. package/examples/node_modules/quantum-coin-js-sdk/example/package.json +15 -0
  51. package/examples/node_modules/quantum-coin-js-sdk/index.d.ts +1031 -0
  52. package/examples/node_modules/quantum-coin-js-sdk/index.js +3144 -0
  53. package/examples/node_modules/quantum-coin-js-sdk/package.json +34 -0
  54. package/examples/node_modules/quantum-coin-js-sdk/tests/encrypted-32.json +1 -0
  55. package/examples/node_modules/quantum-coin-js-sdk/tests/encrypted-36.json +1 -0
  56. package/examples/node_modules/quantum-coin-js-sdk/tests/encrypted-48.json +1 -0
  57. package/examples/node_modules/quantum-coin-js-sdk/tests/generate-verify-vectors.js +91 -0
  58. package/examples/node_modules/quantum-coin-js-sdk/tests/non-transactional.preinit.test.js +41 -0
  59. package/examples/node_modules/quantum-coin-js-sdk/tests/non-transactional.test.js +1389 -0
  60. package/examples/node_modules/quantum-coin-js-sdk/tests/sign-raw-keytype5-context-null.test.js +107 -0
  61. package/examples/node_modules/quantum-coin-js-sdk/tests/sign-raw-transaction.test.js +196 -0
  62. package/examples/node_modules/quantum-coin-js-sdk/tests/sign-verify.test.js +311 -0
  63. package/examples/node_modules/quantum-coin-js-sdk/tests/transactional.relay.test.js +131 -0
  64. package/examples/node_modules/quantum-coin-js-sdk/tests/transactional.rpc.test.js +103 -0
  65. package/examples/node_modules/quantum-coin-js-sdk/tests/verify-vectors.json +95035 -0
  66. package/examples/node_modules/quantum-coin-js-sdk/wasmBase64.d.ts +9 -0
  67. package/examples/node_modules/quantum-coin-js-sdk/wasmBase64.js +16 -0
  68. package/examples/node_modules/quantum-coin-js-sdk/wasm_exec.d.ts +0 -0
  69. package/examples/node_modules/quantum-coin-js-sdk/wasm_exec.js +587 -0
  70. package/examples/node_modules/resolve-pkg-maps/LICENSE +21 -0
  71. package/examples/node_modules/resolve-pkg-maps/README.md +216 -0
  72. package/examples/node_modules/resolve-pkg-maps/dist/index.cjs +1 -0
  73. package/examples/node_modules/resolve-pkg-maps/dist/index.d.cts +11 -0
  74. package/examples/node_modules/resolve-pkg-maps/dist/index.d.mts +11 -0
  75. package/examples/node_modules/resolve-pkg-maps/dist/index.mjs +1 -0
  76. package/examples/node_modules/resolve-pkg-maps/package.json +42 -0
  77. package/examples/node_modules/seed-words/.github/workflows/publish-npmjs.yaml +22 -0
  78. package/examples/node_modules/seed-words/BUILD.md +7 -0
  79. package/examples/node_modules/seed-words/LICENSE +121 -0
  80. package/examples/node_modules/seed-words/README.md +67 -0
  81. package/examples/node_modules/seed-words/dist/seedwords.d.ts +39 -0
  82. package/examples/node_modules/seed-words/package.json +27 -0
  83. package/examples/node_modules/seed-words/seedwords.js +315 -0
  84. package/examples/node_modules/seed-words/seedwords.txt +65536 -0
  85. package/examples/node_modules/seed-words/tsconfig.json +21 -0
  86. package/examples/node_modules/tsx/LICENSE +21 -0
  87. package/examples/node_modules/tsx/README.md +32 -0
  88. package/examples/node_modules/tsx/dist/cjs/api/index.cjs +1 -0
  89. package/examples/node_modules/tsx/dist/cjs/api/index.d.cts +35 -0
  90. package/examples/node_modules/tsx/dist/cjs/api/index.d.mts +35 -0
  91. package/examples/node_modules/tsx/dist/cjs/api/index.mjs +1 -0
  92. package/examples/node_modules/tsx/dist/cjs/index.cjs +1 -0
  93. package/examples/node_modules/tsx/dist/cjs/index.mjs +1 -0
  94. package/examples/node_modules/tsx/dist/cli.cjs +54 -0
  95. package/examples/node_modules/tsx/dist/cli.mjs +55 -0
  96. package/examples/node_modules/tsx/dist/client-BQVF1NaW.mjs +1 -0
  97. package/examples/node_modules/tsx/dist/client-D6NvIMSC.cjs +1 -0
  98. package/examples/node_modules/tsx/dist/esm/api/index.cjs +1 -0
  99. package/examples/node_modules/tsx/dist/esm/api/index.d.cts +35 -0
  100. package/examples/node_modules/tsx/dist/esm/api/index.d.mts +35 -0
  101. package/examples/node_modules/tsx/dist/esm/api/index.mjs +1 -0
  102. package/examples/node_modules/tsx/dist/esm/index.cjs +2 -0
  103. package/examples/node_modules/tsx/dist/esm/index.mjs +2 -0
  104. package/examples/node_modules/tsx/dist/get-pipe-path-BHW2eJdv.mjs +1 -0
  105. package/examples/node_modules/tsx/dist/get-pipe-path-BoR10qr8.cjs +1 -0
  106. package/examples/node_modules/tsx/dist/index-7AaEi15b.mjs +14 -0
  107. package/examples/node_modules/tsx/dist/index-BWFBUo6r.cjs +1 -0
  108. package/examples/node_modules/tsx/dist/index-gbaejti9.mjs +1 -0
  109. package/examples/node_modules/tsx/dist/index-gckBtVBf.cjs +14 -0
  110. package/examples/node_modules/tsx/dist/lexer-DQCqS3nf.mjs +3 -0
  111. package/examples/node_modules/tsx/dist/lexer-DgIbo0BU.cjs +3 -0
  112. package/examples/node_modules/tsx/dist/loader.cjs +1 -0
  113. package/examples/node_modules/tsx/dist/loader.mjs +1 -0
  114. package/examples/node_modules/tsx/dist/node-features-_8ZFwP_x.mjs +1 -0
  115. package/examples/node_modules/tsx/dist/node-features-roYmp9jK.cjs +1 -0
  116. package/examples/node_modules/tsx/dist/package-CeBgXWuR.mjs +1 -0
  117. package/examples/node_modules/tsx/dist/package-Dxt5kIHw.cjs +1 -0
  118. package/examples/node_modules/tsx/dist/patch-repl.cjs +1 -0
  119. package/examples/node_modules/tsx/dist/patch-repl.mjs +1 -0
  120. package/examples/node_modules/tsx/dist/preflight.cjs +1 -0
  121. package/examples/node_modules/tsx/dist/preflight.mjs +1 -0
  122. package/examples/node_modules/tsx/dist/register-2sWVXuRQ.cjs +1 -0
  123. package/examples/node_modules/tsx/dist/register-B7jrtLTO.mjs +1 -0
  124. package/examples/node_modules/tsx/dist/register-CFH5oNdT.mjs +4 -0
  125. package/examples/node_modules/tsx/dist/register-D46fvsV_.cjs +4 -0
  126. package/examples/node_modules/tsx/dist/repl.cjs +3 -0
  127. package/examples/node_modules/tsx/dist/repl.mjs +3 -0
  128. package/examples/node_modules/tsx/dist/require-D4F1Lv60.cjs +1 -0
  129. package/examples/node_modules/tsx/dist/require-DQxpCAr4.mjs +1 -0
  130. package/examples/node_modules/tsx/dist/suppress-warnings.cjs +1 -0
  131. package/examples/node_modules/tsx/dist/suppress-warnings.mjs +1 -0
  132. package/examples/node_modules/tsx/dist/temporary-directory-B83uKxJF.cjs +1 -0
  133. package/examples/node_modules/tsx/dist/temporary-directory-CwHp0_NW.mjs +1 -0
  134. package/examples/node_modules/tsx/dist/types-Cxp8y2TL.d.ts +5 -0
  135. package/examples/node_modules/tsx/package.json +68 -0
  136. package/examples/offline-signing.js +0 -2
  137. package/examples/offline-signing.ts +0 -1
  138. package/examples/package-lock.json +422 -73
  139. package/examples/package.json +1 -1
  140. package/examples/wallet-offline.js +1 -9
  141. package/examples/wallet-offline.ts +1 -9
  142. package/generate-sdk.js +5 -7
  143. package/package.json +2 -2
  144. package/src/abi/interface.js +13 -7
  145. package/src/abi/js-abi-coder.js +23 -18
  146. package/src/constants.d.ts +0 -5
  147. package/src/constants.js +0 -7
  148. package/src/contract/contract-factory.js +9 -3
  149. package/src/contract/contract.js +9 -3
  150. package/src/errors/index.js +12 -0
  151. package/src/index.d.ts +0 -3
  152. package/src/providers/extra-providers.js +20 -6
  153. package/src/providers/json-rpc-provider.js +15 -5
  154. package/src/providers/provider.d.ts +0 -2
  155. package/src/providers/provider.js +1 -3
  156. package/src/utils/address.d.ts +0 -14
  157. package/src/utils/address.js +12 -49
  158. package/src/utils/hashing.d.ts +0 -6
  159. package/src/utils/hashing.js +8 -23
  160. package/src/utils/index.d.ts +0 -3
  161. package/src/utils/rlp.js +7 -4
  162. package/src/wallet/wallet.d.ts +7 -13
  163. package/src/wallet/wallet.js +136 -97
  164. package/test/security/malformed-input.test.js +295 -1
  165. package/test/unit/address-wallet.test.js +329 -129
  166. package/test/unit/address-wallet.test.ts +328 -128
  167. package/test/unit/hashing.test.js +0 -11
  168. package/test/unit/hashing.test.ts +0 -11
  169. package/test/unit/providers.test.js +3 -1
  170. package/test/unit/providers.test.ts +3 -1
  171. package/SPEC.md +0 -3845
@@ -0,0 +1,35 @@
1
+ const qcsdk = require('quantum-coin-js-sdk');
2
+ const ethers = require('ethers');
3
+
4
+
5
+ var clientConfigVal = new qcsdk.Config("", "", 123123, "", ""); //Mainnet
6
+
7
+ //Initialize the SDK
8
+ qcsdk.initialize(clientConfigVal).then((initResult) => {
9
+ if (initResult === false) {
10
+ console.error("Initialize failed");
11
+ return;
12
+ }
13
+ let examplePassphrase = "QuantumCoinExample123!";
14
+
15
+ //Open example wallet created using external wallet application such as Desktop/Web/CLI/Mobile wallet
16
+ const walletEncryptedJson = "{\"address\":\"45dc00282f80628911a15775cd821a3747d2c62e14e54d1339f057c9e921be71\",\"crypto\":{\"cipher\":\"aes-256-ctr\",\"ciphertext\":\"a831e40b8e99a534df5b6dee638742f5d5ebddf07d0aa5603ff4c32d62de8442d1252f84c6777d12d14ca3be80538d5e69cc70e75363730427194cda709dee33da97452fcd4284898afebac2d5b298b10be30a89416afa66edfa46b3a396b880f030d5f2c64a7fcfd458ee8705f160cc98335cf7a7849908e33cd5af88a989c092c5453315436b0d3dd18f9357f68b37c95f30b5e3c6b1a29c39dd1c32af13c39398c137fa45334fd46b0601046818afa0710e38fb780fa47d8cf8392ce43461ef730fc8464fd4c39b75c27017e8a4344855edd16b7ac2e3a4c6a87a077314ada08def8ebde528c40e3d8b32f3ef9f9c8708020d86e99e89b3e5500aa6d9e628a2cc8b1dd17b0bbdd445f69c443b09433c3b8b94a6b1fd7e8af1b88cef8e6078dd010422e85ad3bd2d2e0344c7517f9530073c5f225c602eb61a138e13f79bf12c05bb01c61a2b13aed3d05d601ee42fa04af0ee6b2b37856b67e45348407ce43520e18e5bc639a9bfd0df9fedb8f91858bd3c220a78fc4aeeeaa8d7b3aa420964549b746fcb5b53177089b2ec59658c99b77e1b1e303233c041271a50c6e831379fd168f943563638341cca44ba63b3fe2fdd254386a4c325a881f3fb96f118169a56fed4b002f48bbfdfda728c50cff6529754359f29d44a66762f3a0ea39840a733852faa4a7be1ed6d8afc8291493cbdb55b17b4ef63dbe0f7bfb97c82986974f51a5da2b8dcdcf7f126f08389360164cd666f13ec64b9a63609c56fd154b6322f51d0b1d448dafe7806b59d00ce2fbbf34e6281f8c446012f124a4ea52955ff995dd642b1650cb4cdd9806038d2e3f3c0432a5a35307eae4ffdc49a8b9b83172804767ff8f082c8aa9e12315536ca6cb3b98cd80e438477ff5e53c9184db543fb6f3df0a7017bd9e513e83b707dd6917efd6990e609fd57abc1285e3e72899a1a6f0943539ea8e992050b681437a80b970f6e8d2bcdfa635acc270d7dec1b80bdb373dce18adb924b4ccf1ea61796a10f69eadb9da3ceea7e636e84fa0972e0cfea5237d19f488d31a0280e8a59f59dc44f825fd3bc41b92f1289042f45e892cab5a60a3036d594791143c737f2082cfcecf88f3a34d6cf6e50719c310e92e8e0fadbdce07f992006d5fc5869452ab572f6e4e864d5d72bde42d6ae26a909fa9a3964bc688052451e65a3612ef3e25392edd7388ebdeb3ee51d63ea3951a8ee653e7389d3a20cd7da5292fadad41e2decc398a9318d09d2b0c589c193f9411212e6eb76480adf62f6345e6b7ad980866cfe4921468618d3e29614450052be793c006e784f3180c97058aedd751a7db1b1d676285e7793acdc02642fbe45803ed837f6f518b63bf363ff2b73ac8215b5db7cebff2197467f5f89de7080cd83779ac94d0732deec47bd9473bdf5c45428e961d057c642336257390daa2784f82289941015e7ac2ff399710d4a123e30f9867a62c6ed1f07bfa5059487b558e9aeda68a6171b55c03f85c00fad075f57b344a84b0c098f922b89ed572e578e3d2951eeaa051d5f26339776f51f390af1f5fc62e6ea42fae34da1676d0410a96b7e1d3c88f37c753dcf6a19512c7f619aa0beb27b318c128f5728232b0fc86e4eb9dabca731ffbe8b09a93d82aa95010ef621ed33a319984d3e12b9e856d81f46602c7fe13d24716362ebfc70b43eb46495db78d2dbf509413a0162179023d22a4584f1421622e1151de4e4c80f12114b22d3d06f434a2f85cc5606cdad1d6fa3044a3dd6175049d137eb1a5d764715f1289dda9a8f55fd856275a3650ce7d67e20d025ef1c1c9c2a1f17613b41e4917edab30d31ae7d8c4351e9c8bb83726998e9cffc82f92d7ba1b1fd104d4f013a0496daf75ce2b50d21c4eb20c5d295832f3bd6501f6f1f491783aa476664e058cb2b4d22411bc5ecca5ec53b763f70e9223d9915c83b35e79aa86417b3505c8b952265c6a48ab266fade009c1faacce9d9a89516223593e5f1d5039f82ca0a043eceb78f5ea20d180b22d3f11a7ca5ae0792b5dc9685ba46fc87326eb468295f0890cf9338b69dabd5f826046e216bb7306333120bb36aa902f54dd28cbeb8580f3483cf69f8f9fdb3c7ff936f055f9323fa02db8237db7b2d6d26e137fc5fa728c387dbca015f34228915088a95fdfc09a5d2c42ea8189a1dff888ea53f52541232689ba396d96bffb13bab2d65f94a422ea762b6446d5a8e4e2f0c5b2398fcabba825e532a4bae96b45c2a88ca138ae9118653f71d1d9c7819755febcf15b203e1402522b2762985fdbd70dfc37cd0b6943d50cbbaf42f01b442e6f4445f986c09bc55835bb6a03431d1bfa1916db455c822972ff9fba37b2d4477cbf2138325949c4a15d1e0457b51cb06d35c9bf3478c79256989c36d9ec35b3d7f67eb23e476250f9424835be56ef00406c395d60c608100258b97cd51f853960c44ca48e2ea2696793e825db9e9a52ea840c8dd252273eec1212482738be81301acd8c79e5fd54b218c4e27b139c6e8eb5729b01326273a70f64785878dd3f0b10462bf11b152229dd5b1ef9d5cc7bffc44a85384163de88bb421a2999e0f01cec8b74c8dce0b0a40fd0409c26a9c967940592e61936a70f7c8be7d95d45b9a003b5dc1d33121cb7901afec1c8d98103e29d64a370ac6344600ceb067b921067ce2760a5a7e07c9396606458eb3f404713a8bb8d12211b64fd98bf9a88031cf9bbccab00a9f6a7b5c7033dfa90ff1aee6d95a9af74926ea83332523bbf4df7c4cd8769e0a56e50205b529bbafb37438c8ce05ed02e8dbcb6a60f03a0142e701ab2d2520e159ac2c5ce1a2d0f342bc837f60c7ca912241a55d8ed174f9b714950cc7d3eddd06d23f31d6fc46eb2bc248cfcac8fbb7a0d8bc6f972c9bd9f5ef29942bac1b117675c33664b50fcc6f049528b76dc2fffa766fca42c2968ff6960e33efd2984db268412543c07682f0ddb9bd59ce111820d6f1bd1a76063b0c60479b19b8a49631a722747c6d20133a77f7072330c134d006352e44443230c7eddfc9fd645a50b3e3ee780ef7097198d7c87ad9969d4afe414314b57f248e4237dc164e084be7534f2c3c55f5110fe7d202a5737f067b7a282f8090cfcdd2d34f64aee499c075e50f480272e3d981b3c0e553b8bd04279dcd0097cc035d8016f4e4d40d3b5526b617533e1f1db0d90b4071bd4e2ada7b6ad172beff1edda9c8c750f77895880a0cea9c5b35f70cc32d9b83d088ae66662182c0f41db5c3faaacd7773846d7cee72d3748533ec9983964749f1f5694218d357ecab2d330206dfc11dfaa5c29a6441890faf607d73f33732c07097da08d84231eed7346e706d24bc695df684c6670cc5b10662638f7c01534833f8b6fc6eab95f3841cea2069b7a25d97c390b58d04519a62bc93c56803ee773ba80309917202ddf8fe9cb128869a42e206126c282c4e896e74981db12f4d0f2bddec9a674b75c86e8cbd18d29ddca4dadc11141d066ebe424ace546ec974a6ec8b7ee352fcdc96a88a65c90166cd9c8b5b03640614632aa3eb0d1516b40128b065c3e377ceac6a5be1217351da75534c9d651d80551b3150732389e35025d0769bbb3d9885e83450eb262ed091bcd181979ecfc56d2301b3d3c7941e52a55f7e3460e1056612010cd286aa193a5dbe015b22bca180f239c36eeacbb6f6d5884f469163260fdf015203a8523059d8da4b869be00cb938d318a8215b212dd0bd6a7bd6e336bca3c67ba74872eb19c450982796d794b013f27e3cf889a928fcd94caff8692a29266befe74420edd2117bf947d4730dda838640128bdb17869eab8dfa228d4c4bb5ff5b00a57c6c8d1123487039338e3f342cf273e0e4995e95ff4c8e2a23974bf16c20f5443c21eb9aadf69aaacefddeacb2844f9a5f354cad0a94af5be824e9a2ec4c03828fdab7415d9be05372e8c515c0cd5fcd44e69f1b380df484c860539773ce68b402a6585fcd826a92ce05162cf7f17ca02d7fdd80b9cfa8bb3a37cf62ff6f3ecbe03c186075a5dbce6e36fe46ed9059fa60e347c978f0f3b71bc9d05e4a4e1ce6b48e0593a1acdf9899f4d709e005b972411349fda2c544396eb73c10d89c6db2b5a7506a34d7f5b66b3ff37e8088f2dcd9c2dd76b21818674f8ceb8bbda6c38b58dd5f5de09c8a25949e28aa04a8ccba10275c032309e9b61de148f8495640cfbf3d46e342c3859bfb5e6ab10b4df4a39bc20a2eb48fbaee4c01f5661b4129b15414842eaa46154c77df5484fab490185cfa83f21ec5b72abfa507b6b998654aec4b1031ac1dfc919022423d6020fa1a702fd65f98e0b6f64210f7d2d326de960a51c7c5b357c42073fac112a393c7f40a0f368600ba00010530aa782460098f559f42b37d3510afb425a249c0c17cf0380c40793b068d565fcc2fd70df74dc2b8cbda4849164c30631554517f0ba2c9e94977959012bc7f371b5c375214a5ed4f2d3920746cb5a01c0356c187bb186a7d5ae7bd57e13befa101813dce482b49ad0d41fbe5bc542cf55445136db1f8442003e48a75bb6637be93626178bed28402c91610d067d94d06136b337d4ada511376a84fb6bde4215828359058cb2f5b1d0281ff93743d43b8881d4f7591800166621141cca2b122f1ed63baaca752f7de0cf6d2e92dc6caa2a43df580d8b472400065aeeffc71d5a7a5f52f02d26a26225c53591a60e29a8ae7e9cd0d3f9f8ab8bb5176ae1fd4e881db04f8239b282123147036019a560fb450baf8fc3dbaa7989c04e8e8f674acdadf59048f7fcc5efd8ac3577e9204837dd6bec8c72c52d019e9172825ff27bc9cef950d729a02c26e00167872c53a2c303cb260035a5184519cdb9dc0ae32b1b3d0375b248fe4c5b98a37368cf0d548c48904d87d4f3ff4e9a989b3f28a5747cfd5f7a67d3b8dc30bdf709bfa56075d28e375d24c7409ff442913c1209f1587f8e252a35c6bfdcf581d7fb1bd693329eafd872078de4c1b31a7d5d5f3466adf41b0ee17c9aba8b88bbba6a868ddddfed5085947da0859d16641abc2e869e7a120c807d1a2092ed79f43f287dfdffc044cd3c246f87dc12727dc8b6151ea19f1d919ebd23ba46e5ae7fcc7cfd7a746db70dd0adeef889e5ae74941fbe7f97021fc95e8423ba91b735d8e9587f5ad515d595600abc96c08d796e640def566e990d9f4c6a5e7270f949284221c81df4e57a9c129a45d508820938365093d6dd672f4d4418c7bff35ca1603aa068beeee04060251722f04718303e1fd4c5bc64ef07b13408516ec92581d2de93a93693148ba416615fe1f1b64d5bd8975777337242e0ea9f7586599fdba8dd87c81a4c6bf4eab14d6ebac32cb3310cbbe5cf23620973b4ed7e688bec9e2d5569594c2377ba60f998750dd828bc704aeda55f5608ea12649e91a3733cb9b4a34d9886ea6b4a8d2cfbd883b9997ef1042f8d40b4cd870698585bb409cd5c21365d38e3c95dcd91244a62d766ba728aa822390c2def2166c46f45c275790f2a6dd11f906312214c120bf27efda0afd4cd8d6482d16a4ab72d2e69a49cb3e1b4ebb9025d81479fd2ccb4f66eee4248657c3f8dca13aa7201824bff06c543e0200c4cdff612ab0bb29b89fdb82c3a7abb14edd78f6e224c61c4d3d3b1c1c7038aa54afb4d32c3039d58e057185906c89887cc101b577c97b363d7c587c652a358c4025f690be410171b2c76723433da12a9163a4420f13aa\",\"cipherparams\":{\"iv\":\"664b1a53b2ecf34d3305397defd89b38\"},\"kdf\":\"scrypt\",\"kdfparams\":{\"dklen\":48,\"n\":262144,\"p\":1,\"r\":8,\"salt\":\"d48fb344fbec36d5a3787e4271561bdc61a6c100e20641521fceba2af6bc0668\"},\"mac\":\"ba8bebc33fe945df3340b9e761c199304655ac1c24dbef92b69cc5e6a84fb649\"},\"id\":\"a4d92ffd-9dc9-41ab-9eaa-04ef14b8a4bc\",\"version\":4}";
17
+ let walletExample = qcsdk.deserializeEncryptedWallet(walletEncryptedJson, examplePassphrase);
18
+ if (walletExample === null) {
19
+ console.log("Error opening wallet");
20
+ } else {
21
+ console.log("signSendCoinTransaction from wallet address: " + walletExample.address);
22
+ }
23
+
24
+
25
+ var toAddressExample = "0x8293cd9b6ac502d2fe077b0c157dad39f36a5e546525b053151dced633634612";
26
+ var nonceExample = 0; //use the latest nonce for the address as shown in Block Explorer. If address does not exist, default to 0. You may also get the nonce programatically from qcsdk.getAccountDetails like shown below
27
+ var coinsExample = "10"; //in ethers and not in wei
28
+
29
+ //Sign a transaction
30
+ qcsdk.signSendCoinTransaction(walletExample, toAddressExample, coinsExample, nonceExample).then((signResult) => {
31
+ console.log("signSendCoinTransaction resultCode: " + signResult.resultCode);
32
+ console.log("signSendCoinTransaction hash: " + signResult.txnHash);
33
+ });
34
+
35
+ });
@@ -0,0 +1,43 @@
1
+ const qcsdk = require('quantum-coin-js-sdk');
2
+
3
+ //var clientConfigVal = new qcsdk.Config("https://sdk.readrelay.quantumcoinapi.com", "https://sdk.writerelay.quantumcoinapi.com", 123123, "", ""); //Mainnet
4
+
5
+
6
+ //Initialize the client configuration
7
+ //var clientConfigVal = new qcsdk.Config("https://t4-relayread.quantumcoin.org", "https://t4-relaywrite.quantumcoin.org", 310324, "", ""); //Testnet T4
8
+ //Testnet T4 Block Explorer: https://t4.scan.quantumcoin.org
9
+
10
+ //For mainnet, use the following configuration
11
+ //var clientConfigVal = new qcsdk.Config("https://sdk.readrelay.quantumcoinapi.com", "https://sdk.writerelay.quantumcoinapi.com", 123123, "", ""); //Mainnet
12
+ //Mainnet Block Explorer: https://scan.quantumcoin.org
13
+
14
+ //Local testing configuration
15
+ //var clientConfigVal = new qcsdk.Config("http://127.0.0.1:9090", "http://127.0.0.1:9091", 123123, "", ""); //local testing
16
+ //Mainnet Block Explorer: https://scan.quantumcoin.org
17
+
18
+
19
+ //Initialize the SDK
20
+ qcsdk.initialize(undefined).then((initResult) => {
21
+ if (initResult === false) {
22
+ console.error("Initialize failed");
23
+ return;
24
+ }
25
+
26
+ let examplePassphrase = "helloworld123";
27
+
28
+ //Save to an encrypted wallet that can then be restored into an external wallet application such as Desktop/Web/CLI/Mobile wallet
29
+ let walletObj2 = qcsdk.newWallet();
30
+ let walletEncryptedJson2 = qcsdk.serializeEncryptedWallet(walletObj2, examplePassphrase);
31
+ if (walletEncryptedJson2 === null) {
32
+ throw new Error("serializeEncryptedWallet failed");
33
+ }
34
+ let walletEncryptedJson3 = qcsdk.serializeEncryptedWallet(walletObj2, examplePassphrase);
35
+ if (walletEncryptedJson3 === null) {
36
+ throw new Error("serializeEncryptedWallet failed");
37
+ }
38
+ console.log("Serialized wallet A: " + walletEncryptedJson2); //just an example for demonstration, do not actually log to console
39
+ console.log("Serialized wallet B: " + walletEncryptedJson3); //just an example for demonstration, do not actually log to console
40
+
41
+
42
+ });
43
+
@@ -0,0 +1,405 @@
1
+ const qcsdk = require('quantum-coin-js-sdk');
2
+ const ethers = require('ethers');
3
+
4
+ var clientConfigVal = new qcsdk.Config("https://sdk.readrelay.quantumcoinapi.com", "https://sdk.writerelay.quantumcoinapi.com", 123123, "", ""); //Mainnet
5
+
6
+
7
+ //Initialize the client configuration
8
+ //var clientConfigVal = new qcsdk.Config("https://t4-relayread.quantumcoin.org", "https://t4-relaywrite.quantumcoin.org", 310324, "", ""); //Testnet T4
9
+ //Testnet T4 Block Explorer: https://t4.scan.quantumcoin.org
10
+
11
+ //For mainnet, use the following configuration
12
+ //var clientConfigVal = new qcsdk.Config("https://sdk.readrelay.quantumcoinapi.com", "https://sdk.writerelay.quantumcoinapi.com", 123123, "", ""); //Mainnet
13
+ //Mainnet Block Explorer: https://scan.quantumcoin.org
14
+
15
+ //Local testing configuration
16
+ //var clientConfigVal = new qcsdk.Config("http://127.0.0.1:9090", "http://127.0.0.1:9091", 123123, "", ""); //local testing
17
+ //Mainnet Block Explorer: https://scan.quantumcoin.org
18
+
19
+
20
+ //Conversion examples
21
+ let hexValue = "0x56BC75E2D63100000";
22
+ let weiValueExample = BigInt(hexValue).toString(); //convert hex to wei
23
+ console.log("hex to wei example: hex:" + hexValue + ", wei: " + weiValueExample);
24
+
25
+ let ethValueExample = ethers.formatEther(weiValueExample); //convert wei to eth
26
+ console.log("wei to eth example: wei:" + weiValueExample + ", eth (coins): " + ethValueExample);
27
+
28
+ let weiValueExample2 = ethers.parseUnits(ethValueExample, "ether"); //convert eth to wei
29
+ console.log("eth to wei example: eth (coins):" + ethValueExample + ", wei: " + weiValueExample2);
30
+
31
+ //Initialize the SDK
32
+ qcsdk.initialize(clientConfigVal).then((initResult) => {
33
+ if (initResult === false) {
34
+ console.error("Initialize failed");
35
+ return;
36
+ }
37
+ console.log("Initialize succeeded");
38
+
39
+ console.log("isAddressValid (expected true)" + qcsdk.isAddressValid("0x6f605c4142f1cb037f967101a5b28ccd00b27cce4516190356baaf284d20e667")); //should print true
40
+ console.log("isAddressValid (expected true)" + qcsdk.isAddressValid("0X6F605C4142F1CB037F967101A5B28CCD00B27CCE4516190356BAAF284D20E667")); //should print true
41
+
42
+
43
+ //Get the account details
44
+ let address = "0x0000000000000000000000000000000000000000000000000000000000001000"; //Just an example address https://t4.scan.quantumcoin.org/account/0x0000000000000000000000000000000000000000000000000000000000001000
45
+
46
+ console.log("getAccountDetails " + address);
47
+ qcsdk.getAccountDetails(address).then((accountDetailsResult) => {
48
+ if (accountDetailsResult === null) {
49
+ console.error("getAccountDetails failed : accountDetailsResult is null");
50
+ return;
51
+ }
52
+
53
+ if (accountDetailsResult.resultCode !== 0) {
54
+ console.log("getAccountDetails failed. resultCode is " + accountDetailsResult.resultCode + " , requestId is " + accountDetailsResult.requestId);
55
+ return;
56
+ }
57
+
58
+ if (accountDetailsResult.accountDetails === null) {
59
+ console.error("getAccountDetails failed : accountDetails is null");
60
+ return;
61
+ }
62
+
63
+ console.log("getAccountDetails succeeded:");
64
+
65
+ console.log(" address: " + accountDetailsResult.accountDetails.address);
66
+
67
+ console.log(" balance (wei): " + accountDetailsResult.accountDetails.balance);
68
+ var etherValue = ethers.formatEther(accountDetailsResult.accountDetails.balance)
69
+ console.log(" balance coins (ether): " + etherValue);
70
+
71
+ console.log(" nonce: " + accountDetailsResult.accountDetails.nonce);
72
+
73
+ console.log(" as of blockNumber: " + accountDetailsResult.accountDetails.blockNumber);
74
+ });
75
+
76
+ //Get the transaction details
77
+ let txnHash = "0xe6fbabc178adaaab6b9dbda086de53deaced1d6fe40e7db9539fe9e85695d1be"; //Just an example transaction hash https://quantumscan.com/txn/0xe6fbabc178adaaab6b9dbda086de53deaced1d6fe40e7db9539fe9e85695d1be
78
+
79
+ console.log("getTransactionDetails " + txnHash);
80
+ qcsdk.getTransactionDetails(txnHash).then((transactionDetailsResult) => {
81
+ if (transactionDetailsResult === null) {
82
+ console.error("getTransactionDetails failed : transactionDetailsResult is null");
83
+ return;
84
+ }
85
+
86
+ if (transactionDetailsResult.resultCode !== 0) {
87
+ console.log("getTransactionDetails failed. resultCode is " + transactionDetailsResult.resultCode + " , requestId is " + transactionDetailsResult.requestId);
88
+ if (transactionDetailsResult.response !== null && transactionDetailsResult.response.status === 404) {
89
+ console.log("this transaction does not exist or has been discarded");
90
+ }
91
+ return;
92
+ }
93
+
94
+ if (transactionDetailsResult.transactionDetails === null) {
95
+ console.error("getTransactionDetails failed : transactionDetails is null");
96
+ return;
97
+ }
98
+
99
+ console.log(" blockHash " + transactionDetailsResult.transactionDetails.blockHash);
100
+ console.log(" blockNumber " + transactionDetailsResult.transactionDetails.blockNumber);
101
+ console.log(" from " + transactionDetailsResult.transactionDetails.from);
102
+ console.log(" gas " + transactionDetailsResult.transactionDetails.gas);
103
+ console.log(" gasPrice " + transactionDetailsResult.transactionDetails.gasPrice);
104
+ console.log(" hash " + transactionDetailsResult.transactionDetails.hash);
105
+ console.log(" input " + transactionDetailsResult.transactionDetails.input);
106
+ console.log(" nonce " + transactionDetailsResult.transactionDetails.nonce);
107
+ console.log(" to " + transactionDetailsResult.transactionDetails.to);
108
+ console.log(" value " + transactionDetailsResult.transactionDetails.value);
109
+
110
+ if (transactionDetailsResult.transactionDetails.receipt === null) {
111
+ console.log("transaction receipt is null. This indiciates the transaction is not yet registered in the blockchain. This transaction may be pending.")
112
+ } else {
113
+ console.log(" cumulativeGasUsed " + transactionDetailsResult.transactionDetails.receipt.cumulativeGasUsed);
114
+ console.log(" effectiveGasPrice " + transactionDetailsResult.transactionDetails.receipt.effectiveGasPrice);
115
+ console.log(" gasUsed " + transactionDetailsResult.transactionDetails.receipt.gasUsed);
116
+ console.log(" hash " + transactionDetailsResult.transactionDetails.receipt.hash);
117
+ console.log(" type " + transactionDetailsResult.transactionDetails.receipt.type);
118
+ console.log(" status " + transactionDetailsResult.transactionDetails.receipt.status);
119
+
120
+ if (transactionDetailsResult.transactionDetails.receipt.status === "0x1") {
121
+ console.log(" Transaction has succeeded!!!");
122
+ } else {
123
+ console.log(" Transaction has failed!!!");
124
+ }
125
+ }
126
+ });
127
+
128
+
129
+ //Get the latest block details
130
+ console.log("getLatestBlockDetails");
131
+ qcsdk.getLatestBlockDetails().then((latestBlockDetailsResult) => {
132
+ if (latestBlockDetailsResult === null) {
133
+ console.error(" getLatestBlockDetails failed : latestBlockDetailsResult is null");
134
+ return;
135
+ }
136
+
137
+ if (latestBlockDetailsResult.resultCode !== 0) {
138
+ console.log(" getLatestBlockDetails failed. resultCode is " + latestBlockDetailsResult.resultCode + " , requestId is " + latestBlockDetailsResult.requestId);
139
+ return;
140
+ }
141
+
142
+ if (latestBlockDetailsResult.blockDetails === null) {
143
+ console.error(" getLatestBlockDetails failed : blockDetails is null");
144
+ return;
145
+ }
146
+
147
+ console.log(" getLatestBlockDetails succeeded:");
148
+ console.log(" latest block number: " + latestBlockDetailsResult.blockDetails.blockNumber);
149
+ });
150
+
151
+
152
+ //Create a new wallet
153
+ var wallet1 = qcsdk.newWallet();
154
+ if (wallet1 === null) {
155
+ console.log("creating a new wallet failed");
156
+ return;
157
+ }
158
+ console.log("New wallet address is: " + wallet1.address);
159
+
160
+ //Serialize wallet to a string (You should encrypt the string before saving it to disk or a database.)
161
+ var walletJson = qcsdk.serializeWallet(wallet1);
162
+ if (walletJson === null) {
163
+ console.log("serializeWallet failed");
164
+ return;
165
+ }
166
+
167
+ //Deserialzie a wallet from the serialized wallet
168
+ var wallet2 = qcsdk.deserializeWallet(walletJson);
169
+ console.log("Deserialized wallet address is: " + wallet2.address);
170
+
171
+ //Validate that a wallet address is correct
172
+ console.log("isAddressValid (expected true)" + qcsdk.isAddressValid(wallet1.address)); //should print true
173
+ console.log("isAddressValid (expected false)" + qcsdk.isAddressValid("asfasdfasdfs")); //should print false
174
+
175
+ //Retrieve address from public key
176
+ let addressTemp = qcsdk.addressFromPublicKey(wallet2.publicKey);
177
+ console.log("addressFromPublicKey: " + addressTemp);
178
+ if (addressTemp !== wallet2.address) {
179
+ throw new Error("addressFromPublicKey doesn't match: " + addressTemp + " " + wallet2.publicKey);
180
+ }
181
+ return;
182
+
183
+ //Send coins
184
+ //First get account details nonce
185
+ console.log("sendCoins getAccountDetails " + address);
186
+ qcsdk.getAccountDetails(address).then((accountDetailsResult) => {
187
+ if (accountDetailsResult === null) {
188
+ console.error(" sendCoins getAccountDetails failed : accountDetailsResult is null");
189
+ return;
190
+ }
191
+
192
+ if (accountDetailsResult.resultCode !== 0) {
193
+ console.log(" sendCoins getAccountDetails failed. resultCode is " + accountDetailsResult.resultCode + " , requestId is " + accountDetailsResult.requestId);
194
+ return;
195
+ }
196
+
197
+ if (accountDetailsResult.accountDetails === null) {
198
+ console.error(" sendCoins getAccountDetails failed : accountDetails is null");
199
+ return;
200
+ }
201
+
202
+ var toAddress = "0x8293cd9b6ac502d2fe077b0c157dad39f36a5e546525b053151dced633634612";
203
+ var nonce = accountDetailsResult.accountDetails.nonce;
204
+ var coins = "10"; //in ethers and not in wei
205
+
206
+ console.log("Sending coins (wei) " + coins);
207
+ qcsdk.sendCoins(wallet2, toAddress, coins, nonce).then((sendResult) => { //carefully manage state of nonce when retrying on errors
208
+ if (sendResult === null) {
209
+ console.error(" sendCoins failed : sendResult is null");
210
+ return;
211
+ }
212
+
213
+ if (sendResult.resultCode !== 0) {
214
+ console.log(" sendCoins failed. resultCode is " + sendResult.resultCode);
215
+ if (sendResult.response !== null) {
216
+ console.log(" sendCoin response statusText " + JSON.stringify(sendResult.response.statusText));
217
+ console.log(" ensure account has adequate gas and nonce is correct");
218
+ }
219
+ return;
220
+ }
221
+
222
+ console.log(" sendCoin succeeded. This does not necessarily mean that the transaction has succeded. txnHash " + sendResult.txnHash);
223
+ });
224
+ });
225
+
226
+ //List transactions of an account
227
+ address = "0x0000000000000000000000000000000000000000000000000000000000002000";
228
+ let pageNumber = 0; //zero is default for latest page
229
+ qcsdk.listAccountTransactions(address, pageNumber).then((accountTransactionsResult) => {
230
+ if (accountTransactionsResult === null) {
231
+ console.error(" listAccountTransactions failed : accountTransactionsResult is null");
232
+ return;
233
+ }
234
+
235
+ if (accountTransactionsResult.resultCode !== 0) {
236
+ console.log(" listAccountTransactions failed. resultCode is " + accountTransactionsResult.resultCode + " , requestId is " + accountTransactionsResult.requestId);
237
+ console.log(accountTransactionsResult.response.status);
238
+ return;
239
+ }
240
+
241
+ if (accountTransactionsResult.listAccountTransactionsResponse === null) {
242
+ console.error(" listAccountTransactions failed : listAccountTransactionsResponse is null");
243
+ return;
244
+ }
245
+
246
+ if (accountTransactionsResult.listAccountTransactionsResponse.pageCount === null) {
247
+ console.error(" listAccountTransactions failed : pageCount is null");
248
+ return;
249
+ }
250
+
251
+ if (accountTransactionsResult.listAccountTransactionsResponse.items === null) {
252
+ console.error(" listAccountTransactions : items is null, no items to list");
253
+ return;
254
+ }
255
+
256
+ let txnList = accountTransactionsResult.listAccountTransactionsResponse.items;
257
+
258
+ console.log(" Account address: " + address);
259
+ console.log(" Page Count: " + accountTransactionsResult.listAccountTransactionsResponse.pageCount);
260
+ console.log(" Number of transactions returned: " + txnList.length);
261
+
262
+ for (const txn of txnList) {
263
+ console.log(" Transaction Hash: " + txn.hash);
264
+ console.log(" From Address: " + txn.from);
265
+ console.log(" To Address: " + txn.to);
266
+
267
+ let weiValueExample = BigInt(txn.value).toString(); //value is in hex. convert hex to wei
268
+ let ethValueExample = ethers.formatEther(weiValueExample); //convert wei to eth
269
+ console.log(" Value (hex): " + txn.value + " , (wei): " + weiValueExample + " , coins (eth): " + ethValueExample);
270
+
271
+ console.log(" Status: " + txn.status);
272
+ console.log(" Block Number: " + txn.blockNumber);
273
+ }
274
+
275
+ let pageCount = accountTransactionsResult.listAccountTransactionsResponse.pageCount;
276
+
277
+ //Enumerate and list all the pages
278
+ for (i = 1; i <= pageCount; i++) {
279
+ let pageNumber = i;
280
+ qcsdk.listAccountTransactions(address, pageNumber).then((txnListResult) => {
281
+ let txnList = txnListResult.listAccountTransactionsResponse.items;
282
+ for (const txn of txnList) {
283
+ console.log(" Transaction Hash: " + txn.hash + " pageNumber = " + pageNumber);
284
+ }
285
+ });
286
+ }
287
+ });
288
+
289
+ //Offline sign a transaction from existing wallet. This is typically called from an offline device hosting a cold storage wallet.
290
+ //Another usecase is to first store the signed transaction in a database and then later submit it using the postTransaction function.
291
+ let walletJsonExample = '{"address":"0xAB035828c5A9d240bB97c6136E4299150829c8dEa12908E85351e9dF6C379BB7","privateKey":"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","publicKey":"JEZUcaBrekkaFJIwX1H6/K6N+WNj3LOx8TVp5lWwgmb4qWncGvmGR762gNZFjp/xuTDjlC6drc4mG4+maUoqn8rGRr36EBvc8xxyRn10xklfxWDKNWf8pBcPvnLYy8H5SeA0LCsVJQemSun8WDYvk4fTFOglPvUuf2JvIYc1fBynVnGIuNI1wZ4I+7H/iSIPtsodSsBz3o79eLL2KKsiKHumU8cIx0iEYh3pBZqcQHe3oTywDHbA+sIGwpiqsw3MmTtIgELU2TNuYIMzIPsEzdEwBlh+oBZzDU0NkTe8Ll9MHB73baIAbzd4sSgLJd7yPCJOV0K2IiJygtZ5fYyGKFFt4OX4+WwO0oCihyHjigD8J3+XBZlCxzYi4VO3J/QGxf9+ITVKkwnoHhqXaw7bp3QhyFcfQLZXXOZ9e8sLGoBEQ/VU1CHrpe7VMuUA4BTO5/Ccv538PttQVxCGHpkNFNGk0Z8oZDRN7/genNi2QIM5uM07i0EsvOiw+iSJH+x615E+Ff8kyMxUA2zrDtyVVzbyOQyb8IkKxAI9RNqE4kpLCYaKCptPSueuUZX9JzI1aK4RM88zYIdJiquqdjgzlVAxfvHne9LCJp+NUECp0nuq0D6IJIg1oaYu7nXOVrImAm1XGMSQXxzdp9FbNkD4Hzxlm0ih/zbIw8pVI4RqtJrNf6Qeqbf6jeRvfzq9zUwm9mfeWZmLnnPyAG0XkJPKYGMAGbbWTL2uxm2zFSoSDR0zNLENi6xwaq5f8eQa+xYXF5rYxAchr83SHC6KUN+MX+IpLaRXjVxR7y6G+PUpVPaitUpIvLiHXzPdqTCQ7+xHkgcMo10CSGJjB+4HdEY3a7HPe/vqwFlPmRnr7CxXMHhLepmg71u1seI4fV69fHqsnfeKmdzL8XiB+djmUIZD/EXgoAx2rWhFt4a/csS/+w7owsE+QpWyYaDQidll7PDNuiYl8DyftuBUbDZ7BVwGb6vYGs7r8h6/iALRBoVdqGzb05OaFkZwUoAQBGBNKJgPRkfU6DNRpH4XIpcFgutE4aMWwk6sDpAri90fNgSgubFvZWPrztCTgQOgNdhbUlP2+jKC184Jsc3Sz62j+dGNk2muC/H0frCEGUYJetU2LfJ7mPI9gWbYWzFhXFWv2L4qOU6butU6X4hMDKScdcdPMniM1amn6JdF4rWTXNr4EkvXMh3NxFh60KHRFINMUljNtSsywg7+wVBYXHcShzR7ZnpF591QCwyJI5zuz/Fh9T7ucNsWWUIM9qeEeSu1wB/ZlyL7hQR2mKv9Axv1m4bPQsVzkldaIhVhToFr3NYANSVOGrYPwp0xtwZ1HeUQwD/Pj29uUXqb2acU80JqpsNtw5Ir1EtinKXpJ3lQec6jn+p2nFk3MlNPKw90cLRHg6QmllYVP4O+4ekNnvAVgNNs29Otf1Rh+3qfAKCSZdFged3fXgvTFigQD5tE+AFg9GNIkfnrZfq8G29OWKvbOlqNmogKOHQSHpcUODPiv/DwpbA9O04hCHoCIINZ0b8PxZNXaC/6+e2B6AkBMCnl9TZic4bNo+vs63ydTiuvJMSpWkbt2lnrJ7iKpiSAJ17ZBsXyZQCZ1+Zwe+HEBrA0hW02xVqy+dm3D0d1fnF5D+LdaUrH6UgaUy1bYI4KVq+LTOk2dC4nKkhVlYdG2JLtu16Olq/mpbLY/WeS3svKchXo69oq4lTogVxmc5DCl2gMHqVdK+v/4A7ObhCMftGKSD9BxXurBIhP5CQlYsEVO1tOagm0p7DcAI1O5QeKOCXgL1IrwNuW5gkuRM1MUyvKwnIl8FDBOVvzZRKfBSwAum4CEn6T+ja064ldZDigVACIWl9P9m9zmLXblWcZCi9e8ym+dg=="}';
292
+ let walletExample = qcsdk.deserializeWallet(walletJsonExample);
293
+
294
+ var toAddressExample = "0x8293cd9b6ac502d2fe077b0c157dad39f36a5e546525b053151dced633634612";
295
+ var nonceExample = 0;
296
+ var coinsExample = "10"; //in ethers and not in wei
297
+
298
+ qcsdk.signSendCoinTransaction(walletExample, toAddressExample, coinsExample, nonceExample).then((signResult) => {
299
+ console.log("signSendCoinTransaction resultCode: " + signResult.resultCode);
300
+ console.log("signSendCoinTransaction hash: " + signResult.txnHash);
301
+ console.log("signSendCoinTransaction txnData: " + signResult.txnData); //txnData is to be sent to postTransaction
302
+ });
303
+
304
+ //Post a transaction that was signed offline (output of signSendCoinTransaction)
305
+ let txnData = '0x00f90fbb8304bc348082520801a08293cd9b6ac502d2fe077b0c157dad39f36a5e546525b053151dced633634612888ac7230489e800008080c001b9058024465471a06b7a491a1492305f51fafcae8df96363dcb3b1f13569e655b08266f8a969dc1af98647beb680d6458e9ff1b930e3942e9dadce261b8fa6694a2a9fcac646bdfa101bdcf31c72467d74c6495fc560ca3567fca4170fbe72d8cbc1f949e0342c2b152507a64ae9fc58362f9387d314e8253ef52e7f626f2187357c1ca7567188b8d235c19e08fbb1ff89220fb6ca1d4ac073de8efd78b2f628ab22287ba653c708c74884621de9059a9c4077b7a13cb00c76c0fac206c298aab30dcc993b488042d4d9336e60833320fb04cdd13006587ea016730d4d0d9137bc2e5f4c1c1ef76da2006f3778b1280b25def23c224e5742b622227282d6797d8c8628516de0e5f8f96c0ed280a28721e38a00fc277f97059942c73622e153b727f406c5ff7e21354a9309e81e1a976b0edba77421c8571f40b6575ce67d7bcb0b1a804443f554d421eba5eed532e500e014cee7f09cbf9dfc3edb505710861e990d14d1a4d19f2864344deff81e9cd8b6408339b8cd3b8b412cbce8b0fa24891fec7ad7913e15ff24c8cc54036ceb0edc955736f2390c9bf0890ac4023d44da84e24a4b09868a0a9b4f4ae7ae5195fd27323568ae1133cf336087498aabaa7638339550317ef1e77bd2c2269f8d5040a9d27baad03e88248835a1a62eee75ce56b226026d5718c4905f1cdda7d15b3640f81f3c659b48a1ff36c8c3ca5523846ab49acd7fa41ea9b7fa8de46f7f3abdcd4c26f667de59998b9e73f2006d179093ca60630019b6d64cbdaec66db3152a120d1d3334b10d8bac706aae5ff1e41afb1617179ad8c40721afcdd21c2e8a50df8c5fe2292da4578d5c51ef2e86f8f52954f6a2b54a48bcb8875f33dda93090efec4792070ca35d0248626307ee077446376bb1cf7bfbeac0594f9919ebec2c5730784b7a99a0ef5bb5b1e2387d5ebd7c7aac9df78a99dccbf17881f9d8e6508643fc45e0a00c76ad6845b786bf72c4bffb0ee8c2c13e4295b261a0d089d965ecf0cdba2625f03c9fb6e0546c367b055c066fabd81aceebf21ebf8802d106855da86cdbd3939a16467052801004604d28980f4647d4e83351a47e1722970582eb44e1a316c24eac0e902b8bdd1f3604a0b9b16f6563ebced0938103a035d85b5253f6fa3282d7ce09b1cdd2cfada3f9d18d9369ae0bf1f47eb0841946097ad5362df27b98f23d8166d85b31615c55afd8be2a394e9bbad53a5f884c0ca49c75c74f32788cd5a9a7e89745e2b5935cdaf8124bd7321dcdc4587ad0a1d114834c5258cdb52b32c20efec150585c771287347b667a45e7dd500b0c89239ceecff161f53eee70db1659420cf6a784792bb5c01fd99722fb85047698abfd031bf59b86cf42c57392575a2215614e816bdcd60035254e1ab60fc29d31b706751de510c03fcf8f6f6e517a9bd9a714f3426aa6c36dc3922bd44b629ca5e927795079cea39fea769c593732534f2b0f7470b44783a4269656153f83bee1e90d9ef01580d36cdbd3ad7f5461fb7a9f00a09265d16079dddf5e0bd31628100f9b44f80160f4634891f9eb65fabc1b6f4e58abdb3a5a8d9a880a3874121e97143833e2bff0f0a5b03d3b4e21087a02208359d1bf0fc59357682ffaf9ed81e809013029e5f536627386cda3ebeceb7c9d4e2baf24c4a95a46edda59eb27b88aa62480275ed906c5f2650099d7e6707be1c406b034856d36c55ab2f9d9b70f47757e71790fe2dd694ac7e9481a532d5b608e0a56af8b4ce936742e272a4855958746d892edbb5e8e96afe6a5b2d8fd6792decbca7215e8ebda2ae254e8815c667390c297680c1ea55d2bebffe00ece6e108c7ed18a483f41c57bab04884fe4242562c1153b5b4e6a09b4a7b0dc008d4ee5078a3825e02f522bc0db96e6092e44cd4c532bcac27225f050c1395bf365129f052c00ba6e02127e93fa36b4eb895d6438a05400885a5f4ff66f7398b5db9567190a2f5ef329be76b909fe01202412c7a8a885c2f8630f91f10e64e6d2b76d72ee9c5384299c0996a6d42d98897de70ca4c2d10a399a9934fb08cb82642facf4d4e0dcd1c704400d72107fb603d844cad149577da3660bc6c70176cf1e737d475e200aa200e92f9c10fb09e1a0dcfb201c5d09492f1f22724c4611eda9b9888ddaf7d30a8d830229c34c3c80c33ce4bb95d99dcd3caaa8b398de0bb2f8d21096ef4950a0733c285943bc210043a0b42f6259c65f8bc558c0e6befc76fb5a986339911d58b14a18d8303275996944dc5f4035177b7fa826c1a4d3fa4dacaef89f10f8e55f05a912b1b6ce22b021dc2d4ad59c0fab7340f47a40dc2c39b07477925939cad57ad21dbce761bda1fb6c70f15621c9fb1e90e5a8552d43f9d9998bb7add63015e648b3d3c92ca1f097503d8406d974a49e4d7a070816c5bf965a18721fb8a001fecd5a77d2f07fab9398d4aae40294d6fd6631ce2b45848bb7adfc2a4efa60c848ae9ba8517e06cf5e5f3bfdc512c1e2b747ff7e94856db6e9a70c3aa98666ac7f5694b97561d10c192d28d679ea6916f94b2219925a8e16b753a66cc8d814ce2b7e3d06977951df8f59932bb9b976fdf8a33e92bb53f827347ffcbd912c50556467cbe9ff01ccba26c94a50e58c485edd7db5be95a2ad4335023d3b914337cbdb9a477b1c01025a44e0c3efb71368f90824c026346046ede03c90d21ab2ce636d0a93d7b8e76201f355946b05c30af17ad9770100f5994072de23f95009f6aaf5ae47aef2ccc4f754d54cdf3a1b8b7861ccb6bf76b2943fb729f58216e235e6440caad27c481ce397aa249575fb66ed38f742967551bf05e4876310612a112117282303bb539675757e9b9da6513890dffda231c93f84dc6980a93d4304c09a81b14701e40c21fecfd19ea69399372f634b6750dd4deee2eea2812745c47ba38ec7edea3a211fbeab29c3932f37ccb639b7aa79e011fcaff5a2310cc038cd58a5e24eed507104b6c90f87db1c8db6df2adfcb4a9f051109f7c1c31fec403b367e5b4990537517d343dc5a3fc3fd5061dfd0dd0032ffd937e4fd384105861306a7426bf2298ba7ecb7eee46cba8553377e3e6654e6ca66df1f1fa1823e03490d23fbbf3986b078cb5d6ce7227318f257972f1a81db2b401ded74603e51bc968cdcbede1baa89389e8e38d1ab379bb2f94e8a463889c502ab4d0b622c6f86265d1bd9a5d1b08c6a201a2859ecbf7a9414992273137d3370ed79274faf7d954c725aaf1632a1a5509147a54c6bcf7adc11848936e6b5e3e9aa367e924d03af4afb030dfe909df2670d37d8dc666d5cd6bae496137a90b07992f95519254dc47ba625d48a6d0d6af3ac2c29303260d9cc05821684e396a9e91046aa295bd8e25fbe09c25bb3339e83b41d796e339300952f1525404e61b14965c6bfd621eaaae713522482542da88b1c1d8af90979ae7668c052b74b35d0e7ebfce5f3b916ebfad838e9539e435eb5505aa119b34e61230557b8a4a501179e17640694b23a2caa09fb5526c8f8fc3c11ef333725c4d0310a3da932b91feb7e0c4284d4f4f5ff5e7c0a4fa5a18c2f1bd964ed3096375a21b3edab9f5c54e02387cdc2ad9894c8a3f4666b2d429ee46f8078529dc7af5ff3518d5e75d12c7f91cd7d7865e260ef33621c7a2c410821c81b1dd701cf4205d64a77bc77d5e715bb4554d465b2a1c03be9cc47fdcce0ce67ca8952ec5b0c7afb811931edd64e51bde041f220144b6d7bb06755a265d63314670bd262bc8dd9b806a35a059471f9fb50c97e2d4efefc3db51c4b31c279fa59b3377c32029be252c37f3eecf207545e5436cba14c4e4f5166dd6e7108b4c2c7ddb13e1f878888f4cfe9a921967ae2c732a9e317f417d5b4b5609d86f5bf685ae399ecedcef3acd1e81ec36a9638091f9ec3df3be493f71c27e2622d93cc4831a6898eb7542345f0bf23132e43bd80924e82df8ab0bc5113c61bf2c04c1ab142affa2ffd4eeda42e91f924852ff2b6606ec9d254ead8de534a90cc665e7ed6e457688f1c40a47ea690ab3974e280a74f696edad9f04c944ef664e453934faad8afff5f47d87a5b399d18f33de4288c7a3681980aaf92f34c9fdcac30c5a86801b9d04c6bb7482d351f8571d18d19991f63254b8f85ac8c9ea348a8afd5cda4c86d00aca6f482bb2bd616a20cbdd9d887a40baa32ebc44df867ab92a843da463ccfa5a7faa1222baafba19cfac9c50811eca087d5dbc2b895197420ba6874886270fe2c26d3f251f5bbf4a63c88ff7d9990439f573412eb2482a2099faf19d31ae0450081983390a1e1a73aad06e2913b52fc92388a995305e1b076a6057eadd4853a8f2b14075d27866c6fba28112791d8b5a42a8c5505cbe901eb1faeb72e0fb0f4de35d8e8cd0f5cf532368d4a49807ff9a80fff1a0dfbc5905b9636d3525c05200a2ca8bedcba9089534ac3e20575812f6d0a994ed4785d80daba4bb5bc48bd23928f37b955a951afb44730c829cc078ef2f878f371851fd67ba8884849d176f37390c6b3bc9990c260a706d40bb51e85514662fc77688a341fea074374c757ce4c67a0c069942935b31cb822c4df7d95c5589e6edeeb7830243175a0782ce2a5e31784a3acd60967384f76d991c53fbbdf98cd6cc8c52b76271077de9417d26b706b89db5f82abb33d61f39d83ee773698b77a7052555aad4f581bfbd7ce467229e4b0107d6c90961dffff4130c3baa5647c7115ba6060e4ccd3b7564ed7b859a2e288d41f63d259ac8a04e221a8102dad00d1cd4cc199875f4aafb11bb0a93479af32734a4a9dab9c78a319eed69e6b6229f201576c9a91e4aa4398499de51a7ecf6e54ec0eea3183adcd92ec657ab4a5e417944aaddd13df019ef419c74f9a9c7b39570e70eb289fd09f3c940b306e98f61643d66a9fc2d444c4d3b592e15ffe297e02ae8d50e3696933604a43b8fda8974d3558220b8626c17b65b46ef9b476f025612b194638387115812ecbdf62da668b28e04f71771ecb17a467e1db8cf2f700b7ed16f96f7d6bfdf586e217f7bdea69b33f3a3abb3d4c5d74088479544ca94ffff9c8b06a4d1d85a51bbcb6869726f180a3dc387633f0133fe56d409e6a65f51f887636db36a7892b42f755b734686ba9de501e19059d495fbb26826d0a4af1728e29c2d368da0f7a335c016d5045722d2eb1ecb6ebc0dd09606b7fb3998d828437982300a145d12b541ed0ccb1156e260cf94be043b1548c729bd3c0d2318a9bf0694709d93825fd00b988241ec284d1a7aa8008fd064669599781fb49a4936652658844d7f374fb9ebadd3153e8bc379c41774b985790bfa295ee47d4d04eff00cc623775bb42b32404597533ca28185b1fb5f0f39757081517188b0f2a2b4047485f8187b3bbcad0e7eff52d50567b8fb0cad5e2eefbfd2d435a7b7d9dacb4bdbec5d6e6f0002a4447484d5968829198b5b7d3dbe4fa000000000000000000000000000000000000000000101c2a3b46254236b647c19702639f4f6880a542bf7e06b3245ff77ef0c90a7cbb9e5b7c445bb99f059fa5db48bde3af7fef4da6ed6679417af85b683f859f9b4440a269061e5bddd3e3ee41';
306
+ qcsdk.postTransaction(txnData).then((sendResult) => {
307
+ if (sendResult === null) {
308
+ console.error(" postTransaction failed : sendResult is null");
309
+ return;
310
+ }
311
+
312
+ if (sendResult.resultCode !== 0) {
313
+ console.log(" postTransaction failed. resultCode is " + sendResult.resultCode + " , requestId is " + sendResult.requestId);
314
+ if (sendResult.response !== null) {
315
+ console.log(" postTransaction response statusText " + JSON.stringify(sendResult.response.statusText));
316
+ console.log(" postTransaction ensure account has adequate gas and nonce is correct");
317
+ }
318
+ return;
319
+ }
320
+
321
+ console.log(" postTransaction succeeded. This does not necessarily mean that the transaction has succeded. txnHash " + sendResult.txnHash);
322
+ });
323
+
324
+ //Open example wallet created using external wallet application such as Desktop/Web/CLI/Mobile wallet
325
+ const walletEncryptedJson1 = "{\"address\":\"1a846abe71c8b989e8337c55d608be81c28ab3b2e40c83eaa2a68d516049aec6\",\"crypto\":{\"cipher\":\"aes-256-ctr\",\"ciphertext\":\"ab7e620dd66cb55ac201b9c6796de92bbb06f3681b5932eabe099871f1f7d79acabe30921a39ad13bfe74f42c515734882b6723760142aa3e26e011df514a534ae47bd15d86badd9c6f17c48d4c892711d54d441ee3a0ee0e5b060f816e79c7badd13ff4c235934b1986774223ecf6e8761388969bb239c759b54c8c70e6a2e27c93a4b70129c8159f461d271ae8f3573414c78b88e4d0abfa6365ed45456636d4ed971c7a0c6b84e6f0c2621e819268b135e2bcc169a54d1847b39e6ba2ae8ec969b69f330b7db9e785ed02204d5a1185915ae5338b0f40ef2a7f4d5aaf7563d502135e57f4eb89d5ec1efa5c77e374969d6cd85be625a2ed1225d68ecdd84067bfc69adb83ecd5c6050472eca28a5a646fcdd28077165c629975bec8a79fe1457cb53389b788b25e1f8eff8b2ca326d7dfcaba3f8839225a08057c018a458891fd2caa0d2b27632cffd80f592147ccec9a10dc8a08a48fb55047bff5cf85cda39eb089096bef63842fc3686412f298a54a9e4b0bf4ad36907ba373cbd6d32e7ac494af371da5aa9d38a3463220865114c4adc5e4ac258ba9c6af9fa2ddfd1aec2e16887e4b3977c69561df8599ac9d411c9dd2a4d57f92ea4e5c02aae3f49fb3bc83e16673e6c2dbe96bb181c8dfd0f9757ade2e4ff27215a836058c5ffeab042f6f97c7c02339f76a6284680e01b4bb733690eb3347fbfcc26614b8bf755f9dfce3fea9d4e4d15b164983201732c2e87593a86bca6da6972e128490338f76ae68135888070f4e59e90db54d23834769bdbda9769213faf5357f9167a224523975a946367b68f0cec98658575609f58bfd329e420a921c06713326e4cb20a0df1d77f37e78a320a637a96c604ca3fa89e24beb42313751b8f09b14f9c14c77e4fd13fc6382505d27c771bca0d821ec7c3765acffa99d83c50140a56b0b28101c762bd682fe55cb6f23cbeb3f421d7b36021010e45ac27160dd7ead99c864a1b550c7edb1246950fe32dcc049799f9085287f0a747a6ef7a023df46a23a22f3e833bbf8d404f84344870492658256ee1dfc40fda33bb8d48fc72d4520ba9fc820c9123104a045206809037709f2a5f6723fa77d6bac5a573823d4ec3a7f1cb786a52ee2697e622e5d75962fa554d1024a6c355e21f33a63b2b72e6c4742a8b1c373aa532b40518c38c90b5373c2eb8c9d7be2a9e16047a3ee09dc9a6849deac5183ace6cfe91a9bef2ffc0a7df6ccebfd4c858c84b0e0355650d7466971e66f1e3883013e5ad1be33199b1d110b79070ac1b745ccb14cf63a08f8cca3a21c9525e626ff5f0c34746e10750fb742ad51f11f2acae3676c2111853d7250d01b77821a6ba9e04400ba2c543ca9f2d701ae6f47bfad14ffe3039ee9e71f7b2401359ade9938750ddb9c5a8b018a7929ed8d0e717ff1861446ce17535e9b17c187711190aae3388bd9490837a636c25ed4d42d7079ad1a51e13292c683d5d012abcf46965c534b83ab53f2c1f0cf5830ef7582e06863a33c19a70511df632885d63245965047ea96b56f1af5b3b94a54999f784fb9574fdfcd7c1230e07a2aaa04acd3097b2b9f8ddba05ae9734491deb5c1a513c76ed276cb78bbf4839dae3156d76af444a5805129d5df791167a9c8576a1d7f760b2d2797c4658669608706fbd0ace1be2346f74862dfc9ef518e55632e43c043186e5d070deb34d12fb9e5aba84e5cb50213dc88efd39cc35bf42455aa82d5e3b707b3140be3b8623b34fdd81d08615c188ae8438a13881fdf6bf32f2cb9ff5fa625561040c6b71d4b8eccc90bc3b99650d28dd1ee63773e49664e3d48c484996b290943635a6f2eb1ce9796d3fa144a3f00ef82faaa32d6a413668f7b521517cb68b2b017fcf56c79326fa5e4060e643631ca3f0a0dc0ed718798b6f46b130d437c33f64039e887324b6f5e604b1669d613923794edbf04b1b3caea54793b52b44b170173a4f25c7ecef3b71e2aad76e556b1cb9f1d637ec52ececfa950dd31dbb6a60828a3ad34c1beffe09eb4785786d63bad10a0b0f66ea88c57380f38ea85f018dbd7f538cf1ee7624095b9a01ec5edd528f281168af020609e651ff316aa1320a710134ddfca600cc72174dcdb846d2aa29916488aa1b537b66da92e61af526debef4eb38c984569eaf549ff2129449269b492d030cd74d885f6f5785881cc4804b4a8a09ba4ff7aefe9074ac7d0c4f05d51fe4cc0ff7388a772092b9d02d70e5433a5cf3e02f46a6bd6b818d59a07ce3b9fbbf8b5faba74563bcc5240930c2d406c9aaee3e3ce0429bf68ac2b0a57adb09414cff50817d2a48fb9fa624ab863cb0c31a8b8dc5eaf6fa68cc1d7c6c685c5a33edd5c8933b9e8ab628ee428d0743699b2ff17f25586c7ce959280bb0b8c5342251f0a30b53dbc7bf1ee426ac9619c3560f811f2268ee37f189794e2e4b3db3a2fb2e34b649e504fb467438abfd1082619cc4a0b30d66beb831077812e418d2e2148db10cf4d4a29101ca52ec445b8d83519dd7de85a98e0beae9ee537096d3f1a55a7a80cdfa93d25f07c9f98e8af18cde19ec1f99c5dd4588b717a5039ddb7f177717caf0d0fd45420a70dbd6d3146890d9e450d5224146db4c33b779e3c3a04b976c052bad042ac57dd38be45407808c0fb0d7e2a8819e6cd53c6739e6612996ddaa6f066552590aa0343bc1e62b298ff2514a0cef8be21956c2e942816f7a3a3a0935eaf9b37251409ce444c986c3817e82835555fe18239f3ae33469d7965c2bde9991fde556bd07af01df52bbde0c35bb4ef48e3b5d0db53f8ca4ed35b83f760f0a1bc4ed9f86e85d6039a17df373c85402ef956f01db00eb39c4b74bd0660d29ee746714d9780d738e05c6cca414ce3d7b40dda8036a9eea9ab1388805f913eb19bdd3f09d9e161eaa50231bd9caba61971f194332dd28c696a60458c1c6c2cc5da8b1192611c7c553e9e12fe48ce46bbb891be8bb118721c86222e671ddd1da8f0ccb2b68e02f2014b4925e904e88369aaf7466bd7033a60c265d45955944916ecbdb84bf1b522b01b0149c632e04c568a7eb627c5bb90ece052ebcf79166c28b30d23fe52da0a5ab5dea83ca479a3e3b7a9cfbbfea04dbe6137c19d067317c2ec427a8c75a6b06bec6dcd5d5c0edc9aa80b9003b8e17c088b2f3db327d3e42630d82d20120240c3ba56232280787da4aabbf5bc95a864029f00710e195f2a76460a0317d10b552fe1bea097e41d49756c680a41d6ac186e62169b6b6cd7776ea84618b5b752328a5bacaa10aa122ff9b2698b43efe73d852a899db644863c8c9bc8068ea86ea843fd6fe36272b91cdc5d5317083ef3fd1e5462a0b0d0604dc57b3bbfceb0fca4cd349625dd7b25166af30efe5ee6a0af953a74d65f4736c59918ee55a3b0d9d9d42e04c7f8a77e479109f740e20c464d5d7e3d16805f47b61f403ff7f408c9e850d9baacd8067e544536a4953480b0f9ee9cd45f41ebd67b51f78788a6470cb1e5ca72ca346ce8a50d0ca0c921d5576a4455a1afb6d0bc688004712ee122cacdb29c51e84893324c27fa4a3f1917edf5352272b4c97579a6152e4b77663d0ab532915f2eeb6a862de8b696452321b660c3f2449673d086e95a7af28845a5259b763e0fcd09f72acf7b6c811066263060e5aa5b24658e880a01fd56bda4dad5ab604e129290f7d5489728f2a40968c6168b21cebbbcd11727cc9e9160c4e92e04387d3b0d62aab06a61f26daedd9fed11816ef2180172a47f47184ac4032b88758c98a2e0fb200f70e93ba695f5ebb7a1029610ad360d3b7fa1b4640b9dc674d3625eef786da93dff19bc7991b5d6193a3896664763fde479b5dfc04812111a80782854f2cf68ca7d82765cc9eb40fba4b44640710ed6e653abf9f07b466333f4fd22784d53cf40e17120f42caa841eaa24056b237827b0f47f7257c103c35027e9f503e5acfd023e7357b600d3084d361d5ee65ba319b45c153212a54e6fed85af7e43e0a926ebcbc2edf8de7e2ec9528f00bec262ad04d5c9dafccaea06a24748d28bf1799bae0e895543084539c50b5aaa4fb50d7431d6f0c8cee2a54aaf7ee7919b55bf40adb688632e5dbe273cea09e97b19c3d8e1f4de000deb66fa1942ad03a62d3252f51992244366c156000b49c297167a6cbdedea7ebae139d295f0ad298e0864249b905b7eb812886ec70ecdb286702274b5b8574149bf3866f9e46b997ff5ed622b169a0eb071347f18d530db1663906a28f4544ee4e004ab87b65476af30ede118052ff052b8dc986ca2c93dd5d4943266a579c7698ea014f688b3e8063a107feb162d392e2177b01bff77fb5abe5feebd0607158049a5a093325b7c9ee6b4dfa7a9f65c7c2fb628920d3603a1c2dad979eaa047cd661a268af1078c9788d720e64e4ce9d12e68de1e417ef2f293323681e1071f9220e1ee43d2e29d111b870ce3439f5100ecd4551ab65ee74aa1667e564957e9bc0ae1ea193980da2a0ec2698073388c85bec25ef447f0d5e93a5203fa44dff268e5cb799ed3b66e63d5e07b487e7534f24934c73a62a243e0151843a0fd3807711a101eaa7fc71f0ba68aebb9534d57cba41b094eebfb4c31cca8eddfa426f676aa347be8a7023a4e91ddb154b35cd4d5f7dbc2e5db491de99f33fc2cff2d57029ac950e1ccd681980af6a4e8969dfe39b3c7bfcbcf8fac92f1e6ec9fe572bfa6a7d65860eab2ed10ac01a71290b52e3148e84b7376a8605cd2bb0e8681ffc54691ce087685e33921bd44d36c78291713dce17569570f62137e6904f0d68cf53aa2ec395c389a75141f08114fb293ea63950e4ffee55ec6fc83cf44876b8e7f25cdd393ff87b9eda6eb746085b61a6900de191f0ce2cb388d61ece52e78bc47368194e8e00277e0d1631e6b9d4626ef76f8522582ccd5a40be3febc699bb510acc6271d55ff0f4cf3bb7669855a72efd9ca3e1056a2fe592a5bc877cce2b1f63b58383971da87873d2d1349cf5881242cdce4e7e2c5c514755746a0e0a7c2a6d9701cde005ae3420beb17c379a3516662253554f51f0423bb1844b0b90c54ed8177ceb0e1036a6609d836e748ca06c40ca64befadc6443ec286a0ce464678e8d11eb455f7bb305acebf6cb1f50e394a9bfeb752df1687831bac9cdd811f4f112ef6658d0f8799a866374ff96c5e2b79f30e7a74f8a2bc9ed1f88f01f30e30cb78ffb2bff10108f35e910ee3be4463e9e6f0ed910e8d598326e71dfa2277ffe5579d7fe9b6018bfe295b25219eae07b3b0270665c3fa00c3e0d180812b5cd62925585de84a7c48a9a86dba96544a251654d1966e082432dc85b6149cf21e91a46020ec32b66d28ba3b6a90c0617bc6fdd55aea819af2bcf84864ad60c28fe3c9f8339d0aee68b39d97f63b6e082835d86119cf9b9fdc8b827c847ce40aa10e1577a710132316845e825345e95bdf94d0c66ec65a6c4319fce4792313663b5f7a651a6710783e6ab71608ac6cbbf3af6911adf596ccf7c172b9bd5bceb6db379967b32b143bdd11d2ee12ddf64ecef6391e0f8570e6cddd3db95204919362b89b739fa94e7c1bfde799fd5e22aa25ca6ca42e30c08e23aae2385d99ebab441072a880dcefdab74a4c9bd39d363f6d1933d59400fca161d432aa00f23b1b1c19a154be8989699d549b66d44e39896f5523443bc6ddf4a65e91f1f3fb7b52318869a05856a4fc92f3694c81ed833c972fb918f7e5\",\"cipherparams\":{\"iv\":\"8c46d6162cd4c765759aedcbce2a5874\"},\"kdf\":\"scrypt\",\"kdfparams\":{\"dklen\":32,\"n\":262144,\"p\":1,\"r\":8,\"salt\":\"82fb6cdc6917609135277badacf15baa31899d08b71a5a0fa33167167c161537\"},\"mac\":\"9187b17f7eca48e6b8c586b0cd790dbe0feb876ac8385f93faa7d5e22a3c8fc7\"},\"id\":\"92caf6ee-2d43-48c0-859e-ffa1e0e23312\",\"version\":3}";
326
+ const examplePassphrase = "QuantumCoinExample123!";
327
+ let walletObj1 = qcsdk.deserializeEncryptedWallet(walletEncryptedJson1, examplePassphrase);
328
+ if (walletObj1 === null) {
329
+ throw new Error("deserializeEncryptedWallet failed");
330
+ }
331
+ if (walletObj1.address.toLowerCase() !== "0x1a846ABE71C8B989e8337c55d608Be81C28Ab3b2e40c83eaA2A68D516049AeC6".toLowerCase()) {
332
+ throw new Error("deserializeEncryptedWallet address check failed");
333
+ }
334
+ console.log("wallet address from deserializeEncryptedWallet is " + walletObj1.address);
335
+
336
+ //Save to an encrypted wallet that can then be restored into an external wallet application such as Desktop/Web/CLI/Mobile wallet
337
+ let walletObj2 = qcsdk.newWallet();
338
+ let walletEncryptedJson2 = qcsdk.serializeEncryptedWallet(walletObj2, examplePassphrase);
339
+ if (walletEncryptedJson2 === null) {
340
+ throw new Error("serializeEncryptedWallet failed");
341
+ }
342
+ console.log("Serialized wallet: " + walletEncryptedJson2); //just an example for demonstration, do not actually log to console
343
+
344
+ //Try opening the same wallet again
345
+ let walletObj3 = qcsdk.deserializeEncryptedWallet(walletEncryptedJson2, examplePassphrase);
346
+ if (walletObj3 === null) {
347
+ throw new Error("deserializeEncryptedWallet failed");
348
+ }
349
+
350
+ if (walletObj2.address.toLowerCase() !== walletObj3.address.toLowerCase()) {
351
+ throw new Error("deserializeEncryptedWallet address check failed");
352
+ }
353
+
354
+ //Sign a transaction from a deserialized wallet (1)
355
+ qcsdk.signSendCoinTransaction(walletObj1, toAddressExample, coinsExample, nonceExample).then((signResult) => {
356
+ console.log("signSendCoinTransaction walletObj1 resultCode: " + signResult.resultCode);
357
+ console.log("signSendCoinTransaction walletObj1 hash: " + signResult.txnHash);
358
+ console.log("signSendCoinTransaction walletObj1 txnData: " + signResult.txnData); //txnData is to be sent to postTransaction
359
+ });
360
+
361
+ //Sign a transaction from a deserialized wallet (3)
362
+ qcsdk.signSendCoinTransaction(walletObj1, toAddressExample, coinsExample, nonceExample).then((signResult) => {
363
+ console.log("signSendCoinTransaction walletObj3 resultCode: " + signResult.resultCode);
364
+ console.log("signSendCoinTransaction walletObj3 hash: " + signResult.txnHash);
365
+ console.log("signSendCoinTransaction walletObj3 txnData: " + signResult.txnData); //txnData is to be sent to postTransaction
366
+ });
367
+
368
+ //Create a new seed word list
369
+ let seedWords = qcsdk.newWalletSeedWords();
370
+ if (seedWords === null) {
371
+ console.error("newWalletSeedWords failed");
372
+ return;
373
+ }
374
+ console.log ("SeedWords: " + seedWords);
375
+
376
+ //Open a wallet from seed words
377
+ let seedWallet = qcsdk.openWalletFromSeedWords(seedWords);
378
+ if (seedWallet === null) {
379
+ console.error("openWalletFromSeedWords failed");
380
+ return;
381
+ }
382
+ console.log("seedWallet address: " + seedWallet.address);
383
+
384
+ //Open a wallet from seed words static
385
+ let seedWordList = "servetize,redmation,suaveton,dreadtolk,rondial,pondicle,miscoil,teaguery,dylodecid,portnel,mantical,slapware,sluthike,tactise,crierial,tajluvki,pranicum,sockcup,stacksong,duerling,genogram,peasate,pulubly,skimpop,feldtail,saprostal,crabrock,radiment,dolocsin,strigemen,juryeuk,fextial,merunized,tangienti,stylocyte,plumvieve,bobstike,nosecrown,acudemy,gripstick,lacreous,marculade,sporculum,outslope,bioburden,trompong,sidelay,finchage";
386
+ let seedWordArray = seedWordList.split(",");
387
+ let seedWallet2 = qcsdk.openWalletFromSeedWords(seedWordArray);
388
+ if (seedWallet2 === null) {
389
+ console.error("openWalletFromSeedWords failed");
390
+ return;
391
+ }
392
+ if (seedWallet2.address !== "0xc7C24aE0Db614F1638C5161e823A539a0293238366d4EaF29A63316D631e964F") {
393
+ console.error("seedWallet2 check failed");
394
+ return;
395
+ }
396
+ console.log("seedWallet2 address: " + seedWallet2.address);
397
+
398
+ //Sign a transaction from a wallet created from seed words
399
+ qcsdk.signSendCoinTransaction(seedWallet, toAddressExample, coinsExample, nonceExample).then((signResult) => {
400
+ console.log("signSendCoinTransaction seedWallet resultCode: " + signResult.resultCode);
401
+ console.log("signSendCoinTransaction seedWallet hash: " + signResult.txnHash);
402
+ console.log("signSendCoinTransaction seedWallet txnData: " + signResult.txnData); //txnData is to be sent to postTransaction
403
+ });
404
+ });
405
+