From a68740b3652caa6e8803ffea0f747389adf23a58 Mon Sep 17 00:00:00 2001 From: Pieter Pretorius Date: Sun, 12 Nov 2023 17:56:48 +0200 Subject: [PATCH] feat: adding deeplink converter --- docs/assets/highlight.css | 64 ++++++--- docs/assets/search.js | 2 +- docs/classes/Random.html | 8 +- docs/classes/SignX.html | 68 ++++----- docs/functions/convertDataToDeeplink.html | 69 +++++++++ docs/functions/generateSecureHash.html | 13 +- docs/functions/hashTransactData.html | 13 +- docs/index.html | 150 +++++++++++++++++++- docs/modules.html | 12 +- docs/variables/SIGN_X_LOGIN.html | 11 +- docs/variables/SIGN_X_LOGIN_ERROR.html | 11 +- docs/variables/SIGN_X_LOGIN_SUCCESS.html | 11 +- docs/variables/SIGN_X_TRANSACT.html | 11 +- docs/variables/SIGN_X_TRANSACT_ERROR.html | 11 +- docs/variables/SIGN_X_TRANSACT_SUCCESS.html | 11 +- docs/variables/VERSION.html | 11 +- package.json | 148 +++++++++---------- src/client.ts | 75 +++++++--- src/types/transact.ts | 20 ++- src/utils/encoding.ts | 46 +++++- types/client.d.ts | 24 +--- types/types/transact.d.ts | 18 ++- types/utils/encoding.d.ts | 5 +- 23 files changed, 580 insertions(+), 232 deletions(-) create mode 100644 docs/functions/convertDataToDeeplink.html diff --git a/docs/assets/highlight.css b/docs/assets/highlight.css index 63c0fd4..7859319 100644 --- a/docs/assets/highlight.css +++ b/docs/assets/highlight.css @@ -1,22 +1,30 @@ :root { - --light-hl-0: #0000FF; - --dark-hl-0: #569CD6; - --light-hl-1: #000000; - --dark-hl-1: #D4D4D4; - --light-hl-2: #0070C1; - --dark-hl-2: #4FC1FF; - --light-hl-3: #795E26; - --dark-hl-3: #DCDCAA; - --light-hl-4: #A31515; - --dark-hl-4: #CE9178; - --light-hl-5: #008000; - --dark-hl-5: #6A9955; - --light-hl-6: #001080; - --dark-hl-6: #9CDCFE; - --light-hl-7: #098658; - --dark-hl-7: #B5CEA8; - --light-hl-8: #AF00DB; - --dark-hl-8: #C586C0; + --light-hl-0: #000000; + --dark-hl-0: #D4D4D4; + --light-hl-1: #A31515; + --dark-hl-1: #CE9178; + --light-hl-2: #AF00DB; + --dark-hl-2: #C586C0; + --light-hl-3: #001080; + --dark-hl-3: #9CDCFE; + --light-hl-4: #0000FF; + --dark-hl-4: #569CD6; + --light-hl-5: #0070C1; + --dark-hl-5: #4FC1FF; + --light-hl-6: #795E26; + --dark-hl-6: #DCDCAA; + --light-hl-7: #008000; + --dark-hl-7: #6A9955; + --light-hl-8: #267F99; + --dark-hl-8: #4EC9B0; + --light-hl-9: #098658; + --dark-hl-9: #B5CEA8; + --light-hl-10: #800000; + --dark-hl-10: #808080; + --light-hl-11: #E50000; + --dark-hl-11: #9CDCFE; + --light-hl-12: #000000FF; + --dark-hl-12: #D4D4D4; --light-code-background: #FFFFFF; --dark-code-background: #1E1E1E; } @@ -31,6 +39,10 @@ --hl-6: var(--light-hl-6); --hl-7: var(--light-hl-7); --hl-8: var(--light-hl-8); + --hl-9: var(--light-hl-9); + --hl-10: var(--light-hl-10); + --hl-11: var(--light-hl-11); + --hl-12: var(--light-hl-12); --code-background: var(--light-code-background); } } @@ -44,6 +56,10 @@ --hl-6: var(--dark-hl-6); --hl-7: var(--dark-hl-7); --hl-8: var(--dark-hl-8); + --hl-9: var(--dark-hl-9); + --hl-10: var(--dark-hl-10); + --hl-11: var(--dark-hl-11); + --hl-12: var(--dark-hl-12); --code-background: var(--dark-code-background); } } @@ -57,6 +73,10 @@ --hl-6: var(--light-hl-6); --hl-7: var(--light-hl-7); --hl-8: var(--light-hl-8); + --hl-9: var(--light-hl-9); + --hl-10: var(--light-hl-10); + --hl-11: var(--light-hl-11); + --hl-12: var(--light-hl-12); --code-background: var(--light-code-background); } @@ -70,6 +90,10 @@ --hl-6: var(--dark-hl-6); --hl-7: var(--dark-hl-7); --hl-8: var(--dark-hl-8); + --hl-9: var(--dark-hl-9); + --hl-10: var(--dark-hl-10); + --hl-11: var(--dark-hl-11); + --hl-12: var(--dark-hl-12); --code-background: var(--dark-code-background); } @@ -82,4 +106,8 @@ .hl-6 { color: var(--hl-6); } .hl-7 { color: var(--hl-7); } .hl-8 { color: var(--hl-8); } +.hl-9 { color: var(--hl-9); } +.hl-10 { color: var(--hl-10); } +.hl-11 { color: var(--hl-11); } +.hl-12 { color: var(--hl-12); } pre, code { background: var(--code-background); } diff --git a/docs/assets/search.js b/docs/assets/search.js index d8181c3..dbae5bb 100644 --- a/docs/assets/search.js +++ b/docs/assets/search.js @@ -1 +1 @@ -window.searchData = JSON.parse("{\"kinds\":{\"32\":\"Variable\",\"64\":\"Function\",\"128\":\"Class\",\"512\":\"Constructor\",\"1024\":\"Property\",\"2048\":\"Method\"},\"rows\":[{\"kind\":128,\"name\":\"SignX\",\"url\":\"classes/SignX.html\",\"classes\":\"tsd-kind-class\"},{\"kind\":512,\"name\":\"constructor\",\"url\":\"classes/SignX.html#constructor\",\"classes\":\"tsd-kind-constructor tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"timeout\",\"url\":\"classes/SignX.html#timeout\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"pollingInterval\",\"url\":\"classes/SignX.html#pollingInterval\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"network\",\"url\":\"classes/SignX.html#network\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"endpoint\",\"url\":\"classes/SignX.html#endpoint\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"sitename\",\"url\":\"classes/SignX.html#sitename\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"pollingTimeout\",\"url\":\"classes/SignX.html#pollingTimeout\",\"classes\":\"tsd-kind-property tsd-parent-kind-class tsd-is-private\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"generateRandomHash\",\"url\":\"classes/SignX.html#generateRandomHash\",\"classes\":\"tsd-kind-method tsd-parent-kind-class tsd-is-private\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"login\",\"url\":\"classes/SignX.html#login\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"transact\",\"url\":\"classes/SignX.html#transact\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"startPolling\",\"url\":\"classes/SignX.html#startPolling\",\"classes\":\"tsd-kind-method tsd-parent-kind-class tsd-is-private\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"stopPolling\",\"url\":\"classes/SignX.html#stopPolling\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":32,\"name\":\"SIGN_X_LOGIN\",\"url\":\"variables/SIGN_X_LOGIN.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_LOGIN_SUCCESS\",\"url\":\"variables/SIGN_X_LOGIN_SUCCESS.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_LOGIN_ERROR\",\"url\":\"variables/SIGN_X_LOGIN_ERROR.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_TRANSACT\",\"url\":\"variables/SIGN_X_TRANSACT.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_TRANSACT_SUCCESS\",\"url\":\"variables/SIGN_X_TRANSACT_SUCCESS.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_TRANSACT_ERROR\",\"url\":\"variables/SIGN_X_TRANSACT_ERROR.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"VERSION\",\"url\":\"variables/VERSION.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":64,\"name\":\"hashTransactData\",\"url\":\"functions/hashTransactData.html\",\"classes\":\"tsd-kind-function\"},{\"kind\":64,\"name\":\"generateSecureHash\",\"url\":\"functions/generateSecureHash.html\",\"classes\":\"tsd-kind-function\"},{\"kind\":128,\"name\":\"Random\",\"url\":\"classes/Random.html\",\"classes\":\"tsd-kind-class\"},{\"kind\":2048,\"name\":\"getBytes\",\"url\":\"classes/Random.html#getBytes\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"Random\"},{\"kind\":2048,\"name\":\"getHex\",\"url\":\"classes/Random.html#getHex\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"Random\"},{\"kind\":512,\"name\":\"constructor\",\"url\":\"classes/Random.html#constructor\",\"classes\":\"tsd-kind-constructor tsd-parent-kind-class\",\"parent\":\"Random\"}],\"index\":{\"version\":\"2.3.9\",\"fields\":[\"name\",\"comment\"],\"fieldVectors\":[[\"name/0\",[0,28.904]],[\"comment/0\",[]],[\"name/1\",[1,23.795]],[\"comment/1\",[]],[\"name/2\",[2,28.904]],[\"comment/2\",[]],[\"name/3\",[3,28.904]],[\"comment/3\",[]],[\"name/4\",[4,28.904]],[\"comment/4\",[]],[\"name/5\",[5,28.904]],[\"comment/5\",[]],[\"name/6\",[6,28.904]],[\"comment/6\",[]],[\"name/7\",[7,28.904]],[\"comment/7\",[]],[\"name/8\",[8,28.904]],[\"comment/8\",[]],[\"name/9\",[9,28.904]],[\"comment/9\",[]],[\"name/10\",[10,28.904]],[\"comment/10\",[]],[\"name/11\",[11,28.904]],[\"comment/11\",[]],[\"name/12\",[12,28.904]],[\"comment/12\",[]],[\"name/13\",[13,28.904]],[\"comment/13\",[]],[\"name/14\",[14,28.904]],[\"comment/14\",[]],[\"name/15\",[15,28.904]],[\"comment/15\",[]],[\"name/16\",[16,28.904]],[\"comment/16\",[]],[\"name/17\",[17,28.904]],[\"comment/17\",[]],[\"name/18\",[18,28.904]],[\"comment/18\",[]],[\"name/19\",[19,28.904]],[\"comment/19\",[]],[\"name/20\",[20,28.904]],[\"comment/20\",[]],[\"name/21\",[21,28.904]],[\"comment/21\",[]],[\"name/22\",[22,28.904]],[\"comment/22\",[]],[\"name/23\",[23,28.904]],[\"comment/23\",[]],[\"name/24\",[24,28.904]],[\"comment/24\",[]],[\"name/25\",[1,23.795]],[\"comment/25\",[]]],\"invertedIndex\":[[\"constructor\",{\"_index\":1,\"name\":{\"1\":{},\"25\":{}},\"comment\":{}}],[\"endpoint\",{\"_index\":5,\"name\":{\"5\":{}},\"comment\":{}}],[\"generaterandomhash\",{\"_index\":8,\"name\":{\"8\":{}},\"comment\":{}}],[\"generatesecurehash\",{\"_index\":21,\"name\":{\"21\":{}},\"comment\":{}}],[\"getbytes\",{\"_index\":23,\"name\":{\"23\":{}},\"comment\":{}}],[\"gethex\",{\"_index\":24,\"name\":{\"24\":{}},\"comment\":{}}],[\"hashtransactdata\",{\"_index\":20,\"name\":{\"20\":{}},\"comment\":{}}],[\"login\",{\"_index\":9,\"name\":{\"9\":{}},\"comment\":{}}],[\"network\",{\"_index\":4,\"name\":{\"4\":{}},\"comment\":{}}],[\"pollinginterval\",{\"_index\":3,\"name\":{\"3\":{}},\"comment\":{}}],[\"pollingtimeout\",{\"_index\":7,\"name\":{\"7\":{}},\"comment\":{}}],[\"random\",{\"_index\":22,\"name\":{\"22\":{}},\"comment\":{}}],[\"sign_x_login\",{\"_index\":13,\"name\":{\"13\":{}},\"comment\":{}}],[\"sign_x_login_error\",{\"_index\":15,\"name\":{\"15\":{}},\"comment\":{}}],[\"sign_x_login_success\",{\"_index\":14,\"name\":{\"14\":{}},\"comment\":{}}],[\"sign_x_transact\",{\"_index\":16,\"name\":{\"16\":{}},\"comment\":{}}],[\"sign_x_transact_error\",{\"_index\":18,\"name\":{\"18\":{}},\"comment\":{}}],[\"sign_x_transact_success\",{\"_index\":17,\"name\":{\"17\":{}},\"comment\":{}}],[\"signx\",{\"_index\":0,\"name\":{\"0\":{}},\"comment\":{}}],[\"sitename\",{\"_index\":6,\"name\":{\"6\":{}},\"comment\":{}}],[\"startpolling\",{\"_index\":11,\"name\":{\"11\":{}},\"comment\":{}}],[\"stoppolling\",{\"_index\":12,\"name\":{\"12\":{}},\"comment\":{}}],[\"timeout\",{\"_index\":2,\"name\":{\"2\":{}},\"comment\":{}}],[\"transact\",{\"_index\":10,\"name\":{\"10\":{}},\"comment\":{}}],[\"version\",{\"_index\":19,\"name\":{\"19\":{}},\"comment\":{}}]],\"pipeline\":[]}}"); \ No newline at end of file +window.searchData = JSON.parse("{\"kinds\":{\"32\":\"Variable\",\"64\":\"Function\",\"128\":\"Class\",\"512\":\"Constructor\",\"1024\":\"Property\",\"2048\":\"Method\"},\"rows\":[{\"kind\":128,\"name\":\"SignX\",\"url\":\"classes/SignX.html\",\"classes\":\"tsd-kind-class\"},{\"kind\":512,\"name\":\"constructor\",\"url\":\"classes/SignX.html#constructor\",\"classes\":\"tsd-kind-constructor tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"timeout\",\"url\":\"classes/SignX.html#timeout\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"pollingInterval\",\"url\":\"classes/SignX.html#pollingInterval\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"network\",\"url\":\"classes/SignX.html#network\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"endpoint\",\"url\":\"classes/SignX.html#endpoint\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"sitename\",\"url\":\"classes/SignX.html#sitename\",\"classes\":\"tsd-kind-property tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":1024,\"name\":\"pollingTimeout\",\"url\":\"classes/SignX.html#pollingTimeout\",\"classes\":\"tsd-kind-property tsd-parent-kind-class tsd-is-private\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"generateRandomHash\",\"url\":\"classes/SignX.html#generateRandomHash\",\"classes\":\"tsd-kind-method tsd-parent-kind-class tsd-is-private\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"login\",\"url\":\"classes/SignX.html#login\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"transact\",\"url\":\"classes/SignX.html#transact\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"startPolling\",\"url\":\"classes/SignX.html#startPolling\",\"classes\":\"tsd-kind-method tsd-parent-kind-class tsd-is-private\",\"parent\":\"SignX\"},{\"kind\":2048,\"name\":\"stopPolling\",\"url\":\"classes/SignX.html#stopPolling\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"SignX\"},{\"kind\":32,\"name\":\"SIGN_X_LOGIN\",\"url\":\"variables/SIGN_X_LOGIN.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_LOGIN_SUCCESS\",\"url\":\"variables/SIGN_X_LOGIN_SUCCESS.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_LOGIN_ERROR\",\"url\":\"variables/SIGN_X_LOGIN_ERROR.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_TRANSACT\",\"url\":\"variables/SIGN_X_TRANSACT.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_TRANSACT_SUCCESS\",\"url\":\"variables/SIGN_X_TRANSACT_SUCCESS.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"SIGN_X_TRANSACT_ERROR\",\"url\":\"variables/SIGN_X_TRANSACT_ERROR.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":32,\"name\":\"VERSION\",\"url\":\"variables/VERSION.html\",\"classes\":\"tsd-kind-variable\"},{\"kind\":64,\"name\":\"hashTransactData\",\"url\":\"functions/hashTransactData.html\",\"classes\":\"tsd-kind-function\"},{\"kind\":64,\"name\":\"generateSecureHash\",\"url\":\"functions/generateSecureHash.html\",\"classes\":\"tsd-kind-function\"},{\"kind\":64,\"name\":\"convertDataToDeeplink\",\"url\":\"functions/convertDataToDeeplink.html\",\"classes\":\"tsd-kind-function\"},{\"kind\":128,\"name\":\"Random\",\"url\":\"classes/Random.html\",\"classes\":\"tsd-kind-class\"},{\"kind\":2048,\"name\":\"getBytes\",\"url\":\"classes/Random.html#getBytes\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"Random\"},{\"kind\":2048,\"name\":\"getHex\",\"url\":\"classes/Random.html#getHex\",\"classes\":\"tsd-kind-method tsd-parent-kind-class\",\"parent\":\"Random\"},{\"kind\":512,\"name\":\"constructor\",\"url\":\"classes/Random.html#constructor\",\"classes\":\"tsd-kind-constructor tsd-parent-kind-class\",\"parent\":\"Random\"}],\"index\":{\"version\":\"2.3.9\",\"fields\":[\"name\",\"comment\"],\"fieldVectors\":[[\"name/0\",[0,29.267]],[\"comment/0\",[]],[\"name/1\",[1,24.159]],[\"comment/1\",[]],[\"name/2\",[2,29.267]],[\"comment/2\",[]],[\"name/3\",[3,29.267]],[\"comment/3\",[]],[\"name/4\",[4,29.267]],[\"comment/4\",[]],[\"name/5\",[5,29.267]],[\"comment/5\",[]],[\"name/6\",[6,29.267]],[\"comment/6\",[]],[\"name/7\",[7,29.267]],[\"comment/7\",[]],[\"name/8\",[8,29.267]],[\"comment/8\",[]],[\"name/9\",[9,29.267]],[\"comment/9\",[]],[\"name/10\",[10,29.267]],[\"comment/10\",[]],[\"name/11\",[11,29.267]],[\"comment/11\",[]],[\"name/12\",[12,29.267]],[\"comment/12\",[]],[\"name/13\",[13,29.267]],[\"comment/13\",[]],[\"name/14\",[14,29.267]],[\"comment/14\",[]],[\"name/15\",[15,29.267]],[\"comment/15\",[]],[\"name/16\",[16,29.267]],[\"comment/16\",[]],[\"name/17\",[17,29.267]],[\"comment/17\",[]],[\"name/18\",[18,29.267]],[\"comment/18\",[]],[\"name/19\",[19,29.267]],[\"comment/19\",[]],[\"name/20\",[20,29.267]],[\"comment/20\",[]],[\"name/21\",[21,29.267]],[\"comment/21\",[]],[\"name/22\",[22,29.267]],[\"comment/22\",[]],[\"name/23\",[23,29.267]],[\"comment/23\",[]],[\"name/24\",[24,29.267]],[\"comment/24\",[]],[\"name/25\",[25,29.267]],[\"comment/25\",[]],[\"name/26\",[1,24.159]],[\"comment/26\",[]]],\"invertedIndex\":[[\"constructor\",{\"_index\":1,\"name\":{\"1\":{},\"26\":{}},\"comment\":{}}],[\"convertdatatodeeplink\",{\"_index\":22,\"name\":{\"22\":{}},\"comment\":{}}],[\"endpoint\",{\"_index\":5,\"name\":{\"5\":{}},\"comment\":{}}],[\"generaterandomhash\",{\"_index\":8,\"name\":{\"8\":{}},\"comment\":{}}],[\"generatesecurehash\",{\"_index\":21,\"name\":{\"21\":{}},\"comment\":{}}],[\"getbytes\",{\"_index\":24,\"name\":{\"24\":{}},\"comment\":{}}],[\"gethex\",{\"_index\":25,\"name\":{\"25\":{}},\"comment\":{}}],[\"hashtransactdata\",{\"_index\":20,\"name\":{\"20\":{}},\"comment\":{}}],[\"login\",{\"_index\":9,\"name\":{\"9\":{}},\"comment\":{}}],[\"network\",{\"_index\":4,\"name\":{\"4\":{}},\"comment\":{}}],[\"pollinginterval\",{\"_index\":3,\"name\":{\"3\":{}},\"comment\":{}}],[\"pollingtimeout\",{\"_index\":7,\"name\":{\"7\":{}},\"comment\":{}}],[\"random\",{\"_index\":23,\"name\":{\"23\":{}},\"comment\":{}}],[\"sign_x_login\",{\"_index\":13,\"name\":{\"13\":{}},\"comment\":{}}],[\"sign_x_login_error\",{\"_index\":15,\"name\":{\"15\":{}},\"comment\":{}}],[\"sign_x_login_success\",{\"_index\":14,\"name\":{\"14\":{}},\"comment\":{}}],[\"sign_x_transact\",{\"_index\":16,\"name\":{\"16\":{}},\"comment\":{}}],[\"sign_x_transact_error\",{\"_index\":18,\"name\":{\"18\":{}},\"comment\":{}}],[\"sign_x_transact_success\",{\"_index\":17,\"name\":{\"17\":{}},\"comment\":{}}],[\"signx\",{\"_index\":0,\"name\":{\"0\":{}},\"comment\":{}}],[\"sitename\",{\"_index\":6,\"name\":{\"6\":{}},\"comment\":{}}],[\"startpolling\",{\"_index\":11,\"name\":{\"11\":{}},\"comment\":{}}],[\"stoppolling\",{\"_index\":12,\"name\":{\"12\":{}},\"comment\":{}}],[\"timeout\",{\"_index\":2,\"name\":{\"2\":{}},\"comment\":{}}],[\"transact\",{\"_index\":10,\"name\":{\"10\":{}},\"comment\":{}}],[\"version\",{\"_index\":19,\"name\":{\"19\":{}},\"comment\":{}}]],\"pipeline\":[]}}"); \ No newline at end of file diff --git a/docs/classes/Random.html b/docs/classes/Random.html index e9cd293..b081fe0 100644 --- a/docs/classes/Random.html +++ b/docs/classes/Random.html @@ -1,4 +1,4 @@ -Random | @ixo/signx
+Random | @ixo/signx-sdk
  • Preparing search index...
  • -
  • The search index is not available
@ixo/signx
+
  • The search index is not available
  • @ixo/signx-sdk
    @@ -94,7 +94,7 @@

    Theme

    @@ -6,13 +6,13 @@
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk
    @@ -206,7 +206,7 @@
    +
  • Defined in src/client.ts:32
    • @@ -286,7 +286,7 @@
    +
  • Defined in src/client.ts:36
  • Returns void

    +
  • Defined in src/client.ts:76
    • @@ -668,20 +668,20 @@
      Optional errorMessage: Optional failEvent: string

    Returns void

    +
  • Defined in src/client.ts:126
    • - +
    • Parameters

      • data: TRANSACT_DTO
      -

      Returns Promise<{
          hash: string;
          network: NETWORK;
          sitename: string;
          type: string;
          version: number;
      }>

    +
  • Defined in src/client.ts:58
    • @@ -692,7 +692,7 @@
    @ixo/signx-sdk

    Function generateSecureHash

    @@ -28,7 +28,7 @@
    hash: string
    nonce: string

    Returns string

    +
  • Defined in src/utils/encoding.ts:17
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Function hashTransactData

    @@ -26,7 +26,7 @@

    Parameters

    data: TRANSACT_DTO

    Returns string

    +
  • Defined in src/utils/encoding.ts:6
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk
    -

    @ixo/signx

    -
    +

    @ixo/signx-sdk

    +
    + +

    SignX SDK

    +
    +

    ixo +GitHub +GitHub repo size +License: Apache 2.0

    +

    Twitter +Medium

    +

    NodeJSTypeScript

    +

    + +

    + +
    + +

    The SignX SDK provides an easy way to integrate mobile-to-web authentication and transaction signing using the IXO blockchain in your applications.

    +

    This repo and product is intentionally managed as Open Source and we aim to use this guide to light our way https://opensource.guide/. +Let us know how we are doing!

    + + +

    📝 Description

    +
    +

    The SignX SDK orchestrates a seamless and secure interaction between client applications, a mobile app, and a server, encapsulating the complexities of mobile-to-web authentication and transaction signing on the IXO blockchain. The flow is initiated when a client application triggers a login request through the SDK, which in turn generates a unique identifier and a secure hash. This information is encoded into a QR code that is displayed to the user. Upon scanning this QR code with the mobile app, the user's account details are securely transmitted to the server.

    +

    During this phase, the SDK engages in a polling mechanism, continually checking the server for the authentication response corresponding to the QR code data. This ensures that the client application is updated in near real-time once the user has completed the scanning process. The SDK has built-in error handling and timeout features to manage scenarios where the response from the server is delayed or unsuccessful. Upon receiving a successful response from the server, the SDK triggers an event notifying the client application of the successful login, and provides the user's account details for further interactions.

    +

    With the user now authenticated, the SDK facilitates transaction operations. When a transaction is initiated through the SDK, it packages the necessary transaction data and securely transmits this, along with a unique transaction hash, to the server. Similar to the login flow, a QR code is generated for the user to scan using the mobile app. This QR code encodes information required for the mobile app to retrieve the transaction data from the server, sign the transaction, and broadcast it to the IXO blockchain.

    +

    Post the QR code generation, the SDK re-engages its polling mechanism, constantly checking the server for updates regarding the transaction status. The mobile app, after broadcasting the transaction, uploads the transaction response to the server. Once the server processes this response, it updates the transaction status which is then picked up by the SDK in one of its polling iterations. Upon receiving a successful or failed transaction response, the SDK emits an event to inform the client application of the outcome, thus completing the transaction flow.

    +

    Through this orchestrated flow, the SignX SDK abstracts the technical intricacies, providing a straightforward and secure way for client applications to leverage mobile-to-web authentication and transaction signing on the IXO blockchain.

    +

    The SDK is crafted to interact harmoniously with a designated server, which handles the storage and provides the necessary endpoints for polling data during the authentication and transaction processes. To fully leverage the SDK's capabilities and ensure a streamlined operation, it is essential to set up and utilize the accompanying server, the source code for which can be found here.

    + + +

    🔨 Install

    +
    +
    npm install @ixo/signx-sdk

    yarn add @ixo/signx-sdk +
    + + +

    💻 Usage

    +
    +

    This SDK exposes a client class SignX which can be instantiated in your client applications to interact with the SignX server and mobile app for various operations.

    +

    Import and initialize the SignX client in your application:

    +
    import { SignX } from '@ixo/signx-sdk';

    const signXClient = new SignX({
    endpoint: 'https://your-signx-server.com',
    sitename: 'YourSiteName',
    network: 'mainnet',
    }); +
    + + +

    Login

    +
    +

    Initiate a login request using the login method:

    +
    const loginRequest = await signXClient.login();

    // Use loginRequest data to show QR code to user for scanning by mobile app +
    +

    Subscribe to events for success or failure here

    + + +

    Transacting

    +
    +

    Initiate a transaction using the transact method:

    +
    const transactRequest = await signXClient.transact(TRANSACT_DTO);

    // Use transactRequest data to show QR code to user for scanning by mobile app +
    +

    Subscribe to events for success or failure here. TRANSACT_DTO type can be seen here

    + + +

    Event Handling

    +
    +

    Listen for success and error events emitted by the SignX client:

    +
    signXClient.on(SIGN_X_LOGIN_SUCCESS, data => {
    console.log('Login Success:', data);
    });

    signXClient.on(SIGN_X_LOGIN_ERROR, error => {
    console.error('Login Error:', error);
    });

    signXClient.on(SIGN_X_TRANSACT_SUCCESS, data => {
    console.log('Transaction Success:', data);
    });

    signXClient.on(SIGN_X_TRANSACT_ERROR, error => {
    console.error('Transaction Error:', error);
    }); +
    + + +

    📎 Utility Functions

    +
    + + +

    hashTransactData

    +
    +

    Hashes transaction data for use in the transact method:

    +
    // hashTransactData(data: TRANSACT_DTO): string
    const hash = hashTransactData(transactData); +
    + + +

    generateSecureHash

    +
    +

    Generates a secure hash from a given hash and nonce:

    +
    // generateSecureHash(hash: string, nonce: string): string
    const secureHash = generateSecureHash(hash, nonce); +
    + + +

    🖇️ API Reference

    +
    + + +

    Types

    +
    +
      +
    • NETWORK: The network type:
      type NETWORK = 'mainnet' | 'testnet' | 'devnet';
      +
      +
    • +
    • TRANSACT_DTO: The data transfer object for transactions:
      type TRANSACT_DTO = {
      address: string, // bech32 encoded address, as received from login (eg ixo123)
      did: string, // base64 encoded did, as received from login (eg did:x:1234)
      pubkey: string, // hex encoded pubkey, as receivced from login
      txBodyHex: string, // hex encoded raw txBodyBytes which can be encoded from the registry exported from @ixo/impactxclient-sdk npm package (eg registry.encodeTxBody({ messages, memo }))
      timestamp: string, // stringified utc DateTime, add uniqueness for tx hash to prevent duplicates (eg new Date().toISOString())
      }; +
      +
    • +
    + + +

    Class SignX

    +
    + + +

    Properties

    +
    +
      +
    • timeout: The timeout for polling in milliseconds (default is 2 minutes).
    • +
    • pollingInterval: The interval between polling requests in milliseconds (default is 2.5 seconds).
    • +
    • network: The network type.
    • +
    • endpoint: The endpoint URL of the SignX server.
    • +
    • sitename: The name of your site. (shown on mobile app on request)
    • +
    + + +

    Methods

    +
    +
      +
    • login: Initiates a login request and starts polling.
    • +
    • transact: Initiates a transaction and starts polling.
    • +
    • stopPolling: Stops the polling process.
    • +
    + + +

    📱 Examples

    +
    +

    Example used in a React project:

    +
    let signXClient: SignX;

    let signXInitializing = false;
    export const initializeSignX = async (
    chainInfo: KEPLR_CHAIN_INFO_TYPE,
    walletUser?: USER,
    ): Promise<USER | undefined> => {
    if (signXInitializing) return;
    signXInitializing = true;

    let handleClose: () => void;
    try {
    if (!chainInfo || !chainInfo.chainId) throw new Error('No chain info found to initialize SignX');
    if (chainInfo.chainName !== 'ixo') throw new Error('SignX only works on ixo chain');

    signXClient = new SignX({
    endpoint: 'https://signx.devnet.ixo.earth',
    network: chainInfo.chainNetwork || 'mainnet',
    sitename: config.siteName ?? 'JAMBO dApp',
    });

    // if user already has an address or pubkey(already signed in), return
    if (walletUser?.address || walletUser?.pubKey) return walletUser;

    // get login data from client to display QR code and start polling
    const data = await signXClient.login({ pollingInterval: 2000 });

    const closeModal = () => {
    signXClient.off(SIGN_X_LOGIN_ERROR, () => {});
    signXClient.off(SIGN_X_LOGIN_SUCCESS, () => {});
    signXClient.stopPolling('Login cancelled', SIGN_X_LOGIN_ERROR);
    };

    handleClose = renderModal(
    <SignXModal
    title='SignX Login'
    subtitle='Scan QR with your ImpactsX wallet'
    data={JSON.stringify(data)}
    timeout={signXClient.timeout}
    />,
    closeModal,
    );

    const eventData: any = await new Promise((resolve, reject) => {
    const handleSuccess = (data: any) => {
    signXClient.off(SIGN_X_LOGIN_ERROR, handleError); // Remove error listener once successful
    resolve(data);
    };
    const handleError = (error: any) => {
    signXClient.off(SIGN_X_LOGIN_SUCCESS, handleSuccess); // Remove success listener on error
    reject(error);
    };

    signXClient.on(SIGN_X_LOGIN_SUCCESS, handleSuccess);
    signXClient.on(SIGN_X_LOGIN_ERROR, handleError);
    });
    handleClose(); // manually close the modal after event emitted

    return {
    name: eventData.data.name,
    address: eventData.data.address,
    pubKey: fromHex(eventData.data.pubKey),
    did: eventData.data.did,
    algo: eventData.data.algo,
    };
    } catch (e) {
    console.error('ERROR::initializeSignX::', e);
    // handle error like sign out of wallet
    const event = new Event(EVENT_LISTENER_TYPE.wallet_logout);
    window.dispatchEvent(event);
    } finally {
    signXInitializing = false;
    if (handleClose) handleClose();
    }
    };

    let signXBroadCastMessageBusy = false;
    export const signXBroadCastMessage = async (
    msgs: TRX_MSG[],
    memo = '',
    chainInfo: KEPLR_CHAIN_INFO_TYPE,
    wallet: WALLET,
    ): Promise<string | null> => {
    if (signXBroadCastMessageBusy) return null;
    signXBroadCastMessageBusy = true;

    let handleClose: () => void;
    try {
    if (!chainInfo || !chainInfo.chainId) throw new Error('No chain info found');
    if (chainInfo.chainName !== 'ixo') throw new Error('SignX only works on ixo chain');

    if (!wallet.user) throw new Error('No user found to broadcast transaction');
    if (!signXClient) throw new Error('No signXClient found to broadcast transaction');

    const registry = createRegistry();

    // get login data from client to display QR code and start polling
    const data = await signXClient.transact({
    address: wallet.user.address,
    did: wallet.user.did!,
    pubkey: toHex(wallet.user.pubKey),
    timestamp: new Date().toISOString(),
    txBodyHex: toHex(registry.encodeTxBody({ messages: msgs as any, memo })),
    });

    const closeModal = () => {
    signXClient.off(SIGN_X_TRANSACT_ERROR, () => {});
    signXClient.off(SIGN_X_TRANSACT_SUCCESS, () => {});
    signXClient.stopPolling('Transaction cancelled', SIGN_X_TRANSACT_ERROR);
    };

    handleClose = renderModal(
    <SignXModal
    title='SignX Transaction'
    subtitle='Scan QR with your ImpactsX wallet'
    data={JSON.stringify(data)}
    timeout={signXClient.timeout}
    />,
    closeModal,
    );

    const eventData: any = await new Promise((resolve, reject) => {
    const handleSuccess = (data: any) => {
    signXClient.off(SIGN_X_TRANSACT_ERROR, handleError); // Remove error listener once successful
    resolve(data);
    };
    const handleError = (error: any) => {
    signXClient.off(SIGN_X_TRANSACT_SUCCESS, handleSuccess); // Remove success listener on error
    reject(error);
    };

    signXClient.on(SIGN_X_TRANSACT_SUCCESS, handleSuccess);
    signXClient.on(SIGN_X_TRANSACT_ERROR, handleError);
    });
    handleClose(); // manually close the modal after event emitted

    console.log({ eventData });

    return eventData.data?.transactionHash;
    } catch (e) {
    console.error('ERROR::signXBroadCastMessage::', e);
    Toast.errorToast(`Transaction Failed`);
    return null;
    } finally {
    signXBroadCastMessageBusy = false;
    if (handleClose) handleClose();
    }
    };
    +
    + + +

    📃 License

    +
    +

    This SDK is licensed under the Apache 2 License. See the LICENSE file for more information.

    +
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk
    -

    @ixo/signx

    +

    @ixo/signx-sdk

    Index

    @@ -32,7 +32,8 @@

    Variables

    Functions

    -
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable SIGN_X_LOGINConst

    SIGN_X_LOGIN: "SIGN_X_LOGIN" = 'SIGN_X_LOGIN'
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable SIGN_X_LOGIN_ERRORConst

    SIGN_X_LOGIN_ERROR: "SIGN_X_LOGIN_ERROR" = 'SIGN_X_LOGIN_ERROR'
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable SIGN_X_LOGIN_SUCCESSConst

    SIGN_X_LOGIN_SUCCESS: "SIGN_X_LOGIN_SUCCESS" = 'SIGN_X_LOGIN_SUCCESS'
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable SIGN_X_TRANSACTConst

    SIGN_X_TRANSACT: "SIGN_X_TRANSACT" = 'SIGN_X_TRANSACT'
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable SIGN_X_TRANSACT_ERRORConst

    SIGN_X_TRANSACT_ERROR: "SIGN_X_TRANSACT_ERROR" = 'SIGN_X_TRANSACT_ERROR'
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable SIGN_X_TRANSACT_SUCCESSConst

    SIGN_X_TRANSACT_SUCCESS: "SIGN_X_TRANSACT_SUCCESS" = 'SIGN_X_TRANSACT_SUCCESS'
    @@ -6,13 +6,13 @@
    • Preparing search index...
    • -
    • The search index is not available
    @ixo/signx +
  • The search index is not available
  • @ixo/signx-sdk

    Variable VERSIONConst

    VERSION: 1 = 1