From fde66c85db3d86cf134867fddc99dc85f6063e4c Mon Sep 17 00:00:00 2001 From: CMEONE Date: Wed, 23 Jun 2021 09:19:07 -0700 Subject: [PATCH] Fix mixedToUint8Array --- node/tenvoy.js | 17 ++++++++++++++++- tenvoy.js | 17 ++++++++++++++++- 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/node/tenvoy.js b/node/tenvoy.js index 94b6bd6c..adc817e5 100644 --- a/node/tenvoy.js +++ b/node/tenvoy.js @@ -16,7 +16,7 @@ function tEnvoy(openpgpRef = openpgp, naclRef = nacl, sha256Ref = sha256) { Object.defineProperty(this, "version", { get: () => { - return "v7.0.6"; + return "v7.0.7"; } }); @@ -205,6 +205,21 @@ function tEnvoy(openpgpRef = openpgp, naclRef = nacl, sha256Ref = sha256) { if(mixed == null) { throw "tEnvoy Fatal Error: argument mixed of method util.mixedToUint8Array is required and does not have a default value."; } + let isObjectArray = true; + if(typeof mixed == "object" && mixed.constructor == Object) { + let keys = Object.keys(mixed); + let returnUint8Array = new Uint8Array(keys.length); + for(let i = 0; i < keys.length && isObjectArray; i++) { + if(keys[i] != i || !Number.isInteger(mixed[keys[i]]) || mixed[keys[i]] < 0 || mixed[keys[i]] > 255) { + isObjectArray = false; + } else { + returnUint8Array[i] = mixed[keys[i]]; + } + } + if(isObjectArray) { + return returnUint8Array; + } + } if(mixed instanceof Uint8Array) { if(includeType) { let returnUint8Array = new Uint8Array(mixed.length + 1); diff --git a/tenvoy.js b/tenvoy.js index 62ef0e05..1d979134 100644 --- a/tenvoy.js +++ b/tenvoy.js @@ -46033,7 +46033,7 @@ function tEnvoy(openpgpRef = openpgp, naclRef = nacl, sha256Ref = sha256) { Object.defineProperty(this, "version", { get: () => { - return "v7.0.6"; + return "v7.0.7"; } }); @@ -46222,6 +46222,21 @@ function tEnvoy(openpgpRef = openpgp, naclRef = nacl, sha256Ref = sha256) { if(mixed == null) { throw "tEnvoy Fatal Error: argument mixed of method util.mixedToUint8Array is required and does not have a default value."; } + let isObjectArray = true; + if(typeof mixed == "object" && mixed.constructor == Object) { + let keys = Object.keys(mixed); + let returnUint8Array = new Uint8Array(keys.length); + for(let i = 0; i < keys.length && isObjectArray; i++) { + if(keys[i] != i || !Number.isInteger(mixed[keys[i]]) || mixed[keys[i]] < 0 || mixed[keys[i]] > 255) { + isObjectArray = false; + } else { + returnUint8Array[i] = mixed[keys[i]]; + } + } + if(isObjectArray) { + return returnUint8Array; + } + } if(mixed instanceof Uint8Array) { if(includeType) { let returnUint8Array = new Uint8Array(mixed.length + 1);