utils.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. /*!
  2. Copyright (c) Peculiar Ventures, LLC
  3. */
  4. 'use strict';
  5. Object.defineProperty(exports, '__esModule', { value: true });
  6. function getUTCDate(date) {
  7. return new Date(date.getTime() + (date.getTimezoneOffset() * 60000));
  8. }
  9. function getParametersValue(parameters, name, defaultValue) {
  10. var _a;
  11. if ((parameters instanceof Object) === false) {
  12. return defaultValue;
  13. }
  14. return (_a = parameters[name]) !== null && _a !== void 0 ? _a : defaultValue;
  15. }
  16. function bufferToHexCodes(inputBuffer, inputOffset = 0, inputLength = (inputBuffer.byteLength - inputOffset), insertSpace = false) {
  17. let result = "";
  18. for (const item of (new Uint8Array(inputBuffer, inputOffset, inputLength))) {
  19. const str = item.toString(16).toUpperCase();
  20. if (str.length === 1) {
  21. result += "0";
  22. }
  23. result += str;
  24. if (insertSpace) {
  25. result += " ";
  26. }
  27. }
  28. return result.trim();
  29. }
  30. function checkBufferParams(baseBlock, inputBuffer, inputOffset, inputLength) {
  31. if (!(inputBuffer instanceof ArrayBuffer)) {
  32. baseBlock.error = "Wrong parameter: inputBuffer must be \"ArrayBuffer\"";
  33. return false;
  34. }
  35. if (!inputBuffer.byteLength) {
  36. baseBlock.error = "Wrong parameter: inputBuffer has zero length";
  37. return false;
  38. }
  39. if (inputOffset < 0) {
  40. baseBlock.error = "Wrong parameter: inputOffset less than zero";
  41. return false;
  42. }
  43. if (inputLength < 0) {
  44. baseBlock.error = "Wrong parameter: inputLength less than zero";
  45. return false;
  46. }
  47. if ((inputBuffer.byteLength - inputOffset - inputLength) < 0) {
  48. baseBlock.error = "End of input reached before message was fully decoded (inconsistent offset and length values)";
  49. return false;
  50. }
  51. return true;
  52. }
  53. function utilFromBase(inputBuffer, inputBase) {
  54. let result = 0;
  55. if (inputBuffer.length === 1) {
  56. return inputBuffer[0];
  57. }
  58. for (let i = (inputBuffer.length - 1); i >= 0; i--) {
  59. result += inputBuffer[(inputBuffer.length - 1) - i] * Math.pow(2, inputBase * i);
  60. }
  61. return result;
  62. }
  63. function utilToBase(value, base, reserved = (-1)) {
  64. const internalReserved = reserved;
  65. let internalValue = value;
  66. let result = 0;
  67. let biggest = Math.pow(2, base);
  68. for (let i = 1; i < 8; i++) {
  69. if (value < biggest) {
  70. let retBuf;
  71. if (internalReserved < 0) {
  72. retBuf = new ArrayBuffer(i);
  73. result = i;
  74. }
  75. else {
  76. if (internalReserved < i) {
  77. return (new ArrayBuffer(0));
  78. }
  79. retBuf = new ArrayBuffer(internalReserved);
  80. result = internalReserved;
  81. }
  82. const retView = new Uint8Array(retBuf);
  83. for (let j = (i - 1); j >= 0; j--) {
  84. const basis = Math.pow(2, j * base);
  85. retView[result - j - 1] = Math.floor(internalValue / basis);
  86. internalValue -= (retView[result - j - 1]) * basis;
  87. }
  88. return retBuf;
  89. }
  90. biggest *= Math.pow(2, base);
  91. }
  92. return new ArrayBuffer(0);
  93. }
  94. function utilConcatBuf(...buffers) {
  95. let outputLength = 0;
  96. let prevLength = 0;
  97. for (const buffer of buffers) {
  98. outputLength += buffer.byteLength;
  99. }
  100. const retBuf = new ArrayBuffer(outputLength);
  101. const retView = new Uint8Array(retBuf);
  102. for (const buffer of buffers) {
  103. retView.set(new Uint8Array(buffer), prevLength);
  104. prevLength += buffer.byteLength;
  105. }
  106. return retBuf;
  107. }
  108. function utilConcatView(...views) {
  109. let outputLength = 0;
  110. let prevLength = 0;
  111. for (const view of views) {
  112. outputLength += view.length;
  113. }
  114. const retBuf = new ArrayBuffer(outputLength);
  115. const retView = new Uint8Array(retBuf);
  116. for (const view of views) {
  117. retView.set(view, prevLength);
  118. prevLength += view.length;
  119. }
  120. return retView;
  121. }
  122. function utilDecodeTC() {
  123. const buf = new Uint8Array(this.valueHex);
  124. if (this.valueHex.byteLength >= 2) {
  125. const condition1 = (buf[0] === 0xFF) && (buf[1] & 0x80);
  126. const condition2 = (buf[0] === 0x00) && ((buf[1] & 0x80) === 0x00);
  127. if (condition1 || condition2) {
  128. this.warnings.push("Needlessly long format");
  129. }
  130. }
  131. const bigIntBuffer = new ArrayBuffer(this.valueHex.byteLength);
  132. const bigIntView = new Uint8Array(bigIntBuffer);
  133. for (let i = 0; i < this.valueHex.byteLength; i++) {
  134. bigIntView[i] = 0;
  135. }
  136. bigIntView[0] = (buf[0] & 0x80);
  137. const bigInt = utilFromBase(bigIntView, 8);
  138. const smallIntBuffer = new ArrayBuffer(this.valueHex.byteLength);
  139. const smallIntView = new Uint8Array(smallIntBuffer);
  140. for (let j = 0; j < this.valueHex.byteLength; j++) {
  141. smallIntView[j] = buf[j];
  142. }
  143. smallIntView[0] &= 0x7F;
  144. const smallInt = utilFromBase(smallIntView, 8);
  145. return (smallInt - bigInt);
  146. }
  147. function utilEncodeTC(value) {
  148. const modValue = (value < 0) ? (value * (-1)) : value;
  149. let bigInt = 128;
  150. for (let i = 1; i < 8; i++) {
  151. if (modValue <= bigInt) {
  152. if (value < 0) {
  153. const smallInt = bigInt - modValue;
  154. const retBuf = utilToBase(smallInt, 8, i);
  155. const retView = new Uint8Array(retBuf);
  156. retView[0] |= 0x80;
  157. return retBuf;
  158. }
  159. let retBuf = utilToBase(modValue, 8, i);
  160. let retView = new Uint8Array(retBuf);
  161. if (retView[0] & 0x80) {
  162. const tempBuf = retBuf.slice(0);
  163. const tempView = new Uint8Array(tempBuf);
  164. retBuf = new ArrayBuffer(retBuf.byteLength + 1);
  165. retView = new Uint8Array(retBuf);
  166. for (let k = 0; k < tempBuf.byteLength; k++) {
  167. retView[k + 1] = tempView[k];
  168. }
  169. retView[0] = 0x00;
  170. }
  171. return retBuf;
  172. }
  173. bigInt *= Math.pow(2, 8);
  174. }
  175. return (new ArrayBuffer(0));
  176. }
  177. function isEqualBuffer(inputBuffer1, inputBuffer2) {
  178. if (inputBuffer1.byteLength !== inputBuffer2.byteLength) {
  179. return false;
  180. }
  181. const view1 = new Uint8Array(inputBuffer1);
  182. const view2 = new Uint8Array(inputBuffer2);
  183. for (let i = 0; i < view1.length; i++) {
  184. if (view1[i] !== view2[i]) {
  185. return false;
  186. }
  187. }
  188. return true;
  189. }
  190. function padNumber(inputNumber, fullLength) {
  191. const str = inputNumber.toString(10);
  192. if (fullLength < str.length) {
  193. return "";
  194. }
  195. const dif = fullLength - str.length;
  196. const padding = new Array(dif);
  197. for (let i = 0; i < dif; i++) {
  198. padding[i] = "0";
  199. }
  200. const paddingString = padding.join("");
  201. return paddingString.concat(str);
  202. }
  203. const base64Template = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
  204. const base64UrlTemplate = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=";
  205. function toBase64(input, useUrlTemplate = false, skipPadding = false, skipLeadingZeros = false) {
  206. let i = 0;
  207. let flag1 = 0;
  208. let flag2 = 0;
  209. let output = "";
  210. const template = (useUrlTemplate) ? base64UrlTemplate : base64Template;
  211. if (skipLeadingZeros) {
  212. let nonZeroPosition = 0;
  213. for (let i = 0; i < input.length; i++) {
  214. if (input.charCodeAt(i) !== 0) {
  215. nonZeroPosition = i;
  216. break;
  217. }
  218. }
  219. input = input.slice(nonZeroPosition);
  220. }
  221. while (i < input.length) {
  222. const chr1 = input.charCodeAt(i++);
  223. if (i >= input.length) {
  224. flag1 = 1;
  225. }
  226. const chr2 = input.charCodeAt(i++);
  227. if (i >= input.length) {
  228. flag2 = 1;
  229. }
  230. const chr3 = input.charCodeAt(i++);
  231. const enc1 = chr1 >> 2;
  232. const enc2 = ((chr1 & 0x03) << 4) | (chr2 >> 4);
  233. let enc3 = ((chr2 & 0x0F) << 2) | (chr3 >> 6);
  234. let enc4 = chr3 & 0x3F;
  235. if (flag1 === 1) {
  236. enc3 = enc4 = 64;
  237. }
  238. else {
  239. if (flag2 === 1) {
  240. enc4 = 64;
  241. }
  242. }
  243. if (skipPadding) {
  244. if (enc3 === 64) {
  245. output += `${template.charAt(enc1)}${template.charAt(enc2)}`;
  246. }
  247. else {
  248. if (enc4 === 64) {
  249. output += `${template.charAt(enc1)}${template.charAt(enc2)}${template.charAt(enc3)}`;
  250. }
  251. else {
  252. output += `${template.charAt(enc1)}${template.charAt(enc2)}${template.charAt(enc3)}${template.charAt(enc4)}`;
  253. }
  254. }
  255. }
  256. else {
  257. output += `${template.charAt(enc1)}${template.charAt(enc2)}${template.charAt(enc3)}${template.charAt(enc4)}`;
  258. }
  259. }
  260. return output;
  261. }
  262. function fromBase64(input, useUrlTemplate = false, cutTailZeros = false) {
  263. const template = (useUrlTemplate) ? base64UrlTemplate : base64Template;
  264. function indexOf(toSearch) {
  265. for (let i = 0; i < 64; i++) {
  266. if (template.charAt(i) === toSearch)
  267. return i;
  268. }
  269. return 64;
  270. }
  271. function test(incoming) {
  272. return ((incoming === 64) ? 0x00 : incoming);
  273. }
  274. let i = 0;
  275. let output = "";
  276. while (i < input.length) {
  277. const enc1 = indexOf(input.charAt(i++));
  278. const enc2 = (i >= input.length) ? 0x00 : indexOf(input.charAt(i++));
  279. const enc3 = (i >= input.length) ? 0x00 : indexOf(input.charAt(i++));
  280. const enc4 = (i >= input.length) ? 0x00 : indexOf(input.charAt(i++));
  281. const chr1 = (test(enc1) << 2) | (test(enc2) >> 4);
  282. const chr2 = ((test(enc2) & 0x0F) << 4) | (test(enc3) >> 2);
  283. const chr3 = ((test(enc3) & 0x03) << 6) | test(enc4);
  284. output += String.fromCharCode(chr1);
  285. if (enc3 !== 64) {
  286. output += String.fromCharCode(chr2);
  287. }
  288. if (enc4 !== 64) {
  289. output += String.fromCharCode(chr3);
  290. }
  291. }
  292. if (cutTailZeros) {
  293. const outputLength = output.length;
  294. let nonZeroStart = (-1);
  295. for (let i = (outputLength - 1); i >= 0; i--) {
  296. if (output.charCodeAt(i) !== 0) {
  297. nonZeroStart = i;
  298. break;
  299. }
  300. }
  301. if (nonZeroStart !== (-1)) {
  302. output = output.slice(0, nonZeroStart + 1);
  303. }
  304. else {
  305. output = "";
  306. }
  307. }
  308. return output;
  309. }
  310. function arrayBufferToString(buffer) {
  311. let resultString = "";
  312. const view = new Uint8Array(buffer);
  313. for (const element of view) {
  314. resultString += String.fromCharCode(element);
  315. }
  316. return resultString;
  317. }
  318. function stringToArrayBuffer(str) {
  319. const stringLength = str.length;
  320. const resultBuffer = new ArrayBuffer(stringLength);
  321. const resultView = new Uint8Array(resultBuffer);
  322. for (let i = 0; i < stringLength; i++) {
  323. resultView[i] = str.charCodeAt(i);
  324. }
  325. return resultBuffer;
  326. }
  327. const log2 = Math.log(2);
  328. function nearestPowerOf2(length) {
  329. const base = (Math.log(length) / log2);
  330. const floor = Math.floor(base);
  331. const round = Math.round(base);
  332. return ((floor === round) ? floor : round);
  333. }
  334. function clearProps(object, propsArray) {
  335. for (const prop of propsArray) {
  336. delete object[prop];
  337. }
  338. }
  339. exports.arrayBufferToString = arrayBufferToString;
  340. exports.bufferToHexCodes = bufferToHexCodes;
  341. exports.checkBufferParams = checkBufferParams;
  342. exports.clearProps = clearProps;
  343. exports.fromBase64 = fromBase64;
  344. exports.getParametersValue = getParametersValue;
  345. exports.getUTCDate = getUTCDate;
  346. exports.isEqualBuffer = isEqualBuffer;
  347. exports.nearestPowerOf2 = nearestPowerOf2;
  348. exports.padNumber = padNumber;
  349. exports.stringToArrayBuffer = stringToArrayBuffer;
  350. exports.toBase64 = toBase64;
  351. exports.utilConcatBuf = utilConcatBuf;
  352. exports.utilConcatView = utilConcatView;
  353. exports.utilDecodeTC = utilDecodeTC;
  354. exports.utilEncodeTC = utilEncodeTC;
  355. exports.utilFromBase = utilFromBase;
  356. exports.utilToBase = utilToBase;