@xyo-network/hash 2.107.1 → 2.107.4

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 (69) hide show
  1. package/dist/browser/index-browser.cjs +410 -1
  2. package/dist/browser/index-browser.cjs.map +1 -1
  3. package/dist/browser/index-browser.js +384 -1
  4. package/dist/browser/index-browser.js.map +1 -1
  5. package/dist/browser/worker/index.cjs +63 -1
  6. package/dist/browser/worker/index.cjs.map +1 -1
  7. package/dist/browser/worker/index.js +48 -1
  8. package/dist/browser/worker/index.js.map +1 -1
  9. package/dist/browser/worker/jsHash.cjs +33 -1
  10. package/dist/browser/worker/jsHash.cjs.map +1 -1
  11. package/dist/browser/worker/jsHash.js +9 -1
  12. package/dist/browser/worker/jsHash.js.map +1 -1
  13. package/dist/browser/worker/jsHashNode.cjs +36 -1
  14. package/dist/browser/worker/jsHashNode.cjs.map +1 -1
  15. package/dist/browser/worker/jsHashNode.js +23 -1
  16. package/dist/browser/worker/jsHashNode.js.map +1 -1
  17. package/dist/browser/worker/subtleHash.cjs +10 -1
  18. package/dist/browser/worker/subtleHash.cjs.map +1 -1
  19. package/dist/browser/worker/subtleHash.js +8 -1
  20. package/dist/browser/worker/subtleHash.js.map +1 -1
  21. package/dist/browser/worker/subtleHashNode.cjs +35 -1
  22. package/dist/browser/worker/subtleHashNode.cjs.map +1 -1
  23. package/dist/browser/worker/subtleHashNode.js +22 -1
  24. package/dist/browser/worker/subtleHashNode.js.map +1 -1
  25. package/dist/browser/worker/wasmHash.cjs +11 -1
  26. package/dist/browser/worker/wasmHash.cjs.map +1 -1
  27. package/dist/browser/worker/wasmHash.js +9 -1
  28. package/dist/browser/worker/wasmHash.js.map +1 -1
  29. package/dist/browser/worker/wasmHashNode.cjs +36 -1
  30. package/dist/browser/worker/wasmHashNode.cjs.map +1 -1
  31. package/dist/browser/worker/wasmHashNode.js +23 -1
  32. package/dist/browser/worker/wasmHashNode.js.map +1 -1
  33. package/dist/neutral/index.cjs +392 -1
  34. package/dist/neutral/index.cjs.map +1 -1
  35. package/dist/neutral/index.js +367 -1
  36. package/dist/neutral/index.js.map +1 -1
  37. package/dist/node/index.cjs +406 -1
  38. package/dist/node/index.cjs.map +1 -1
  39. package/dist/node/index.js +371 -1
  40. package/dist/node/index.js.map +1 -1
  41. package/dist/node/worker/index.cjs +69 -1
  42. package/dist/node/worker/index.cjs.map +1 -1
  43. package/dist/node/worker/index.js +48 -1
  44. package/dist/node/worker/index.js.map +1 -1
  45. package/dist/node/worker/jsHash.cjs +33 -1
  46. package/dist/node/worker/jsHash.cjs.map +1 -1
  47. package/dist/node/worker/jsHash.js +9 -1
  48. package/dist/node/worker/jsHash.js.map +1 -1
  49. package/dist/node/worker/jsHashNode.cjs +40 -1
  50. package/dist/node/worker/jsHashNode.cjs.map +1 -1
  51. package/dist/node/worker/jsHashNode.js +23 -1
  52. package/dist/node/worker/jsHashNode.js.map +1 -1
  53. package/dist/node/worker/subtleHash.cjs +10 -1
  54. package/dist/node/worker/subtleHash.cjs.map +1 -1
  55. package/dist/node/worker/subtleHash.js +8 -1
  56. package/dist/node/worker/subtleHash.js.map +1 -1
  57. package/dist/node/worker/subtleHashNode.cjs +39 -1
  58. package/dist/node/worker/subtleHashNode.cjs.map +1 -1
  59. package/dist/node/worker/subtleHashNode.js +22 -1
  60. package/dist/node/worker/subtleHashNode.js.map +1 -1
  61. package/dist/node/worker/wasmHash.cjs +11 -1
  62. package/dist/node/worker/wasmHash.cjs.map +1 -1
  63. package/dist/node/worker/wasmHash.js +9 -1
  64. package/dist/node/worker/wasmHash.js.map +1 -1
  65. package/dist/node/worker/wasmHashNode.cjs +40 -1
  66. package/dist/node/worker/wasmHashNode.cjs.map +1 -1
  67. package/dist/node/worker/wasmHashNode.js +23 -1
  68. package/dist/node/worker/wasmHashNode.js.map +1 -1
  69. package/package.json +4 -4
