@witnet/sdk 1.1.0 → 1.1.2

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.
@@ -62,8 +62,8 @@ function requireRadonAsset(specs) {
62
62
  ? flattenRadonAssets(specs.assets, specs?.type)
63
63
  : loadModuleAssets({ flattened: true, type: specs?.type }));
64
64
  const found = stuff.find((entry) => entry.key === specs.artifact);
65
- if (found) {
66
- return found[0].artifact;
65
+ if (found?.artifact) {
66
+ return found.artifact;
67
67
  }
68
68
  else {
69
69
  throw Error(`Radon asset "${specs.artifact}" not available.`);
@@ -150,4 +150,4 @@ function parseScriptOperator(script, opcode, args) {
150
150
  }
151
151
  }
152
152
  }
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/lib/radon/utils.ts"],"names":[],"mappings":"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","sourcesContent":["require('dotenv').config()\r\nimport { decode as cborDecode } from 'cbor'\r\n\r\nimport { fromHexString, isHexString } from \"../../bin/helpers\"\r\n\r\nimport { RadonRequest, RadonModal, RadonTemplate, RadonRetrieval } from \"./index\"\r\n\r\nimport {\r\n  RadonAny,\r\n  RadonArray,\r\n  RadonBoolean,\r\n  RadonBytes,\r\n  RadonFloat,\r\n  RadonInteger,\r\n  RadonMap,\r\n  RadonString,\r\n  RadonOperators,\r\n} from \"./types\"\r\n\r\nconst WITNET_ASSETS_PATH = process.env.WITNET_SDK_RADON_ASSETS_PATH || \"../../../../../witnet/assets\"\r\n\r\nexport { execRadonBytecode } from \"../../bin/helpers\"\r\n\r\n/**\r\n * Decodes a Radon script out from a Protobuf-serialized bytecode.\r\n * @param hexString Radon script bytecode.\r\n * @returns Radon script object (i.e. chain of Radon operators with a deterministic output Radon type).\r\n */\r\nexport function parseRadonScript(bytecode: any): RadonAny {\r\n  let buffer\r\n  if (isHexString(bytecode)) {\r\n    buffer = fromHexString(bytecode)\r\n  } else if (bytecode instanceof Uint8Array) {\r\n    buffer = Buffer.from(bytecode)\r\n  } else if (bytecode instanceof Buffer) {\r\n    buffer = bytecode\r\n  } else {\r\n    throw new TypeError(`Unsupported RadonScript bytecode format: ${bytecode}`)\r\n  }\r\n  const array = cborDecode(buffer)\r\n  return parseScript(array)\r\n}\r\n\r\n\r\nexport function flattenRadonAssets<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(\r\n  tree: any,\r\n  type?: { new(specs: any): T; },\r\n  headers?: string[]\r\n): Array<{ key: string, artifact: any }> {\r\n  if (!headers) headers = []\r\n  const entries: Array<{ key: string, artifact: any }> = []\r\n  for (const key in tree) {\r\n    if (\r\n      (type && tree[key] instanceof type)\r\n      || (!type && (\r\n          tree[key] instanceof RadonRequest\r\n          || tree[key] instanceof RadonTemplate\r\n          || tree[key] instanceof RadonModal\r\n          || tree[key] instanceof RadonRetrieval\r\n      ))\r\n    ) {\r\n      entries.push({\r\n        key,\r\n        artifact: tree[key],\r\n      })\r\n    } else if (typeof tree[key] === \"object\") {\r\n      entries.push(...flattenRadonAssets(\r\n        tree[key],\r\n        type,\r\n        [...headers, key]\r\n      ))\r\n    }\r\n  }\r\n  return entries\r\n};\r\n\r\nexport function requireRadonAsset<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(specs: {\r\n  artifact: string,\r\n  assets?: any,\r\n  type?: { new (specs: any): T; },\r\n}): T {\r\n  const stuff = (\r\n    specs?.assets \r\n      ? flattenRadonAssets(specs.assets, specs?.type) \r\n      : loadModuleAssets({ flattened: true, type: specs?.type })\r\n  );\r\n  const found = stuff.find((entry: { key: string, artifact: any }) => entry.key === specs.artifact)\r\n  if (found) {\r\n    return found[0].artifact\r\n  } else {\r\n    throw Error(`Radon asset \"${specs.artifact}\" not available.`)\r\n  }\r\n}\r\n\r\n/**\r\n * Search Witnet Radon assets declared or imported within current repository, \r\n * whose names complies with the provided `pattern` and `filterFn`. \r\n * If no `filterFn` is specified, search will include assets whose names \r\n * are suffixed by given `pattern` (case insensitive).\r\n * @param options Search options\r\n * @param filterFn Filtering function.\r\n * @returns An array of Radon assets of the specified kind complying with the search pattern. \r\n */\r\nexport function searchRadonAssets<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(\r\n  options: {\r\n    /**\r\n     * Object containing structured heriarchy of Radon assets. If not provided, Radon assets declared within project's environment.\r\n     */\r\n    assets?: any,\r\n    /**\r\n     * Limits number of returned Radon assets.\r\n     */\r\n    limit?: number,\r\n    /**\r\n     * Offsets returned array of Radon assets.\r\n     */\r\n    offset?: number,\r\n    /**\r\n     * Name pattern searched for.\r\n     */\r\n    pattern: string,\r\n    /**\r\n     * Specific type of Radon asset to search for: `RadonRequest`, `RadonRequest`, `RadonRetrieval` or `RadonCCDR`.\r\n     */\r\n    type?: { new (specs: any): T; },\r\n  },\r\n  filterFn?: (key: string, pattern: string) => boolean,\r\n): Array<[key: string, artifact: T]> {\r\n  const defaultFilter = (key: string, pattern: string) => key.toLowerCase().endsWith(pattern.toLowerCase())\r\n  const stuff = (\r\n    options?.assets\r\n      ? flattenRadonAssets(options.assets, options?.type)\r\n      : loadModuleAssets({ flattened: true, type: options?.type })\r\n  );\r\n  return (\r\n    stuff\r\n      .filter((entry: { key: string, artifact: any }) => (filterFn || defaultFilter)(entry.key, options.pattern || \"\"))\r\n      .slice(options?.offset || 0, options?.limit)\r\n      .map((entry: { key: string, artifact: any | T }) => [entry.key, entry.artifact])\r\n  );\r\n}\r\n\r\n\r\n// ====================================================================================================================\r\n// --- INTERNAL METHODS -----------------------------------------------------------------------------------------------\r\n\r\nfunction loadModuleAssets<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(\r\n  options: {\r\n    // legacy?: boolean,\r\n    flattened?: boolean,\r\n    type?: { new(specs: any): T; },\r\n  },\r\n): any {\r\n  // const stuff = options?.legacy ? require(`${WITNET_ASSETS_PATH}`).legacy : {\r\n  //   requests: require(`${WITNET_ASSETS_PATH}/requests`),\r\n  //   templates: require(`${WITNET_ASSETS_PATH}/templates`),\r\n  //   retrievals: require(`${WITNET_ASSETS_PATH}/retrievals`),\r\n  // };\r\n  const stuff = require(`${WITNET_ASSETS_PATH}`)\r\n  return options?.flattened ? flattenRadonAssets(stuff, options?.type) : stuff\r\n}\r\n\r\nfunction parseScript(array: any, script?: any): any {\r\n  if (Array.isArray(array)) {\r\n    array.forEach(item => {\r\n      if (Array.isArray(item)) {\r\n        script = parseScriptOperator(script, item[0], ...item.slice(1))\r\n      } else {\r\n        script = parseScriptOperator(script, item)\r\n      }\r\n    })\r\n    return script\r\n  } else {\r\n    return parseScriptOperator(script, array)\r\n  }\r\n}\r\n\r\nfunction parseScriptOperator(script: any, opcode: any, args?: any): any {\r\n  if (!script) {\r\n    const found = Object.entries({\r\n      \"10\": RadonArray,\r\n      \"20\": RadonBoolean,\r\n      \"30\": RadonBytes,\r\n      \"40\": RadonInteger,\r\n      \"50\": RadonFloat,\r\n      \"60\": RadonMap,\r\n      \"70\": RadonString,\r\n    }).find(entry => entry[0] === (parseInt(opcode) & 0xf0).toString(16))\r\n    if (found) {\r\n      script = new found[1]\r\n    } else {\r\n      throw TypeError(`unknown Radon operator: ${opcode}`)\r\n    }\r\n  }\r\n  if (opcode) {\r\n    let operator = RadonOperators[opcode].split(/(?=[A-Z])/).slice(1).join(\"\")\r\n    operator = operator.charAt(0).toLowerCase() + operator.slice(1)\r\n    switch (operator) {\r\n      case \"filter\": case \"map\": case \"sort\": case \"alter\":\r\n        const innerScript = parseScript(args)\r\n        return script[operator](innerScript, ...args.slice(1));\r\n\r\n      // case \"alter\":\r\n      //   return script[operator](args[0], parseScript(args[1], ...args.slice(2)));\r\n\r\n      default:\r\n        return script[operator](args)\r\n    }\r\n  }\r\n}\r\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/lib/radon/utils.ts"],"names":[],"mappings":"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","sourcesContent":["require('dotenv').config()\r\nimport { decode as cborDecode } from 'cbor'\r\n\r\nimport { fromHexString, isHexString } from \"../../bin/helpers\"\r\n\r\nimport { RadonRequest, RadonModal, RadonTemplate, RadonRetrieval } from \"./index\"\r\n\r\nimport {\r\n  RadonAny,\r\n  RadonArray,\r\n  RadonBoolean,\r\n  RadonBytes,\r\n  RadonFloat,\r\n  RadonInteger,\r\n  RadonMap,\r\n  RadonString,\r\n  RadonOperators,\r\n} from \"./types\"\r\n\r\nconst WITNET_ASSETS_PATH = process.env.WITNET_SDK_RADON_ASSETS_PATH || \"../../../../../witnet/assets\"\r\n\r\nexport { execRadonBytecode } from \"../../bin/helpers\"\r\n\r\n/**\r\n * Decodes a Radon script out from a Protobuf-serialized bytecode.\r\n * @param hexString Radon script bytecode.\r\n * @returns Radon script object (i.e. chain of Radon operators with a deterministic output Radon type).\r\n */\r\nexport function parseRadonScript(bytecode: any): RadonAny {\r\n  let buffer\r\n  if (isHexString(bytecode)) {\r\n    buffer = fromHexString(bytecode)\r\n  } else if (bytecode instanceof Uint8Array) {\r\n    buffer = Buffer.from(bytecode)\r\n  } else if (bytecode instanceof Buffer) {\r\n    buffer = bytecode\r\n  } else {\r\n    throw new TypeError(`Unsupported RadonScript bytecode format: ${bytecode}`)\r\n  }\r\n  const array = cborDecode(buffer)\r\n  return parseScript(array)\r\n}\r\n\r\n\r\nexport function flattenRadonAssets<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(\r\n  tree: any,\r\n  type?: { new(specs: any): T; },\r\n  headers?: string[]\r\n): Array<{ key: string, artifact: any }> {\r\n  if (!headers) headers = []\r\n  const entries: Array<{ key: string, artifact: any }> = []\r\n  for (const key in tree) {\r\n    if (\r\n      (type && tree[key] instanceof type)\r\n      || (!type && (\r\n          tree[key] instanceof RadonRequest\r\n          || tree[key] instanceof RadonTemplate\r\n          || tree[key] instanceof RadonModal\r\n          || tree[key] instanceof RadonRetrieval\r\n      ))\r\n    ) {\r\n      entries.push({\r\n        key,\r\n        artifact: tree[key],\r\n      })\r\n    } else if (typeof tree[key] === \"object\") {\r\n      entries.push(...flattenRadonAssets(\r\n        tree[key],\r\n        type,\r\n        [...headers, key]\r\n      ))\r\n    }\r\n  }\r\n  return entries\r\n};\r\n\r\nexport function requireRadonAsset<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(specs: {\r\n  artifact: string,\r\n  assets?: any,\r\n  type?: { new (specs: any): T; },\r\n}): T {\r\n  const stuff = (\r\n    specs?.assets \r\n      ? flattenRadonAssets(specs.assets, specs?.type) \r\n      : loadModuleAssets({ flattened: true, type: specs?.type })\r\n  );\r\n  const found = stuff.find((entry: { key: string, artifact: any }) => entry.key === specs.artifact)\r\n  if (found?.artifact) {\r\n    return found.artifact\r\n  } else {\r\n    throw Error(`Radon asset \"${specs.artifact}\" not available.`)\r\n  }\r\n}\r\n\r\n/**\r\n * Search Witnet Radon assets declared or imported within current repository, \r\n * whose names complies with the provided `pattern` and `filterFn`. \r\n * If no `filterFn` is specified, search will include assets whose names \r\n * are suffixed by given `pattern` (case insensitive).\r\n * @param options Search options\r\n * @param filterFn Filtering function.\r\n * @returns An array of Radon assets of the specified kind complying with the search pattern. \r\n */\r\nexport function searchRadonAssets<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(\r\n  options: {\r\n    /**\r\n     * Object containing structured heriarchy of Radon assets. If not provided, Radon assets declared within project's environment.\r\n     */\r\n    assets?: any,\r\n    /**\r\n     * Limits number of returned Radon assets.\r\n     */\r\n    limit?: number,\r\n    /**\r\n     * Offsets returned array of Radon assets.\r\n     */\r\n    offset?: number,\r\n    /**\r\n     * Name pattern searched for.\r\n     */\r\n    pattern: string,\r\n    /**\r\n     * Specific type of Radon asset to search for: `RadonRequest`, `RadonRequest`, `RadonRetrieval` or `RadonCCDR`.\r\n     */\r\n    type?: { new (specs: any): T; },\r\n  },\r\n  filterFn?: (key: string, pattern: string) => boolean,\r\n): Array<[key: string, artifact: T]> {\r\n  const defaultFilter = (key: string, pattern: string) => key.toLowerCase().endsWith(pattern.toLowerCase())\r\n  const stuff = (\r\n    options?.assets\r\n      ? flattenRadonAssets(options.assets, options?.type)\r\n      : loadModuleAssets({ flattened: true, type: options?.type })\r\n  );\r\n  return (\r\n    stuff\r\n      .filter((entry: { key: string, artifact: any }) => (filterFn || defaultFilter)(entry.key, options.pattern || \"\"))\r\n      .slice(options?.offset || 0, options?.limit)\r\n      .map((entry: { key: string, artifact: any | T }) => [entry.key, entry.artifact])\r\n  );\r\n}\r\n\r\n\r\n// ====================================================================================================================\r\n// --- INTERNAL METHODS -----------------------------------------------------------------------------------------------\r\n\r\nfunction loadModuleAssets<T extends RadonRequest | RadonTemplate | RadonModal | RadonRetrieval>(\r\n  options: {\r\n    // legacy?: boolean,\r\n    flattened?: boolean,\r\n    type?: { new(specs: any): T; },\r\n  },\r\n): any {\r\n  // const stuff = options?.legacy ? require(`${WITNET_ASSETS_PATH}`).legacy : {\r\n  //   requests: require(`${WITNET_ASSETS_PATH}/requests`),\r\n  //   templates: require(`${WITNET_ASSETS_PATH}/templates`),\r\n  //   retrievals: require(`${WITNET_ASSETS_PATH}/retrievals`),\r\n  // };\r\n  const stuff = require(`${WITNET_ASSETS_PATH}`)\r\n  return options?.flattened ? flattenRadonAssets(stuff, options?.type) : stuff\r\n}\r\n\r\nfunction parseScript(array: any, script?: any): any {\r\n  if (Array.isArray(array)) {\r\n    array.forEach(item => {\r\n      if (Array.isArray(item)) {\r\n        script = parseScriptOperator(script, item[0], ...item.slice(1))\r\n      } else {\r\n        script = parseScriptOperator(script, item)\r\n      }\r\n    })\r\n    return script\r\n  } else {\r\n    return parseScriptOperator(script, array)\r\n  }\r\n}\r\n\r\nfunction parseScriptOperator(script: any, opcode: any, args?: any): any {\r\n  if (!script) {\r\n    const found = Object.entries({\r\n      \"10\": RadonArray,\r\n      \"20\": RadonBoolean,\r\n      \"30\": RadonBytes,\r\n      \"40\": RadonInteger,\r\n      \"50\": RadonFloat,\r\n      \"60\": RadonMap,\r\n      \"70\": RadonString,\r\n    }).find(entry => entry[0] === (parseInt(opcode) & 0xf0).toString(16))\r\n    if (found) {\r\n      script = new found[1]\r\n    } else {\r\n      throw TypeError(`unknown Radon operator: ${opcode}`)\r\n    }\r\n  }\r\n  if (opcode) {\r\n    let operator = RadonOperators[opcode].split(/(?=[A-Z])/).slice(1).join(\"\")\r\n    operator = operator.charAt(0).toLowerCase() + operator.slice(1)\r\n    switch (operator) {\r\n      case \"filter\": case \"map\": case \"sort\": case \"alter\":\r\n        const innerScript = parseScript(args)\r\n        return script[operator](innerScript, ...args.slice(1));\r\n\r\n      // case \"alter\":\r\n      //   return script[operator](args[0], parseScript(args[1], ...args.slice(2)));\r\n\r\n      default:\r\n        return script[operator](args)\r\n    }\r\n  }\r\n}\r\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@witnet/sdk",
3
- "version": "1.1.0",
3
+ "version": "1.1.2",
4
4
  "description": "Typescript library and CLI tooling for Web3 buidlers willing to interact with the Witnet blockchain.",
5
5
  "author": "Witnet Foundation",
6
6
  "license": "MIT",
@@ -19,19 +19,20 @@
19
19
  ],