@@ -1,2 +1,368 @@
1
- var U=Object.defineProperty;var a=(r,t)=>U(r,"name",{value:t,configurable:!0}),i=(r=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(r,{get:(t,s)=>(typeof require<"u"?require:t)[s]}):r)(function(r){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+r+'" is not supported')});import{typeOf as A}from"@xylabs/typeof";var q=a(r=>{if(r===null||Array.isArray(r))return!1;if(r===void 0||Object.keys(r).length===0)return!0;for(let[t]of Object.values(r))if(A(t)==="object"){if(q(t))return!0}else if(t===void 0)return!0;return!1},"hasEmptyFields");import{Worker as B}from"@xylabs/threads";var m=a(r=>{try{let t=r?.toString().slice(6)??"";return new B(t,{fromSource:!0})}catch{return}},"createNodeWorker");import{assertEx as j}from"@xylabs/assert";import{asHash as f,hexFromArrayBuffer as $}from"@xylabs/hex";import{ObjectWrapper as E}from"@xylabs/object";import{subtle as v}from"@xylabs/platform";import{Pool as z,spawn as C}from"@xylabs/threads";import{WasmSupport as J}from"@xyo-network/wasm";import{sha256 as L}from"hash-wasm";import b from"sha.js";import{typeOf as I}from"@xylabs/typeof";var h=a(r=>{if(r===null||Array.isArray(r))return r;let t={};for(let[s,e]of Object.entries(r))I(e)==="object"?t[s]=h(e):e!==void 0&&(t[s]=e);return t},"removeEmptyFields");import{omitBy as x}from"@xylabs/lodash";import{isObject as N}from"@xylabs/object";var T=a(r=>N(r)?c(r):r,"subSort"),c=a(r=>{let t={},s=Object.keys(r);for(let e of s.sort())t[e]=T(r[e]);return t},"sortFields");var H=a(()=>{let r=i("sha.js"),{asHash:t}=i("@xylabs/hex"),{expose:s}=i("@xylabs/threads/worker");s({hash(e){return t(r("sha256").update(e).digest().toString("hex"),!0)}})},"jsHashFunc");var P=a(()=>{let{subtle:r}=i("@xylabs/platform"),{expose:t}=i("@xylabs/threads/worker");t({async hash(s){return await r.digest("SHA-256",s)}})},"subtleHashFunc");var g=a(()=>{let{sha256:r}=i("hash-wasm"),{asHash:t}=i("@xylabs/hex"),{expose:s}=i("@xylabs/threads/worker");s({async hash(e){return t(await r(e),!0)}})},"wasmHashFunc");var k=new J(["bigInt"]),W=a(r=>(t,s)=>(j(typeof s=="string",()=>`Invalid key type [${s}, ${typeof s}]`),s.startsWith(r)),"omitByPredicate"),l=class r extends E{static{a(this,"PayloadHasher")}static allowHashPooling=!0;static allowSubtle=!0;static createBrowserWorker;static createNodeWorker;static initialized=(()=>{globalThis.xyo=globalThis.xyo??{},globalThis.xyo.hashing&&console.warn("Two static instances of PayloadHasher detected"),globalThis.xyo,globalThis.xyo})();static jsHashWorkerUrl;static subtleHashWorkerUrl;static warnIfUsingJsHash=!0;static wasmHashWorkerUrl;static wasmInitialized=k.initialize();static wasmSupport=k;static _jsHashPool;static _subtleHashPool;static _wasmHashPool;static get jsHashPool(){if(!this.allowHashPooling||this._jsHashPool===null)return null;try{return this._jsHashPool=this._jsHashPool??(this.jsHashWorkerUrl?this.createWorkerPool(this.jsHashWorkerUrl,H):null)}catch{return console.warn("Creating js hash worker failed"),this._jsHashPool=null,null}}static get subtleHashPool(){if(!this.allowHashPooling||this._subtleHashPool===null)return null;try{return this._subtleHashPool=this._subtleHashPool??(this.subtleHashWorkerUrl?this.createWorkerPool(this.subtleHashWorkerUrl,P):null)}catch{return console.warn("Creating subtle hash worker failed"),this._subtleHashPool=null,null}}static get wasmHashPool(){if(!this.allowHashPooling||this._wasmHashPool===null)return null;try{return this._wasmHashPool=this._wasmHashPool??(this.wasmHashWorkerUrl?this.createWorkerPool(this.wasmHashWorkerUrl,g):null)}catch{return console.warn("Creating wasm hash worker failed"),this._wasmHashPool=null,null}}static createWorker(t,s){return t&&console.debug(`createWorker: ${t}`),j(this.createBrowserWorker?.(t)??this.createNodeWorker?.(s),()=>"Unable to create worker")}static async filterExcludeByHash(t=[],s){let e=Array.isArray(s)?s:[s];return(await this.hashPairs(t)).filter(([o,n])=>!e.includes(n))?.map(o=>o[0])}static async filterIncludeByHash(t=[],s){let e=Array.isArray(s)?s:[s];return(await this.hashPairs(t)).filter(([o,n])=>e.includes(n))?.map(o=>o[0])}static async findByHash(t=[],s){return(await this.hashPairs(t)).find(([e,o])=>o===s)?.[0]}static async hash(t){let s=this.stringifyHashFields(t);if(r.allowSubtle)try{let o=new TextEncoder().encode(s),n=await this.subtleHash(o);return $(n,{bitLength:256})}catch{r.allowSubtle=!1}if(await this.wasmInitialized,this.wasmSupport.canUseWasm)try{return this.wasmHash(s)}catch{this.wasmSupport.allowWasm=!1}return await this.jsHash(s)}static hashFields(t){return c(h(x(t,W("_"))))}static async hashPairs(t){return await Promise.all(t.map(async s=>[s,await r.hash(s)]))}static hashSync(t){return f(b("sha256").update(this.stringifyHashFields(t)).digest().toString("hex"),!0)}static async hashes(t){return t?await Promise.all(t.map(s=>this.hash(s))):void 0}static async jsHash(t){r.warnIfUsingJsHash&&console.warn("Using jsHash [No subtle or wasm?]");let s=this.jsHashPool;return s===null?f(b("sha256").update(t).digest().toString("hex"),!0):await s.queue(async e=>await e.hash(t))}static json(t,s=!1){return c(h(s?t:x(t,W("_"))))}static jsonPayload(t,s=!1){return this.json(t,s)}static stringifyHashFields(t){return JSON.stringify(this.hashFields(t))}static async subtleHash(t){let s=this.subtleHashPool;return s===null?await v.digest("SHA-256",t):await s.queue(async e=>await e.hash(t))}static async wasmHash(t){let s=this.wasmHashPool;return s===null?f(await L(t),!0):s.queue(async e=>await e.hash(t))}static createWorkerPool(t,s,e=8){return t&&console.debug(`createWorkerPool: ${t}`),z(a(()=>C(this.createWorker(t,s)),"createFunc"),e)}async hash(){return await r.hash(this.obj)}hashSync(){return r.hashSync(this.obj)}json(t=!1){return r.json(this.obj,t)}};l.createNodeWorker=m;var p=class extends l{static{a(this,"NodePayloadHasher")}static createNodeWorker=m};import{assertEx as S}from"@xylabs/assert";import{mapValues as V,merge as D,omitBy as y,pickBy as w}from"@xylabs/lodash";import{isObject as F}from"@xylabs/object";var d=a((r,t,s)=>{if(Array.isArray(r))return r;let e=w(r,F),o=w(r,u=>!F(u)),n=y(e,t),O=y(o,t),_=V(n,u=>d(u,t,s));return D({},O,_)},"deepBy"),qt=a((r,t)=>d(r,(s,e)=>(S(typeof e=="string",()=>`Invalid key type [${e}, ${typeof e}]`),e.startsWith(t)),y),"deepOmitPrefixedFields"),Bt=a(r=>d(r,(t,s)=>(S(typeof s=="string",()=>`Invalid key type [${s}, ${typeof s}]`),s.startsWith("_")),w),"deepPickUnderscoreFields");export{p as PayloadHasher,d as deepBy,qt as deepOmitPrefixedFields,Bt as deepPickUnderscoreFields,q as hasEmptyFields,h as removeEmptyFields,c as sortFields};
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
4
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
5
+ }) : x)(function(x) {
6
+ if (typeof require !== "undefined") return require.apply(this, arguments);
7
+ throw Error('Dynamic require of "' + x + '" is not supported');
8
+ });
9
+
10
+ // src/hasEmptyFields.ts
11
+ import { typeOf } from "@xylabs/typeof";
12
+ var hasEmptyFields = /* @__PURE__ */ __name((obj) => {
13
+ if (obj === null || Array.isArray(obj)) return false;
14
+ if (obj === void 0 || Object.keys(obj).length === 0) return true;
15
+ for (const [value] of Object.values(obj)) {
16
+ if (typeOf(value) === "object") {
17
+ if (hasEmptyFields(value)) return true;
18
+ } else if (value === void 0) {
19
+ return true;
20
+ }
21
+ }
22
+ return false;
23
+ }, "hasEmptyFields");
24
+
25
+ // src/createNodeWorker.ts
26
+ import { Worker } from "@xylabs/threads";
27
+ var createNodeWorker = /* @__PURE__ */ __name((func) => {
28
+ try {
29
+ const code = func?.toString().slice(6) ?? "";
30
+ const w = new Worker(
31
+ code,
32
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
33
+ {
34
+ fromSource: true
35
+ }
36
+ );
37
+ return w;
38
+ } catch {
39
+ return;
40
+ }
41
+ }, "createNodeWorker");
42
+
43
+ // src/PayloadHasher.ts
44
+ import { assertEx } from "@xylabs/assert";
45
+ import { asHash, hexFromArrayBuffer } from "@xylabs/hex";
46
+ import { ObjectWrapper } from "@xylabs/object";
47
+ import { subtle } from "@xylabs/platform";
48
+ import { Pool, spawn } from "@xylabs/threads";
49
+ import { WasmSupport } from "@xyo-network/wasm";
50
+ import { sha256 } from "hash-wasm";
51
+ import shajs from "sha.js";
52
+
53
+ // src/removeEmptyFields.ts
54
+ import { typeOf as typeOf2 } from "@xylabs/typeof";
55
+ var removeEmptyFields = /* @__PURE__ */ __name((obj) => {
56
+ if (obj === null || Array.isArray(obj)) return obj;
57
+ const newObject = {};
58
+ for (const [key, value] of Object.entries(obj)) {
59
+ if (typeOf2(value) === "object") {
60
+ newObject[key] = removeEmptyFields(value);
61
+ } else if (value !== void 0) {
62
+ newObject[key] = value;
63
+ }
64
+ }
65
+ return newObject;
66
+ }, "removeEmptyFields");
67
+
68
+ // src/PayloadHasher.ts
69
+ import { omitBy } from "@xylabs/lodash";
70
+
71
+ // src/sortFields.ts
72
+ import { isObject } from "@xylabs/object";
73
+ var subSort = /* @__PURE__ */ __name((value) => {
74
+ return isObject(value) ? sortFields(value) : value;
75
+ }, "subSort");
76
+ var sortFields = /* @__PURE__ */ __name((obj) => {
77
+ const result = {};
78
+ const keys = Object.keys(obj);
79
+ for (const key of keys.sort()) {
80
+ result[key] = subSort(obj[key]);
81
+ }
82
+ return result;
83
+ }, "sortFields");
84
+
85
+ // src/worker/jsHashNode.ts
86
+ var jsHashFunc = /* @__PURE__ */ __name(() => {
87
+ const shajs2 = __require("sha.js");
88
+ const { asHash: asHash2 } = __require("@xylabs/hex");
89
+ const { expose } = __require("@xylabs/threads/worker");
90
+ expose({
91
+ hash(data) {
92
+ return asHash2(shajs2("sha256").update(data).digest().toString("hex"), true);
93
+ }
94
+ });
95
+ }, "jsHashFunc");
96
+
97
+ // src/worker/subtleHashNode.ts
98
+ var subtleHashFunc = /* @__PURE__ */ __name(() => {
99
+ const { subtle: subtle2 } = __require("@xylabs/platform");
100
+ const { expose } = __require("@xylabs/threads/worker");
101
+ expose({
102
+ async hash(data) {
103
+ return await subtle2.digest("SHA-256", data);
104
+ }
105
+ });
106
+ }, "subtleHashFunc");
107
+
108
+ // src/worker/wasmHashNode.ts
109
+ var wasmHashFunc = /* @__PURE__ */ __name(() => {
110
+ const { sha256: sha2562 } = __require("hash-wasm");
111
+ const { asHash: asHash2 } = __require("@xylabs/hex");
112
+ const { expose } = __require("@xylabs/threads/worker");
113
+ expose({
114
+ async hash(data) {
115
+ return asHash2(await sha2562(data), true);
116
+ }
117
+ });
118
+ }, "wasmHashFunc");
119
+
120
+ // src/PayloadHasher.ts
121
+ var wasmSupportStatic = new WasmSupport([
122
+ "bigInt"
123
+ ]);
124
+ var omitByPredicate = /* @__PURE__ */ __name((prefix) => (_, key) => {
125
+ assertEx(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
126
+ return key.startsWith(prefix);
127
+ }, "omitByPredicate");
128
+ var PayloadHasher = class _PayloadHasher extends ObjectWrapper {
129
+ static {
130
+ __name(this, "PayloadHasher");
131
+ }
132
+ static allowHashPooling = true;
133
+ static allowSubtle = true;
134
+ static createBrowserWorker;
135
+ static createNodeWorker;
136
+ static initialized = (() => {
137
+ globalThis.xyo = globalThis.xyo ?? {};
138
+ if (globalThis.xyo.hashing) {
139
+ console.warn("Two static instances of PayloadHasher detected");
140
+ }
141
+ globalThis.xyo === globalThis.xyo;
142
+ })();
143
+ static jsHashWorkerUrl;
144
+ static subtleHashWorkerUrl;
145
+ static warnIfUsingJsHash = true;
146
+ static wasmHashWorkerUrl;
147
+ static wasmInitialized = wasmSupportStatic.initialize();
148
+ static wasmSupport = wasmSupportStatic;
149
+ // These get set to null if they fail to create and then we just don't use workers - needed for storybook
150
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
151
+ static _jsHashPool;
152
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
153
+ static _subtleHashPool;
154
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
155
+ static _wasmHashPool;
156
+ static get jsHashPool() {
157
+ if (!this.allowHashPooling || this._jsHashPool === null) {
158
+ return null;
159
+ }
160
+ try {
161
+ return this._jsHashPool = this._jsHashPool ?? (this.jsHashWorkerUrl ? this.createWorkerPool(this.jsHashWorkerUrl, jsHashFunc) : null);
162
+ } catch {
163
+ console.warn("Creating js hash worker failed");
164
+ this._jsHashPool = null;
165
+ return null;
166
+ }
167
+ }
168
+ static get subtleHashPool() {
169
+ if (!this.allowHashPooling || this._subtleHashPool === null) {
170
+ return null;
171
+ }
172
+ try {
173
+ return this._subtleHashPool = this._subtleHashPool ?? (this.subtleHashWorkerUrl ? this.createWorkerPool(this.subtleHashWorkerUrl, subtleHashFunc) : null);
174
+ } catch {
175
+ console.warn("Creating subtle hash worker failed");
176
+ this._subtleHashPool = null;
177
+ return null;
178
+ }
179
+ }
180
+ static get wasmHashPool() {
181
+ if (!this.allowHashPooling || this._wasmHashPool === null) {
182
+ return null;
183
+ }
184
+ try {
185
+ return this._wasmHashPool = this._wasmHashPool ?? (this.wasmHashWorkerUrl ? this.createWorkerPool(this.wasmHashWorkerUrl, wasmHashFunc) : null);
186
+ } catch {
187
+ console.warn("Creating wasm hash worker failed");
188
+ this._wasmHashPool = null;
189
+ return null;
190
+ }
191
+ }
192
+ static createWorker(url, func) {
193
+ if (url) console.debug(`createWorker: ${url}`);
194
+ return assertEx(this.createBrowserWorker?.(url) ?? this.createNodeWorker?.(func), () => "Unable to create worker");
195
+ }
196
+ static async filterExcludeByHash(objs = [], hash) {
197
+ const hashes = Array.isArray(hash) ? hash : [
198
+ hash
199
+ ];
200
+ return (await this.hashPairs(objs)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0]);
201
+ }
202
+ static async filterIncludeByHash(objs = [], hash) {
203
+ const hashes = Array.isArray(hash) ? hash : [
204
+ hash
205
+ ];
206
+ return (await this.hashPairs(objs)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0]);
207
+ }
208
+ static async findByHash(objs = [], hash) {
209
+ return (await this.hashPairs(objs)).find(([_, objHash]) => objHash === hash)?.[0];
210
+ }
211
+ /**
212
+ * Asynchronously hashes a payload
213
+ * @param obj A payload
214
+ * @returns The payload hash
215
+ */
216
+ static async hash(obj) {
217
+ const stringToHash = this.stringifyHashFields(obj);
218
+ if (_PayloadHasher.allowSubtle) {
219
+ try {
220
+ const enc = new TextEncoder();
221
+ const data = enc.encode(stringToHash);
222
+ const hashArray = await this.subtleHash(data);
223
+ return hexFromArrayBuffer(hashArray, {
224
+ bitLength: 256
225
+ });
226
+ } catch {
227
+ _PayloadHasher.allowSubtle = false;
228
+ }
229
+ }
230
+ await this.wasmInitialized;
231
+ if (this.wasmSupport.canUseWasm) {
232
+ try {
233
+ return this.wasmHash(stringToHash);
234
+ } catch {
235
+ this.wasmSupport.allowWasm = false;
236
+ }
237
+ }
238
+ return await this.jsHash(stringToHash);
239
+ }
240
+ static hashFields(obj) {
241
+ return sortFields(removeEmptyFields(omitBy(obj, omitByPredicate("_"))));
242
+ }
243
+ /**
244
+ * Creates an array of payload/hash tuples based on the payloads passed in
245
+ * @param objs Any array of payloads
246
+ * @returns An array of payload/hash tuples
247
+ */
248
+ static async hashPairs(objs) {
249
+ return await Promise.all(objs.map(async (obj) => [
250
+ obj,
251
+ await _PayloadHasher.hash(obj)
252
+ ]));
253
+ }
254
+ /**
255
+ * Synchronously hashes a payload
256
+ * @param obj A payload
257
+ * @returns The payload hash
258
+ */
259
+ static hashSync(obj) {
260
+ return asHash(shajs("sha256").update(this.stringifyHashFields(obj)).digest().toString("hex"), true);
261
+ }
262
+ /**
263
+ * Creates an array of payload hashes based on the payloads passed in
264
+ * @param objs Any array of payloads
265
+ * @returns An array of payload hashes
266
+ */
267
+ static async hashes(objs) {
268
+ return objs ? await Promise.all(objs.map((obj) => this.hash(obj))) : void 0;
269
+ }
270
+ static async jsHash(data) {
271
+ if (_PayloadHasher.warnIfUsingJsHash) {
272
+ console.warn("Using jsHash [No subtle or wasm?]");
273
+ }
274
+ const pool = this.jsHashPool;
275
+ return pool === null ? asHash(shajs("sha256").update(data).digest().toString("hex"), true) : await pool.queue(async (thread) => await thread.hash(data));
276
+ }
277
+ /**
278
+ * Returns a clone of the payload that is JSON safe
279
+ * @param obj A payload
280
+ * @param meta Keeps underscore (meta) fields if set to true
281
+ * @returns Returns a clone of the payload that is JSON safe
282
+ */
283
+ static json(payload, meta = false) {
284
+ return sortFields(removeEmptyFields(meta ? payload : omitBy(payload, omitByPredicate("_"))));
285
+ }
286
+ /** @deprecated us json instead */
287
+ static jsonPayload(payload, meta = false) {
288
+ return this.json(payload, meta);
289
+ }
290
+ static stringifyHashFields(obj) {
291
+ return JSON.stringify(this.hashFields(obj));
292
+ }
293
+ static async subtleHash(data) {
294
+ const pool = this.subtleHashPool;
295
+ return pool === null ? await subtle.digest("SHA-256", data) : await pool.queue(async (thread) => await thread.hash(data));
296
+ }
297
+ static async wasmHash(data) {
298
+ const pool = this.wasmHashPool;
299
+ return pool === null ? asHash(await sha256(data), true) : pool.queue(async (thread) => await thread.hash(data));
300
+ }
301
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
302
+ static createWorkerPool(url, func, size = 8) {
303
+ if (url) console.debug(`createWorkerPool: ${url}`);
304
+ const createFunc = /* @__PURE__ */ __name(() => spawn(this.createWorker(url, func)), "createFunc");
305
+ return Pool(createFunc, size);
306
+ }
307
+ async hash() {
308
+ return await _PayloadHasher.hash(this.obj);
309
+ }
310
+ hashSync() {
311
+ return _PayloadHasher.hashSync(this.obj);
312
+ }
313
+ /**
314
+ * Returns a clone of the payload that is JSON safe
315
+ * @param meta Keeps underscore (meta) fields if set to true
316
+ * @returns Returns a clone of the payload that is JSON safe
317
+ */
318
+ json(meta = false) {
319
+ return _PayloadHasher.json(this.obj, meta);
320
+ }
321
+ };
322
+
323
+ // src/NodePayloadHasher.ts
324
+ PayloadHasher.createNodeWorker = createNodeWorker;
325
+ var NodePayloadHasher = class extends PayloadHasher {
326
+ static {
327
+ __name(this, "NodePayloadHasher");
328
+ }
329
+ static createNodeWorker = createNodeWorker;
330
+ };
331
+
332
+ // src/removeFields.ts
333
+ import { assertEx as assertEx2 } from "@xylabs/assert";
334
+ import { mapValues, merge, omitBy as omitBy2, pickBy } from "@xylabs/lodash";
335
+ import { isObject as isObject2 } from "@xylabs/object";
336
+ var deepBy = /* @__PURE__ */ __name((obj, predicate, func) => {
337
+ if (Array.isArray(obj)) {
338
+ return obj;
339
+ }
340
+ const onlyObjects = pickBy(obj, isObject2);
341
+ const nonObjects = pickBy(obj, (value) => !isObject2(value));
342
+ const pickedObjects = omitBy2(onlyObjects, predicate);
343
+ const pickedNonObjects = omitBy2(nonObjects, predicate);
344
+ const processedObjects = mapValues(pickedObjects, (obj2) => deepBy(obj2, predicate, func));
345
+ return merge({}, pickedNonObjects, processedObjects);
346
+ }, "deepBy");
347
+ var deepOmitPrefixedFields = /* @__PURE__ */ __name((obj, prefix) => {
348
+ return deepBy(obj, (_, key) => {
349
+ assertEx2(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
350
+ return key.startsWith(prefix);
351
+ }, omitBy2);
352
+ }, "deepOmitPrefixedFields");
353
+ var deepPickUnderscoreFields = /* @__PURE__ */ __name((obj) => {
354
+ return deepBy(obj, (_, key) => {
355
+ assertEx2(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
356
+ return key.startsWith("_");
357
+ }, pickBy);
358
+ }, "deepPickUnderscoreFields");
359
+ export {
360
+ NodePayloadHasher as PayloadHasher,
361
+ deepBy,
362
+ deepOmitPrefixedFields,
363
+ deepPickUnderscoreFields,
364
+ hasEmptyFields,
365
+ removeEmptyFields,
366
+ sortFields
367
+ };
2
368
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hasEmptyFields.ts","../../src/createNodeWorker.ts","../../src/PayloadHasher.ts","../../src/removeEmptyFields.ts","../../src/sortFields.ts","../../src/worker/jsHashNode.ts","../../src/worker/subtleHashNode.ts","../../src/worker/wasmHashNode.ts","../../src/NodePayloadHasher.ts","../../src/removeFields.ts"],"sourcesContent":["import { EmptyObject } from '@xylabs/object'\nimport { typeOf } from '@xylabs/typeof'\n\nexport const hasEmptyFields = <T extends EmptyObject>(obj: T): boolean => {\n if (obj === null || Array.isArray(obj)) return false\n\n if (obj === undefined || Object.keys(obj).length === 0) return true\n\n for (const [value] of Object.values(obj)) {\n if (typeOf(value) === 'object') {\n if (hasEmptyFields(value as Record<string, unknown>)) return true\n } else if (value === undefined) {\n return true\n }\n }\n return false\n}\n","import { Worker } from '@xylabs/threads'\n\nexport const createNodeWorker = (func?: () => unknown) => {\n try {\n const code = func?.toString().slice(6) ?? ''\n const w = new Worker(\n code,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n { fromSource: true } as any,\n )\n return w\n } catch {\n return\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { asHash, Hash, hexFromArrayBuffer } from '@xylabs/hex'\nimport { EmptyObject, ObjectWrapper } from '@xylabs/object'\nimport { subtle } from '@xylabs/platform'\nimport { ModuleThread, Pool, spawn, Worker } from '@xylabs/threads'\n// eslint-disable-next-line import/no-unresolved\nimport { WorkerModule } from '@xylabs/threads/dist/types/worker'\nimport { WasmSupport } from '@xyo-network/wasm'\nimport { sha256 } from 'hash-wasm'\nimport shajs from 'sha.js'\n\nimport { removeEmptyFields } from './removeEmptyFields'\nimport { omitBy } from '@xylabs/lodash'\nimport { sortFields } from './sortFields'\nimport { jsHashFunc, subtleHashFunc, wasmHashFunc } from './worker'\n\nconst wasmSupportStatic = new WasmSupport(['bigInt'])\n\nconst omitByPredicate = (prefix: string) => (_: unknown, key: string) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n}\n\nexport class PayloadHasher<T extends EmptyObject = EmptyObject> extends ObjectWrapper<T> {\n static allowHashPooling = true\n static allowSubtle = true\n static createBrowserWorker?: (url?: URL) => Worker | undefined\n static createNodeWorker?: (func?: () => unknown) => Worker | undefined\n\n static initialized = (() => {\n globalThis.xyo = globalThis.xyo ?? {}\n if (globalThis.xyo.hashing) {\n console.warn('Two static instances of PayloadHasher detected')\n }\n globalThis.xyo === globalThis.xyo ?? { hashing: PayloadHasher }\n })()\n\n static jsHashWorkerUrl?: URL\n static subtleHashWorkerUrl?: URL\n\n static warnIfUsingJsHash = true\n\n static wasmHashWorkerUrl?: URL\n\n static readonly wasmInitialized = wasmSupportStatic.initialize()\n static readonly wasmSupport = wasmSupportStatic\n\n // These get set to null if they fail to create and then we just don't use workers - needed for storybook\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static _jsHashPool?: Pool<ModuleThread<WorkerModule<any>>> | null\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static _subtleHashPool?: Pool<ModuleThread<WorkerModule<any>>> | null\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static _wasmHashPool?: Pool<ModuleThread<WorkerModule<any>>> | null\n\n private static get jsHashPool() {\n if (!this.allowHashPooling || this._jsHashPool === null) {\n return null\n }\n try {\n return (this._jsHashPool = this._jsHashPool ?? (this.jsHashWorkerUrl ? this.createWorkerPool(this.jsHashWorkerUrl, jsHashFunc) : null))\n } catch {\n console.warn('Creating js hash worker failed')\n this._jsHashPool = null\n return null\n }\n }\n\n private static get subtleHashPool() {\n if (!this.allowHashPooling || this._subtleHashPool === null) {\n return null\n }\n try {\n return (this._subtleHashPool =\n this._subtleHashPool ?? (this.subtleHashWorkerUrl ? this.createWorkerPool(this.subtleHashWorkerUrl, subtleHashFunc) : null))\n } catch {\n console.warn('Creating subtle hash worker failed')\n this._subtleHashPool = null\n return null\n }\n }\n\n private static get wasmHashPool() {\n if (!this.allowHashPooling || this._wasmHashPool === null) {\n return null\n }\n try {\n return (this._wasmHashPool =\n this._wasmHashPool ?? (this.wasmHashWorkerUrl ? this.createWorkerPool(this.wasmHashWorkerUrl, wasmHashFunc) : null))\n } catch {\n console.warn('Creating wasm hash worker failed')\n this._wasmHashPool = null\n return null\n }\n }\n\n static createWorker(url?: URL, func?: () => unknown) {\n if (url) console.debug(`createWorker: ${url}`)\n return assertEx(this.createBrowserWorker?.(url) ?? this.createNodeWorker?.(func), () => 'Unable to create worker')\n }\n\n static async filterExcludeByHash<T extends EmptyObject>(objs: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.hashPairs(objs)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByHash<T extends EmptyObject>(objs: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.hashPairs(objs)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByHash<T extends EmptyObject>(objs: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.hashPairs(objs)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n /**\n * Asynchronously hashes a payload\n * @param obj A payload\n * @returns The payload hash\n */\n static async hash<T extends EmptyObject>(obj: T): Promise<Hash> {\n const stringToHash = this.stringifyHashFields(obj)\n\n if (PayloadHasher.allowSubtle) {\n try {\n const enc = new TextEncoder()\n const data = enc.encode(stringToHash)\n const hashArray = await this.subtleHash(data)\n return hexFromArrayBuffer(hashArray, { bitLength: 256 })\n } catch {\n PayloadHasher.allowSubtle = false\n }\n }\n\n await this.wasmInitialized\n if (this.wasmSupport.canUseWasm) {\n try {\n return this.wasmHash(stringToHash)\n } catch {\n this.wasmSupport.allowWasm = false\n }\n }\n return await this.jsHash(stringToHash)\n }\n\n static hashFields<T extends EmptyObject>(obj: T): T {\n return sortFields(removeEmptyFields(omitBy(obj, omitByPredicate('_')))) as T\n }\n\n /**\n * Creates an array of payload/hash tuples based on the payloads passed in\n * @param objs Any array of payloads\n * @returns An array of payload/hash tuples\n */\n static async hashPairs<T extends EmptyObject>(objs: T[]): Promise<[T, Hash][]> {\n return await Promise.all(objs.map<Promise<[T, Hash]>>(async (obj) => [obj, await PayloadHasher.hash(obj)]))\n }\n\n /**\n * Synchronously hashes a payload\n * @param obj A payload\n * @returns The payload hash\n */\n static hashSync<T extends EmptyObject>(obj: T): Hash {\n return asHash(shajs('sha256').update(this.stringifyHashFields(obj)).digest().toString('hex'), true)\n }\n\n /**\n * Creates an array of payload hashes based on the payloads passed in\n * @param objs Any array of payloads\n * @returns An array of payload hashes\n */\n static async hashes<T extends EmptyObject>(objs?: T[]): Promise<Hash[] | undefined> {\n return objs ? await Promise.all(objs.map((obj) => this.hash(obj))) : undefined\n }\n\n static async jsHash(data: string) {\n if (PayloadHasher.warnIfUsingJsHash) {\n console.warn('Using jsHash [No subtle or wasm?]')\n }\n const pool = this.jsHashPool\n return pool === null ?\n asHash(shajs('sha256').update(data).digest().toString('hex'), true)\n : await pool.queue(async (thread) => await thread.hash(data))\n }\n\n /**\n * Returns a clone of the payload that is JSON safe\n * @param obj A payload\n * @param meta Keeps underscore (meta) fields if set to true\n * @returns Returns a clone of the payload that is JSON safe\n */\n static json<T extends EmptyObject>(payload: T, meta = false): T {\n return sortFields(removeEmptyFields(meta ? payload : omitBy(payload, omitByPredicate('_')))) as T\n }\n\n /** @deprecated us json instead */\n static jsonPayload<T extends EmptyObject>(payload: T, meta = false): T {\n return this.json(payload, meta)\n }\n\n static stringifyHashFields<T extends EmptyObject>(obj: T) {\n return JSON.stringify(this.hashFields(obj))\n }\n\n static async subtleHash(data: Uint8Array): Promise<ArrayBuffer> {\n const pool = this.subtleHashPool\n return pool === null ? await subtle.digest('SHA-256', data) : await pool.queue(async (thread) => await thread.hash(data))\n }\n\n static async wasmHash(data: string) {\n const pool = this.wasmHashPool\n return pool === null ? asHash(await sha256(data), true) : pool.queue(async (thread) => await thread.hash(data))\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static createWorkerPool<T extends WorkerModule<any>>(url?: URL, func?: () => unknown, size = 8) {\n if (url) console.debug(`createWorkerPool: ${url}`)\n const createFunc = () => spawn<T>(this.createWorker(url, func))\n return Pool(createFunc, size)\n }\n\n async hash(): Promise<Hash> {\n return await PayloadHasher.hash(this.obj)\n }\n\n hashSync(): Hash {\n return PayloadHasher.hashSync(this.obj)\n }\n\n /**\n * Returns a clone of the payload that is JSON safe\n * @param meta Keeps underscore (meta) fields if set to true\n * @returns Returns a clone of the payload that is JSON safe\n */\n json(meta = false): T {\n return PayloadHasher.json(this.obj, meta)\n }\n}\n","import { AnyObject, EmptyObject } from '@xylabs/object'\nimport { typeOf } from '@xylabs/typeof'\n\nexport const removeEmptyFields = <T extends EmptyObject>(obj: T): T => {\n if (obj === null || Array.isArray(obj)) return obj\n\n const newObject: AnyObject = {}\n for (const [key, value] of Object.entries(obj)) {\n if (typeOf(value) === 'object') {\n newObject[key] = removeEmptyFields(value as Record<string, unknown>)\n } else if (value !== undefined) {\n newObject[key] = value\n }\n }\n return newObject as T\n}\n","import { AnyObject, EmptyObject, isObject } from '@xylabs/object'\n\n//if an object, sub-sort\nconst subSort = (value: unknown) => {\n return isObject(value) ? sortFields(value) : value\n}\n\nexport const sortFields = <T extends EmptyObject>(obj: T) => {\n const result: AnyObject = {}\n const keys = Object.keys(obj) as (keyof T)[]\n for (const key of keys.sort()) {\n result[key] = subSort(obj[key])\n }\n return result as T\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nexport const jsHashFunc = () => {\n const shajs = require('sha.js')\n const { asHash } = require('@xylabs/hex')\n const { expose } = require('@xylabs/threads/worker')\n\n expose({\n hash(data: string) {\n return asHash(shajs('sha256').update(data).digest().toString('hex'), true)\n },\n })\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nexport const subtleHashFunc = () => {\n const { subtle } = require('@xylabs/platform')\n const { expose } = require('@xylabs/threads/worker')\n\n expose({\n async hash(data: ArrayBuffer) {\n return await subtle.digest('SHA-256', data)\n },\n })\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nexport const wasmHashFunc = () => {\n const { sha256 } = require('hash-wasm')\n const { asHash } = require('@xylabs/hex')\n const { expose } = require('@xylabs/threads/worker')\n\n expose({\n async hash(data: string) {\n return asHash(await sha256(data), true)\n },\n })\n}\n","import { createNodeWorker } from './createNodeWorker'\nimport { PayloadHasher } from './PayloadHasher'\n\nPayloadHasher.createNodeWorker = createNodeWorker\n\nexport class NodePayloadHasher extends PayloadHasher {\n static override createNodeWorker = createNodeWorker\n}\n","import { assertEx } from '@xylabs/assert'\nimport { mapValues, merge, omitBy, pickBy } from '@xylabs/lodash'\nimport { EmptyObject, isObject } from '@xylabs/object'\ntype ValueKeyIteratee<T> = (value: T, key: string) => unknown\n\nexport const deepBy = <T extends EmptyObject>(obj: T, predicate: ValueKeyIteratee<T>, func: typeof omitBy | typeof pickBy): T => {\n if (Array.isArray(obj)) {\n return obj\n }\n\n //pick the child objects\n const onlyObjects = pickBy<T>(obj, isObject)\n\n //pick the child non-objects\n const nonObjects = pickBy<T>(obj, (value) => !isObject(value))\n\n const pickedObjects = omitBy(onlyObjects, predicate)\n const pickedNonObjects = omitBy(nonObjects, predicate)\n\n const processedObjects = mapValues(pickedObjects, (obj: T) => deepBy(obj, predicate, func))\n\n return merge({}, pickedNonObjects, processedObjects) as T\n}\n\nexport const deepOmitPrefixedFields = <T extends EmptyObject>(obj: T, prefix: string): T => {\n return deepBy(\n obj,\n (_, key) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n },\n omitBy,\n )\n}\n\nexport const deepPickUnderscoreFields = <T extends EmptyObject>(obj: T): T => {\n return deepBy(\n obj,\n (_, key) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith('_')\n },\n pickBy,\n )\n}\n"],"mappings":"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","names":["typeOf","hasEmptyFields","__name","obj","Array","isArray","undefined","Object","keys","length","value","values","typeOf","Worker","createNodeWorker","__name","func","code","toString","slice","Worker","fromSource","assertEx","asHash","hexFromArrayBuffer","ObjectWrapper","subtle","Pool","spawn","WasmSupport","sha256","shajs","typeOf","removeEmptyFields","__name","obj","Array","isArray","newObject","key","value","Object","entries","typeOf","undefined","omitBy","isObject","subSort","__name","value","isObject","sortFields","obj","result","keys","Object","key","sort","jsHashFunc","__name","shajs","require","asHash","expose","hash","data","update","digest","toString","subtleHashFunc","__name","subtle","require","expose","hash","data","digest","wasmHashFunc","__name","sha256","require","asHash","expose","hash","data","wasmSupportStatic","WasmSupport","omitByPredicate","__name","prefix","_","key","assertEx","startsWith","PayloadHasher","ObjectWrapper","allowHashPooling","allowSubtle","createBrowserWorker","createNodeWorker","initialized","globalThis","xyo","hashing","console","warn","jsHashWorkerUrl","subtleHashWorkerUrl","warnIfUsingJsHash","wasmHashWorkerUrl","wasmInitialized","initialize","wasmSupport","_jsHashPool","_subtleHashPool","_wasmHashPool","jsHashPool","createWorkerPool","jsHashFunc","subtleHashPool","subtleHashFunc","wasmHashPool","wasmHashFunc","createWorker","url","func","debug","filterExcludeByHash","objs","hash","hashes","Array","isArray","hashPairs","filter","objHash","includes","map","pair","filterIncludeByHash","findByHash","find","obj","stringToHash","stringifyHashFields","data","TextEncoder","encode","hashArray","subtleHash","hexFromArrayBuffer","bitLength","canUseWasm","wasmHash","allowWasm","jsHash","hashFields","sortFields","removeEmptyFields","omitBy","Promise","all","hashSync","asHash","shajs","update","digest","toString","undefined","pool","queue","thread","json","payload","meta","jsonPayload","JSON","stringify","subtle","sha256","size","Pool","spawn","PayloadHasher","createNodeWorker","NodePayloadHasher","assertEx","mapValues","merge","omitBy","pickBy","isObject","deepBy","__name","obj","predicate","func","Array","isArray","onlyObjects","pickBy","isObject","nonObjects","value","pickedObjects","omitBy","pickedNonObjects","processedObjects","mapValues","merge","deepOmitPrefixedFields","prefix","_","key","assertEx","startsWith","deepPickUnderscoreFields"]}
1
+ {"version":3,"sources":["../../src/hasEmptyFields.ts","../../src/createNodeWorker.ts","../../src/PayloadHasher.ts","../../src/removeEmptyFields.ts","../../src/sortFields.ts","../../src/worker/jsHashNode.ts","../../src/worker/subtleHashNode.ts","../../src/worker/wasmHashNode.ts","../../src/NodePayloadHasher.ts","../../src/removeFields.ts"],"sourcesContent":["import { EmptyObject } from '@xylabs/object'\nimport { typeOf } from '@xylabs/typeof'\n\nexport const hasEmptyFields = <T extends EmptyObject>(obj: T): boolean => {\n if (obj === null || Array.isArray(obj)) return false\n\n if (obj === undefined || Object.keys(obj).length === 0) return true\n\n for (const [value] of Object.values(obj)) {\n if (typeOf(value) === 'object') {\n if (hasEmptyFields(value as Record<string, unknown>)) return true\n } else if (value === undefined) {\n return true\n }\n }\n return false\n}\n","import { Worker } from '@xylabs/threads'\n\nexport const createNodeWorker = (func?: () => unknown) => {\n try {\n const code = func?.toString().slice(6) ?? ''\n const w = new Worker(\n code,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n { fromSource: true } as any,\n )\n return w\n } catch {\n return\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { asHash, Hash, hexFromArrayBuffer } from '@xylabs/hex'\nimport { EmptyObject, ObjectWrapper } from '@xylabs/object'\nimport { subtle } from '@xylabs/platform'\nimport { ModuleThread, Pool, spawn, Worker } from '@xylabs/threads'\n// eslint-disable-next-line import/no-unresolved\nimport { WorkerModule } from '@xylabs/threads/dist/types/worker'\nimport { WasmSupport } from '@xyo-network/wasm'\nimport { sha256 } from 'hash-wasm'\nimport shajs from 'sha.js'\n\nimport { removeEmptyFields } from './removeEmptyFields'\nimport { omitBy } from '@xylabs/lodash'\nimport { sortFields } from './sortFields'\nimport { jsHashFunc, subtleHashFunc, wasmHashFunc } from './worker'\n\nconst wasmSupportStatic = new WasmSupport(['bigInt'])\n\nconst omitByPredicate = (prefix: string) => (_: unknown, key: string) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n}\n\nexport class PayloadHasher<T extends EmptyObject = EmptyObject> extends ObjectWrapper<T> {\n static allowHashPooling = true\n static allowSubtle = true\n static createBrowserWorker?: (url?: URL) => Worker | undefined\n static createNodeWorker?: (func?: () => unknown) => Worker | undefined\n\n static initialized = (() => {\n globalThis.xyo = globalThis.xyo ?? {}\n if (globalThis.xyo.hashing) {\n console.warn('Two static instances of PayloadHasher detected')\n }\n globalThis.xyo === globalThis.xyo ?? { hashing: PayloadHasher }\n })()\n\n static jsHashWorkerUrl?: URL\n static subtleHashWorkerUrl?: URL\n\n static warnIfUsingJsHash = true\n\n static wasmHashWorkerUrl?: URL\n\n static readonly wasmInitialized = wasmSupportStatic.initialize()\n static readonly wasmSupport = wasmSupportStatic\n\n // These get set to null if they fail to create and then we just don't use workers - needed for storybook\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static _jsHashPool?: Pool<ModuleThread<WorkerModule<any>>> | null\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static _subtleHashPool?: Pool<ModuleThread<WorkerModule<any>>> | null\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static _wasmHashPool?: Pool<ModuleThread<WorkerModule<any>>> | null\n\n private static get jsHashPool() {\n if (!this.allowHashPooling || this._jsHashPool === null) {\n return null\n }\n try {\n return (this._jsHashPool = this._jsHashPool ?? (this.jsHashWorkerUrl ? this.createWorkerPool(this.jsHashWorkerUrl, jsHashFunc) : null))\n } catch {\n console.warn('Creating js hash worker failed')\n this._jsHashPool = null\n return null\n }\n }\n\n private static get subtleHashPool() {\n if (!this.allowHashPooling || this._subtleHashPool === null) {\n return null\n }\n try {\n return (this._subtleHashPool =\n this._subtleHashPool ?? (this.subtleHashWorkerUrl ? this.createWorkerPool(this.subtleHashWorkerUrl, subtleHashFunc) : null))\n } catch {\n console.warn('Creating subtle hash worker failed')\n this._subtleHashPool = null\n return null\n }\n }\n\n private static get wasmHashPool() {\n if (!this.allowHashPooling || this._wasmHashPool === null) {\n return null\n }\n try {\n return (this._wasmHashPool =\n this._wasmHashPool ?? (this.wasmHashWorkerUrl ? this.createWorkerPool(this.wasmHashWorkerUrl, wasmHashFunc) : null))\n } catch {\n console.warn('Creating wasm hash worker failed')\n this._wasmHashPool = null\n return null\n }\n }\n\n static createWorker(url?: URL, func?: () => unknown) {\n if (url) console.debug(`createWorker: ${url}`)\n return assertEx(this.createBrowserWorker?.(url) ?? this.createNodeWorker?.(func), () => 'Unable to create worker')\n }\n\n static async filterExcludeByHash<T extends EmptyObject>(objs: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.hashPairs(objs)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByHash<T extends EmptyObject>(objs: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.hashPairs(objs)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByHash<T extends EmptyObject>(objs: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.hashPairs(objs)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n /**\n * Asynchronously hashes a payload\n * @param obj A payload\n * @returns The payload hash\n */\n static async hash<T extends EmptyObject>(obj: T): Promise<Hash> {\n const stringToHash = this.stringifyHashFields(obj)\n\n if (PayloadHasher.allowSubtle) {\n try {\n const enc = new TextEncoder()\n const data = enc.encode(stringToHash)\n const hashArray = await this.subtleHash(data)\n return hexFromArrayBuffer(hashArray, { bitLength: 256 })\n } catch {\n PayloadHasher.allowSubtle = false\n }\n }\n\n await this.wasmInitialized\n if (this.wasmSupport.canUseWasm) {\n try {\n return this.wasmHash(stringToHash)\n } catch {\n this.wasmSupport.allowWasm = false\n }\n }\n return await this.jsHash(stringToHash)\n }\n\n static hashFields<T extends EmptyObject>(obj: T): T {\n return sortFields(removeEmptyFields(omitBy(obj, omitByPredicate('_')))) as T\n }\n\n /**\n * Creates an array of payload/hash tuples based on the payloads passed in\n * @param objs Any array of payloads\n * @returns An array of payload/hash tuples\n */\n static async hashPairs<T extends EmptyObject>(objs: T[]): Promise<[T, Hash][]> {\n return await Promise.all(objs.map<Promise<[T, Hash]>>(async (obj) => [obj, await PayloadHasher.hash(obj)]))\n }\n\n /**\n * Synchronously hashes a payload\n * @param obj A payload\n * @returns The payload hash\n */\n static hashSync<T extends EmptyObject>(obj: T): Hash {\n return asHash(shajs('sha256').update(this.stringifyHashFields(obj)).digest().toString('hex'), true)\n }\n\n /**\n * Creates an array of payload hashes based on the payloads passed in\n * @param objs Any array of payloads\n * @returns An array of payload hashes\n */\n static async hashes<T extends EmptyObject>(objs?: T[]): Promise<Hash[] | undefined> {\n return objs ? await Promise.all(objs.map((obj) => this.hash(obj))) : undefined\n }\n\n static async jsHash(data: string) {\n if (PayloadHasher.warnIfUsingJsHash) {\n console.warn('Using jsHash [No subtle or wasm?]')\n }\n const pool = this.jsHashPool\n return pool === null ?\n asHash(shajs('sha256').update(data).digest().toString('hex'), true)\n : await pool.queue(async (thread) => await thread.hash(data))\n }\n\n /**\n * Returns a clone of the payload that is JSON safe\n * @param obj A payload\n * @param meta Keeps underscore (meta) fields if set to true\n * @returns Returns a clone of the payload that is JSON safe\n */\n static json<T extends EmptyObject>(payload: T, meta = false): T {\n return sortFields(removeEmptyFields(meta ? payload : omitBy(payload, omitByPredicate('_')))) as T\n }\n\n /** @deprecated us json instead */\n static jsonPayload<T extends EmptyObject>(payload: T, meta = false): T {\n return this.json(payload, meta)\n }\n\n static stringifyHashFields<T extends EmptyObject>(obj: T) {\n return JSON.stringify(this.hashFields(obj))\n }\n\n static async subtleHash(data: Uint8Array): Promise<ArrayBuffer> {\n const pool = this.subtleHashPool\n return pool === null ? await subtle.digest('SHA-256', data) : await pool.queue(async (thread) => await thread.hash(data))\n }\n\n static async wasmHash(data: string) {\n const pool = this.wasmHashPool\n return pool === null ? asHash(await sha256(data), true) : pool.queue(async (thread) => await thread.hash(data))\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private static createWorkerPool<T extends WorkerModule<any>>(url?: URL, func?: () => unknown, size = 8) {\n if (url) console.debug(`createWorkerPool: ${url}`)\n const createFunc = () => spawn<T>(this.createWorker(url, func))\n return Pool(createFunc, size)\n }\n\n async hash(): Promise<Hash> {\n return await PayloadHasher.hash(this.obj)\n }\n\n hashSync(): Hash {\n return PayloadHasher.hashSync(this.obj)\n }\n\n /**\n * Returns a clone of the payload that is JSON safe\n * @param meta Keeps underscore (meta) fields if set to true\n * @returns Returns a clone of the payload that is JSON safe\n */\n json(meta = false): T {\n return PayloadHasher.json(this.obj, meta)\n }\n}\n","import { AnyObject, EmptyObject } from '@xylabs/object'\nimport { typeOf } from '@xylabs/typeof'\n\nexport const removeEmptyFields = <T extends EmptyObject>(obj: T): T => {\n if (obj === null || Array.isArray(obj)) return obj\n\n const newObject: AnyObject = {}\n for (const [key, value] of Object.entries(obj)) {\n if (typeOf(value) === 'object') {\n newObject[key] = removeEmptyFields(value as Record<string, unknown>)\n } else if (value !== undefined) {\n newObject[key] = value\n }\n }\n return newObject as T\n}\n","import { AnyObject, EmptyObject, isObject } from '@xylabs/object'\n\n//if an object, sub-sort\nconst subSort = (value: unknown) => {\n return isObject(value) ? sortFields(value) : value\n}\n\nexport const sortFields = <T extends EmptyObject>(obj: T) => {\n const result: AnyObject = {}\n const keys = Object.keys(obj) as (keyof T)[]\n for (const key of keys.sort()) {\n result[key] = subSort(obj[key])\n }\n return result as T\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nexport const jsHashFunc = () => {\n const shajs = require('sha.js')\n const { asHash } = require('@xylabs/hex')\n const { expose } = require('@xylabs/threads/worker')\n\n expose({\n hash(data: string) {\n return asHash(shajs('sha256').update(data).digest().toString('hex'), true)\n },\n })\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nexport const subtleHashFunc = () => {\n const { subtle } = require('@xylabs/platform')\n const { expose } = require('@xylabs/threads/worker')\n\n expose({\n async hash(data: ArrayBuffer) {\n return await subtle.digest('SHA-256', data)\n },\n })\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nexport const wasmHashFunc = () => {\n const { sha256 } = require('hash-wasm')\n const { asHash } = require('@xylabs/hex')\n const { expose } = require('@xylabs/threads/worker')\n\n expose({\n async hash(data: string) {\n return asHash(await sha256(data), true)\n },\n })\n}\n","import { createNodeWorker } from './createNodeWorker'\nimport { PayloadHasher } from './PayloadHasher'\n\nPayloadHasher.createNodeWorker = createNodeWorker\n\nexport class NodePayloadHasher extends PayloadHasher {\n static override createNodeWorker = createNodeWorker\n}\n","import { assertEx } from '@xylabs/assert'\nimport { mapValues, merge, omitBy, pickBy } from '@xylabs/lodash'\nimport { EmptyObject, isObject } from '@xylabs/object'\ntype ValueKeyIteratee<T> = (value: T, key: string) => unknown\n\nexport const deepBy = <T extends EmptyObject>(obj: T, predicate: ValueKeyIteratee<T>, func: typeof omitBy | typeof pickBy): T => {\n if (Array.isArray(obj)) {\n return obj\n }\n\n //pick the child objects\n const onlyObjects = pickBy<T>(obj, isObject)\n\n //pick the child non-objects\n const nonObjects = pickBy<T>(obj, (value) => !isObject(value))\n\n const pickedObjects = omitBy(onlyObjects, predicate)\n const pickedNonObjects = omitBy(nonObjects, predicate)\n\n const processedObjects = mapValues(pickedObjects, (obj: T) => deepBy(obj, predicate, func))\n\n return merge({}, pickedNonObjects, processedObjects) as T\n}\n\nexport const deepOmitPrefixedFields = <T extends EmptyObject>(obj: T, prefix: string): T => {\n return deepBy(\n obj,\n (_, key) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n },\n omitBy,\n )\n}\n\nexport const deepPickUnderscoreFields = <T extends EmptyObject>(obj: T): T => {\n return deepBy(\n obj,\n (_, key) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith('_')\n },\n pickBy,\n )\n}\n"],"mappings":"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","names":["typeOf","hasEmptyFields","obj","Array","isArray","undefined","Object","keys","length","value","values","typeOf","Worker","createNodeWorker","func","code","toString","slice","w","Worker","fromSource","assertEx","asHash","hexFromArrayBuffer","ObjectWrapper","subtle","Pool","spawn","WasmSupport","sha256","shajs","typeOf","removeEmptyFields","obj","Array","isArray","newObject","key","value","Object","entries","typeOf","undefined","omitBy","isObject","subSort","value","isObject","sortFields","obj","result","keys","Object","key","sort","jsHashFunc","shajs","require","asHash","expose","hash","data","update","digest","toString","subtleHashFunc","subtle","require","expose","hash","data","digest","wasmHashFunc","sha256","require","asHash","expose","hash","data","wasmSupportStatic","WasmSupport","omitByPredicate","prefix","_","key","assertEx","startsWith","PayloadHasher","ObjectWrapper","allowHashPooling","allowSubtle","createBrowserWorker","createNodeWorker","initialized","globalThis","xyo","hashing","console","warn","jsHashWorkerUrl","subtleHashWorkerUrl","warnIfUsingJsHash","wasmHashWorkerUrl","wasmInitialized","initialize","wasmSupport","_jsHashPool","_subtleHashPool","_wasmHashPool","jsHashPool","createWorkerPool","jsHashFunc","subtleHashPool","subtleHashFunc","wasmHashPool","wasmHashFunc","createWorker","url","func","debug","filterExcludeByHash","objs","hash","hashes","Array","isArray","hashPairs","filter","objHash","includes","map","pair","filterIncludeByHash","findByHash","find","obj","stringToHash","stringifyHashFields","enc","TextEncoder","data","encode","hashArray","subtleHash","hexFromArrayBuffer","bitLength","canUseWasm","wasmHash","allowWasm","jsHash","hashFields","sortFields","removeEmptyFields","omitBy","Promise","all","hashSync","asHash","shajs","update","digest","toString","undefined","pool","queue","thread","json","payload","meta","jsonPayload","JSON","stringify","subtle","sha256","size","createFunc","spawn","Pool","PayloadHasher","createNodeWorker","NodePayloadHasher","assertEx","mapValues","merge","omitBy","pickBy","isObject","deepBy","obj","predicate","func","Array","isArray","onlyObjects","pickBy","isObject","nonObjects","value","pickedObjects","omitBy","pickedNonObjects","processedObjects","mapValues","merge","deepOmitPrefixedFields","prefix","_","key","assertEx","startsWith","deepPickUnderscoreFields"]}