20
20
  "exports": {
21
21
  ".": {
22
+ "types": "./dist/src/*.d.ts",
22
23
  "require": "./dist/src/index.js",
23
- "default": "./dist/src/index.js",
24
- "types": "./dist/src/*.d.ts"
24
+ "default": "./dist/src/index.js"
25
25
  },
26
26
  "./assets": "./dist/witnet/assets/index.js",
27
27
  "./utils": {
28
+ "types": "./dist/src/lib/*.d.ts",
28
29
  "require": "./dist/src/lib/utils.js",
29
- "default": "./dist/src/lib/utils.js",
30
- "types": "./dist/src/lib/*.d.ts"
30
+ "default": "./dist/src/lib/utils.js"
31
31
  }
32
32
  },
33
33
  "types": "./dist",
34
34
  "dependencies": {
35
+ "@bitcoinerlab/secp256k1": "^1.2.0",
35
36
  "axios": "^1.12.2",
36
37
  "bech32": "~2.0.0",
37
38
  "bip32": "^4.0.0",
@@ -48,8 +49,7 @@
48
49
  "promise-poller": "~1.9.1",
49
50
  "protobufjs": "^7.5.4",
50
51
  "qrcode-terminal": "^0.12.0",
51
- "secp256k1": "^5.0.1",
52
- "tiny-secp256k1": "~2.2.4"
52
+ "secp256k1": "^5.0.1"
53
53
  },
54
54
  "devDependencies": {
55
55
  "@types/node": "^22.18.5",
@@ -27,12 +27,21 @@ module.exports = {
27
27
  hint: "List available Witnet Radon assets.",
28
28
  params: "[RADON_ASSETS ...]",
29
29
  options: {
30
+ filter: {
31
+ hint: "Restrict output to name-matching assets.",
32
+ },
30
33
  legacy: {
31
34
  hint: "List only those declared in witnet/assets folder.",
32
35
  },
33
- filter: {
34
- hint: "Restrict output to name-matching assets.",
36
+ modals: {
37
+ hint: "Restrict output to Radon modals.",
35
38
  },
39
+ requests: {
40
+ hint: "Restrict output to Radon requests.",
41
+ },
42
+ templates: {
43
+ hint: "Restrict output to Radon templates.",
44
+ },
36
45
  },
37
46
  },
38
47
  check: {
@@ -169,21 +178,25 @@ async function assets (options = {}, [...patterns]) {
169
178
  `${options?.module ? options.module.toUpperCase() : path.basename(process.cwd()).toUpperCase()} RADON ASSETS`,
170
179
  helpers.colors.white
171
180
  )
172
- const assets = clearEmptyBranches(loadAssets(options), patterns, options?.filter)
181
+ const assets = clearEmptyBranches(
182
+ options?.module ? require(options.module) : loadAssets(options),
183
+ patterns,
184
+ options
185
+ );
173
186
  if (assets && Object.keys(assets).length > 0) {
174
- traceWitnetArtifacts(assets, patterns, " ", options?.filter)
187
+ traceWitnetArtifacts(assets, patterns, " ", options)
175
188
  } else {
176
189
  console.info("> No custom Radon assets declared just yet.")
177
190
  }
178
191
  }
179
192
  /// -------------------------------------------------------------------------------------------------------------------
180
193
 
181
- async function check (options = {}) {
194
+ async function check () {
182
195
  if (!isModuleInitialized) {
183
196
  throw new Error(`No Witnet Radon workspace has been initialized. Please, run ${white("npx witsdk radon init")} if willing to declare your own Radon assets.`)
184
197
  }
185
198
  try {
186
- const assets = loadAssets({ ...options, legacy: true })
199
+ const assets = loadAssets({ legacy: true })
187
200
  const [
188
201
  modals,
189
202
  requests,
@@ -234,7 +247,7 @@ async function decode (options = {}, args = []) {
234
247
  } else {
235
248
  args = args.slice(1)
236
249
 
237
- const assets = loadAssets(options)
250
+ const assets = options?.module ? require(options.module) : loadAssets(options)
238
251
  const headline = options?.headline
239
252
  const crafts = flattenRadonArtifacts(assets).filter(craft => craft.key.toLowerCase().indexOf(asset.toLowerCase()) >= 0)
240
253
  if (crafts.length === 0) {
@@ -300,7 +313,7 @@ async function dryrun (options = {}, args = []) {
300
313
  }
301
314
  } else {
302
315
  args = args.slice(1)
303
- const assets = loadAssets(options)
316
+ const assets = options?.module ? require(options.module) : loadAssets(options)
304
317
  const headline = options?.headline
305
318
  const crafts = flattenRadonArtifacts(assets).filter(craft => craft.key.toLowerCase().indexOf(asset.toLowerCase()) >= 0)
306
319
  if (crafts.length === 0) {
@@ -384,8 +397,12 @@ const stringifyReducer = (x, c) => {
384
397
  }
385
398
 
386
399
  function loadAssets (options) {
387
- const { assets } = options?.module ? require(options.module) : (options?.legacy ? {} : require("@witnet/sdk"))
388
- return isModuleInitialized && fs.existsSync(`${WITNET_ASSETS_PATH}`) ? merge(assets, require(`${WITNET_ASSETS_PATH}`)) : assets
400
+ const { assets } = options?.legacy ? {} : require("@witnet/sdk")
401
+ return (
402
+ isModuleInitialized && fs.existsSync(`${WITNET_ASSETS_PATH}`)
403
+ ? merge(assets, require(`${WITNET_ASSETS_PATH}`))
404
+ : assets
405
+ );
389
406
  }
390
407
 
391
408
  function flattenRadonArtifacts (tree, headers) {
@@ -412,44 +429,64 @@ function flattenRadonArtifacts (tree, headers) {
412
429
  return matches
413
430
  };
414
431
 
415
- function countWitnetArtifacts (assets, args, filter = false) {
432
+ function countWitnetArtifacts (assets, args, options) {
416
433
  let counter = 0
417
434
  Object.entries(assets).forEach(([key, value]) => {
418
- if ((
419
- value instanceof Witnet.Radon.RadonModal ||
420
- value instanceof Witnet.Radon.RadonRequest ||
421
- value instanceof Witnet.Radon.RadonTemplate ||
422
- value instanceof Witnet.Radon.RadonRetrieval
423
- ) && (
424
- !filter ||
425
- !args ||
426
- args.length === 0 ||
427
- args.find(arg => key.toLowerCase().indexOf(arg.toLowerCase()) >= 0)
435
+ let include = (
436
+ (options?.modals && value instanceof Witnet.Radon.RadonModal)
437
+ || (options?.templates && value instanceof Witnet.Radon.RadonTemplate)
438
+ || (options?.retrievals && value instanceof Witnet.Radon.RadonRetrieval)
439
+ || (options?.requests && value instanceof Witnet.Radon.RadonRequest)
440
+ );
441
+ if (!(options?.modals || options?.templates || options?.retrievals || options?.requests)) {
442
+ include = (
443
+ value instanceof Witnet.Radon.RadonModal ||
444
+ value instanceof Witnet.Radon.RadonRequest ||
445
+ value instanceof Witnet.Radon.RadonTemplate ||
446
+ value instanceof Witnet.Radon.RadonRetrieval
447
+ );
448
+ }
449
+ if (include && (
450
+ !options?.filter
451
+ || !args
452
+ || args.length === 0
453
+ || args.find(arg => key.toLowerCase().indexOf(arg.toLowerCase()) >= 0)
428
454
  )) {
429
455
  counter++
430
456
  } else if (typeof value === "object") {
431
- counter += countWitnetArtifacts(value, args)
457
+ counter += countWitnetArtifacts(value, args, options)
432
458
  }
433
459
  })
434
460
  return counter
435
461
  }
436
462
 
437
- function clearEmptyBranches (node, args, filter) {
463
+ function clearEmptyBranches (node, args, options) {
438
464
  if (node) {
439
465
  const assets = Object.fromEntries(
440
466
  Object.entries(node).map(([key, value]) => {
467
+ let include = (
468
+ (options?.modals && value instanceof Witnet.Radon.RadonModal)
469
+ || (options?.templates && value instanceof Witnet.Radon.RadonTemplate)
470
+ || (options?.retrievals && value instanceof Witnet.Radon.RadonRetrieval)
471
+ || (options?.requests && value instanceof Witnet.Radon.RadonRequest)
472
+ );
473
+ if (!(options?.modals || options?.templates || options?.retrievals || options?.requests)) {
474
+ include = (
475
+ value instanceof Witnet.Radon.RadonModal ||
476
+ value instanceof Witnet.Radon.RadonRequest ||
477
+ value instanceof Witnet.Radon.RadonTemplate ||
478
+ value instanceof Witnet.Radon.RadonRetrieval
479
+ );
480
+ }
441
481
  if (
442
- (!filter || args.find(arg => key.toLowerCase().indexOf(arg.toLowerCase()) >= 0)) && (
443
- value instanceof Witnet.Radon.RadonRetrieval ||
444
- value instanceof Witnet.Radon.RadonModal ||
445
- value instanceof Witnet.Radon.RadonRequest ||
446
- value instanceof Witnet.Radon.RadonTemplate
482
+ include && (
483
+ !options?.filter || args.find(arg => key.toLowerCase().indexOf(arg.toLowerCase()) >= 0)
447
484
  )
448
485
  ) {
449
486
  return [key, value]
450
487
  } else if (typeof value === "object") {
451
- if (countWitnetArtifacts(value, args, filter) > 0) {
452
- return [key, clearEmptyBranches(value, args, filter)]
488
+ if (countWitnetArtifacts(value, args, options) > 0) {
489
+ return [key, clearEmptyBranches(value, args, options)]
453
490
  } else {
454
491
  return [key, undefined]
455
492
  }
@@ -467,25 +504,25 @@ function clearEmptyBranches (node, args, filter) {
467
504
  }
468
505
  }
469
506
 
470
- function traceWitnetArtifacts (assets, args, indent = "", filter = false) {
507
+ function traceWitnetArtifacts (assets, args, indent = "", options) {
471
508
  const prefix = `${indent}`
472
509
  Object.keys(assets).forEach((key, index) => {
473
510
  const isLast = index === Object.keys(assets).length - 1
474
511
  const found = args.find(arg => key.toLowerCase().indexOf(arg.toLowerCase()) >= 0)
475
512
  const color = found ? helpers.colors.mcyan : helpers.colors.cyan
476
513
  if (assets[key] instanceof Witnet.Radon.RadonRequest) {
477
- if (!filter || found) {
514
+ if (!options?.filter || found) {
478
515
  console.info(`${prefix}${color(key)} ${assets[key].sources.length > 1 ? helpers.colors.yellow(`(${assets[key].sources.length} sources)`) : ""}`)
479
516
  if (isLast) {
480
517
  console.info(`${prefix}`)
481
518
  }
482
519
  }
483
- } else if (
520
+ } else if ((
484
521
  assets[key] instanceof Witnet.Radon.RadonTemplate ||
485
522
  assets[key] instanceof Witnet.Radon.RadonModal
486
- ) {
523
+ )) {
487
524
  const argsCount = assets[key].argsCount
488
- if (!filter || found) {
525
+ if (!options?.filter || found) {
489
526
  console.info(`${prefix}${color(key)} ${argsCount > 0 ? helpers.colors.green(`(${argsCount} args)`) : ""}`)
490
527
  if (isLast) {
491
528
  console.info(`${prefix}`)
@@ -493,15 +530,15 @@ function traceWitnetArtifacts (assets, args, indent = "", filter = false) {
493
530
  }
494
531
  } else if (assets[key] instanceof Witnet.Radon.RadonRetrieval) {
495
532
  const argsCount = assets[key].argsCount
496
- if (!filter || found) {
533
+ if (!options?.filter || found) {
497
534
  console.info(`${prefix}${color(key)} ${argsCount > 0 ? helpers.colors.green(`(${argsCount} args)`) : ""}`)
498
535
  if (isLast) {
499
536
  console.info(`${prefix}`)
500
537
  }
501
538
  }
502
- } else if (typeof assets[key] === "object" && countWitnetArtifacts(assets[key], args, filter) > 0) {
539
+ } else if (typeof assets[key] === "object" && countWitnetArtifacts(assets[key], args, options) > 0) {
503
540
  console.info(`${indent}${isLast ? "└─ " : "├─ "}${key}`)
504
- traceWitnetArtifacts(assets[key], args, !isLast ? `${indent}│ ` : `${indent} `, filter)
541
+ traceWitnetArtifacts(assets[key], args, !isLast ? `${indent}│ ` : `${indent} `, options)
505
542
  }
506
543
  })
507
544
  }
@@ -946,13 +946,12 @@ async function _loadRadonRequest (options = {}) {
946
946
  }
947
947
 
948
948
  // load Radon assets from environment
949
- let assets = utils.searchRadonAssets(
950
- {
951
- assets: loadAssets(options),
949
+ const assets = utils.searchRadonAssets({
950
+ assets: options?.module ? require(options.module) : loadAssets(options),
952
951
  pattern: options?.pattern,
953
- },
952
+ },
954
953
  (key, pattern) => key.toLowerCase().indexOf(pattern.toLowerCase()) >= 0
955
- )
954
+ );
956
955
 
957
956
  if (args.length > 0) {
958
957
  // ignore RadonRequests if args were passed from the CLI
@@ -98,7 +98,7 @@ async function execRadonBytecode (bytecode, ...flags) {
98
98
  throw EvalError("invalid hex string")
99
99
  } else {
100
100
  const npx = os.type() === "Windows_NT" ? "npx.cmd" : "npx"
101
- return cmd(npx, "witnet", "radon", "dry-run", bytecode, ...flags)
101
+ return cmd(npx, "witsdk", "radon", "dry-run", bytecode, ...flags)
102
102
  // .catch((err) => {
103
103
  // let errorMessage = err.message.split('\n').slice(1).join('\n').trim()
104
104
  // const errorRegex = /.*^error: (?<message>.*)$.*/gm
@@ -1,4 +1,4 @@
1
- #!/usr/bin/env node
1
+ #!/usr/bin/env node
2
2
 
3
3
  /// IMPORTS ===========================================================================================================
4
4