@xyo-network/payload-builder 2.106.0 → 2.107.1

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 (51) hide show
  1. package/dist/browser/Builder.d.cts +0 -10
  2. package/dist/browser/Builder.d.cts.map +1 -1
  3. package/dist/browser/Builder.d.mts +0 -10
  4. package/dist/browser/Builder.d.mts.map +1 -1
  5. package/dist/browser/Builder.d.ts +0 -10
  6. package/dist/browser/Builder.d.ts.map +1 -1
  7. package/dist/browser/BuilderBase.d.cts +1 -3
  8. package/dist/browser/BuilderBase.d.cts.map +1 -1
  9. package/dist/browser/BuilderBase.d.mts +1 -3
  10. package/dist/browser/BuilderBase.d.mts.map +1 -1
  11. package/dist/browser/BuilderBase.d.ts +1 -3
  12. package/dist/browser/BuilderBase.d.ts.map +1 -1
  13. package/dist/browser/index.cjs +1 -268
  14. package/dist/browser/index.cjs.map +1 -1
  15. package/dist/browser/index.js +1 -247
  16. package/dist/browser/index.js.map +1 -1
  17. package/dist/neutral/Builder.d.cts +0 -10
  18. package/dist/neutral/Builder.d.cts.map +1 -1
  19. package/dist/neutral/Builder.d.mts +0 -10
  20. package/dist/neutral/Builder.d.mts.map +1 -1
  21. package/dist/neutral/Builder.d.ts +0 -10
  22. package/dist/neutral/Builder.d.ts.map +1 -1
  23. package/dist/neutral/BuilderBase.d.cts +1 -3
  24. package/dist/neutral/BuilderBase.d.cts.map +1 -1
  25. package/dist/neutral/BuilderBase.d.mts +1 -3
  26. package/dist/neutral/BuilderBase.d.mts.map +1 -1
  27. package/dist/neutral/BuilderBase.d.ts +1 -3
  28. package/dist/neutral/BuilderBase.d.ts.map +1 -1
  29. package/dist/neutral/index.cjs +1 -268
  30. package/dist/neutral/index.cjs.map +1 -1
  31. package/dist/neutral/index.js +1 -247
  32. package/dist/neutral/index.js.map +1 -1
  33. package/dist/node/Builder.d.cts +0 -10
  34. package/dist/node/Builder.d.cts.map +1 -1
  35. package/dist/node/Builder.d.mts +0 -10
  36. package/dist/node/Builder.d.mts.map +1 -1
  37. package/dist/node/Builder.d.ts +0 -10
  38. package/dist/node/Builder.d.ts.map +1 -1
  39. package/dist/node/BuilderBase.d.cts +1 -3
  40. package/dist/node/BuilderBase.d.cts.map +1 -1
  41. package/dist/node/BuilderBase.d.mts +1 -3
  42. package/dist/node/BuilderBase.d.mts.map +1 -1
  43. package/dist/node/BuilderBase.d.ts +1 -3
  44. package/dist/node/BuilderBase.d.ts.map +1 -1
  45. package/dist/node/index.cjs +1 -275
  46. package/dist/node/index.cjs.map +1 -1
  47. package/dist/node/index.js +1 -248
  48. package/dist/node/index.js.map +1 -1
  49. package/package.json +7 -6
  50. package/src/Builder.ts +10 -4
  51. package/src/BuilderBase.ts +8 -2
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["export * from './Builder'\nexport * from './BuilderBase'\nexport * from './Options'\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'\nimport { deepOmitPrefixedFields, PayloadHasher } from '@xyo-network/hash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase'\nimport { PayloadBuilderOptions } from './Options'\n\nexport interface BuildOptions {\n stamp?: boolean\n validate?: boolean\n}\n\nexport class PayloadBuilder<\n T extends Payload = Payload<AnyObject>,\n O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,\n> extends PayloadBuilderBase<T, O> {\n static async build<T extends Payload = Payload<AnyObject>>(payload: T, options?: BuildOptions): Promise<WithMeta<T>>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T[], options?: BuildOptions): Promise<WithMeta<T>[]>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T | T[], options: BuildOptions = {}) {\n if (Array.isArray(payload)) {\n return await Promise.all(payload.map((payload) => this.build(payload, options)))\n } else {\n const { stamp = false, validate = true } = options\n const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload as WithMeta<T>\n\n //check for legacy signatures\n const { _signatures } = payload as { _signatures?: JsonArray }\n if (_signatures && !incomingMeta.signatures) {\n incomingMeta.signatures = _signatures\n }\n\n const fields = removeMetaAndSchema(payload)\n const dataHashableFields = await PayloadBuilder.dataHashableFields(schema, fields)\n const $hash = validate || incomingDataHash === undefined ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash\n const $meta: JsonObject = { ...incomingMeta }\n if ($meta.timestamp === undefined && stamp) {\n $meta.timestamp = Date.now()\n }\n const hashableFields: WithMeta<Payload> = { ...dataHashableFields, $hash, schema }\n\n if (Object.keys($meta).length > 0) {\n hashableFields.$meta = $meta\n }\n\n return hashableFields as WithMeta<T>\n }\n }\n\n static async dataHash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return (await this.build(payload, options)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined, options?: BuildOptions): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[], options?: BuildOptions): Promise<Hash[] | undefined> {\n return payloads ?\n await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return built.$hash\n }),\n )\n : undefined\n }\n\n static async filterExclude<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash)\n }\n\n static async filterExcludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n static async hash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return await PayloadHasher.hash(await PayloadBuilder.build(payload, options))\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 Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map<Promise<[WithMeta<T>, Hash]>>(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\n }\n\n static async hashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n $meta?: JsonObject,\n $hash?: Hash,\n timestamp?: number,\n stamp = false,\n ): Promise<WithMeta<T>> {\n const dataFields = await this.dataHashableFields<T>(schema, fields)\n assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')\n const result: WithMeta<T> = deepOmitPrefixedFields<WithMeta<T>>(\n {\n ...dataFields,\n $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),\n schema,\n } as WithMeta<T>,\n '_',\n )\n\n const clonedMeta = { ...$meta }\n\n if (timestamp) {\n clonedMeta.timestamp = timestamp\n }\n\n if (clonedMeta.timestamp === undefined && stamp) {\n clonedMeta.timestamp = Date.now()\n }\n\n if (Object.keys(clonedMeta).length > 0) {\n result.$meta = clonedMeta\n }\n\n return result\n }\n\n static async hashes(payloads: undefined): Promise<undefined>\n static async hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async hashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return await PayloadHasher.hashes(payloads)\n }\n\n static async toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n result[pair[0].$hash] = pair[0]\n }\n return result\n }\n\n static async toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.dataHashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n /**\n * Creates an object map of payload hashes to payloads based on the payloads passed in\n * @param objs Any array of payloads\n * @returns A map of hashes to payloads\n */\n static async toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n static withoutMeta(payload: undefined): undefined\n static withoutMeta<T extends PayloadWithMeta>(payload: T): Omit<T, '$meta'>\n static withoutMeta<T extends PayloadWithMeta>(payloads: T[]): Omit<T, '$meta'>[]\n static withoutMeta<T extends PayloadWithMeta>(payloads: T | T[]) {\n if (Array.isArray(payloads)) {\n return payloads.map((payload) => this.withoutMeta(payload))\n } else {\n if (payloads) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, ...result } = payloads\n return result as Omit<T, '$meta'>\n }\n }\n }\n\n async build(options?: BuildOptions): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n return await PayloadBuilder.build<T>({ ...dataHashableFields, $meta: this._$meta, schema: this._schema } as Payload as T, options)\n }\n\n async hashableFields() {\n return await PayloadBuilder.hashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n this._$meta,\n )\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { deepOmitPrefixedFields, removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderOptions } from './Options'\n\nexport type WithOptionalSchema<T extends Payload> = Omit<T, 'schema'> & Partial<T>\n\nexport type WithoutSchema<T extends WithOptionalSchema<Payload>> = Omit<T, 'schema'>\n\nexport type WithoutMeta<T extends WithOptionalMeta<Payload>> = Omit<T, '$hash' | '$meta'>\n\nexport const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSchema<WithOptionalMeta<T>>): WithoutSchema<WithoutMeta<T>> => {\n const { ...result } = payload\n delete result.$hash\n delete result.$meta\n delete result.schema\n return result as Omit<T, 'schema'>\n}\n\nexport class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: WithoutSchema<WithoutMeta<T>>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = removeEmptyFields(fields ?? {}) as WithoutSchema<WithoutMeta<T>>\n this._$meta = meta\n }\n\n static dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promisable<Omit<T, '$hash' | '$meta'>> {\n const cleanFields = fields ? removeEmptyFields(fields) : undefined\n assertEx(\n cleanFields === undefined || isJsonObject(cleanFields),\n () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,\n )\n return deepOmitPrefixedFields(deepOmitPrefixedFields({ schema, ...cleanFields }, '$'), '_') as T\n }\n\n protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {\n const meta: JsonObject = { ...otherMeta }\n\n if (!meta.timestamp && stamp) {\n meta.timestamp = meta.timestamp ?? Date.now()\n }\n\n return meta\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta ?? (this._fields as WithMeta<T>).$meta\n return this\n }\n\n async dataHashableFields() {\n return await PayloadBuilderBase.dataHashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n )\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: WithOptionalSchema<WithOptionalMeta<T>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = removeMetaAndSchema<T>(fields)\n }\n return this\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n\n protected async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp)\n }\n}\n"],"mappings":"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","names":["import_assert","import_object","import_hash","removeMetaAndSchema","payload","result","$hash","$meta","schema","PayloadBuilderBase","_$meta","_fields","_schema","constructor","options","fields","meta","removeEmptyFields","dataHashableFields","cleanFields","undefined","assertEx","isJsonObject","JSON","stringify","toJson","deepOmitPrefixedFields","metaFields","dataHash","otherMeta","stamp","timestamp","Date","now","fieldsOnly","value","PayloadBuilder","PayloadBuilderBase","build","payload","options","Array","isArray","Promise","all","map","stamp","validate","schema","$hash","incomingDataHash","$meta","incomingMeta","_signatures","signatures","fields","removeMetaAndSchema","dataHashableFields","undefined","PayloadHasher","hash","timestamp","Date","now","hashableFields","Object","keys","length","dataHash","dataHashPairs","payloads","built","dataHashes","filterExclude","filterExcludeByHash","filterExcludeByDataHash","hashes","filter","_","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","dataFields","assertEx","isJsonObject","result","deepOmitPrefixedFields","clonedMeta","toAllHashMap","objs","toDataHashMap","toHashMap","withoutMeta","_$meta","_schema","_fields"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["export * from './Builder'\nexport * from './BuilderBase'\nexport * from './Options'\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { omitBy } from '@xylabs/lodash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase'\nimport { PayloadBuilderOptions } from './Options'\n\nexport interface BuildOptions {\n stamp?: boolean\n validate?: boolean\n}\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 PayloadBuilder<\n T extends Payload = Payload<AnyObject>,\n O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,\n> extends PayloadBuilderBase<T, O> {\n static async build<T extends Payload = Payload<AnyObject>>(payload: T, options?: BuildOptions): Promise<WithMeta<T>>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T[], options?: BuildOptions): Promise<WithMeta<T>[]>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T | T[], options: BuildOptions = {}) {\n if (Array.isArray(payload)) {\n return await Promise.all(payload.map((payload) => this.build(payload, options)))\n } else {\n const { stamp = false, validate = true } = options\n const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload as WithMeta<T>\n\n //check for legacy signatures\n const { _signatures } = payload as { _signatures?: JsonArray }\n if (_signatures && !incomingMeta.signatures) {\n incomingMeta.signatures = _signatures\n }\n\n const fields = removeMetaAndSchema(payload)\n const dataHashableFields = await PayloadBuilder.dataHashableFields(schema, fields)\n const $hash = validate || incomingDataHash === undefined ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash\n const $meta: JsonObject = { ...incomingMeta }\n if ($meta.timestamp === undefined && stamp) {\n $meta.timestamp = Date.now()\n }\n const hashableFields: WithMeta<Payload> = { ...dataHashableFields, $hash, schema }\n\n if (Object.keys($meta).length > 0) {\n hashableFields.$meta = $meta\n }\n\n return hashableFields as WithMeta<T>\n }\n }\n\n static async dataHash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return (await this.build(payload, options)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined, options?: BuildOptions): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[], options?: BuildOptions): Promise<Hash[] | undefined> {\n return payloads ?\n await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return built.$hash\n }),\n )\n : undefined\n }\n\n static async filterExclude<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash)\n }\n\n static async filterExcludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n static async hash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return await PayloadHasher.hash(await PayloadBuilder.build(payload, options))\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 Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map<Promise<[WithMeta<T>, Hash]>>(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\n }\n\n static async hashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n $meta?: JsonObject,\n $hash?: Hash,\n timestamp?: number,\n stamp = false,\n ): Promise<WithMeta<T>> {\n const dataFields = await this.dataHashableFields<T>(schema, fields)\n assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')\n const result: WithMeta<T> = omitBy(\n {\n ...dataFields,\n $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),\n schema,\n } as WithMeta<T>,\n omitByPredicate('_'),\n ) as WithMeta<T>\n\n const clonedMeta = { ...$meta }\n\n if (timestamp) {\n clonedMeta.timestamp = timestamp\n }\n\n if (clonedMeta.timestamp === undefined && stamp) {\n clonedMeta.timestamp = Date.now()\n }\n\n if (Object.keys(clonedMeta).length > 0) {\n result.$meta = clonedMeta\n }\n\n return result\n }\n\n static async hashes(payloads: undefined): Promise<undefined>\n static async hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async hashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return await PayloadHasher.hashes(payloads)\n }\n\n static async toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n result[pair[0].$hash] = pair[0]\n }\n return result\n }\n\n static async toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.dataHashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n /**\n * Creates an object map of payload hashes to payloads based on the payloads passed in\n * @param objs Any array of payloads\n * @returns A map of hashes to payloads\n */\n static async toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n static withoutMeta(payload: undefined): undefined\n static withoutMeta<T extends PayloadWithMeta>(payload: T): Omit<T, '$meta'>\n static withoutMeta<T extends PayloadWithMeta>(payloads: T[]): Omit<T, '$meta'>[]\n static withoutMeta<T extends PayloadWithMeta>(payloads: T | T[]) {\n if (Array.isArray(payloads)) {\n return payloads.map((payload) => this.withoutMeta(payload))\n } else {\n if (payloads) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, ...result } = payloads\n return result as Omit<T, '$meta'>\n }\n }\n }\n\n async build(options?: BuildOptions): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n return await PayloadBuilder.build<T>({ ...dataHashableFields, $meta: this._$meta, schema: this._schema } as Payload as T, options)\n }\n\n async hashableFields() {\n return await PayloadBuilder.hashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n this._$meta,\n )\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'\nimport { omitBy } from '@xylabs/lodash'\n\nimport { PayloadBuilderOptions } from './Options'\n\nexport type WithOptionalSchema<T extends Payload> = Omit<T, 'schema'> & Partial<T>\n\nexport type WithoutSchema<T extends WithOptionalSchema<Payload>> = Omit<T, 'schema'>\n\nexport type WithoutMeta<T extends WithOptionalMeta<Payload>> = Omit<T, '$hash' | '$meta'>\n\nexport const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSchema<WithOptionalMeta<T>>): WithoutSchema<WithoutMeta<T>> => {\n const { ...result } = payload\n delete result.$hash\n delete result.$meta\n delete result.schema\n return result as Omit<T, 'schema'>\n}\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 PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: WithoutSchema<WithoutMeta<T>>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = removeEmptyFields(fields ?? {}) as WithoutSchema<WithoutMeta<T>>\n this._$meta = meta\n }\n\n static dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promisable<Omit<T, '$hash' | '$meta'>> {\n const cleanFields = fields ? removeEmptyFields(fields) : undefined\n assertEx(\n cleanFields === undefined || isJsonObject(cleanFields),\n () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,\n )\n return omitBy(omitBy({ schema, ...cleanFields }, omitByPredicate('$')), omitByPredicate('_')) as unknown as T\n }\n\n protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {\n const meta: JsonObject = { ...otherMeta }\n\n if (!meta.timestamp && stamp) {\n meta.timestamp = meta.timestamp ?? Date.now()\n }\n\n return meta\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta ?? (this._fields as WithMeta<T>).$meta\n return this\n }\n\n async dataHashableFields() {\n return await PayloadBuilderBase.dataHashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n )\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: WithOptionalSchema<WithOptionalMeta<T>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = removeMetaAndSchema<T>(fields)\n }\n return this\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n\n protected async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp)\n }\n}\n"],"mappings":"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","names":["src_exports","__export","PayloadBuilder","PayloadBuilderBase","removeMetaAndSchema","__toCommonJS","import_assert","import_object","import_hash","import_lodash","import_assert","import_object","import_hash","import_lodash","removeMetaAndSchema","__name","payload","result","$hash","$meta","schema","omitByPredicate","prefix","_","key","assertEx","startsWith","PayloadBuilderBase","_$meta","_fields","_schema","constructor","options","fields","meta","removeEmptyFields","dataHashableFields","cleanFields","undefined","isJsonObject","JSON","stringify","toJson","omitBy","metaFields","dataHash","otherMeta","stamp","timestamp","Date","now","fieldsOnly","value","_PayloadBuilderBase","omitByPredicate","__name","prefix","_","key","assertEx","startsWith","PayloadBuilder","PayloadBuilderBase","build","payload","options","Array","isArray","Promise","all","map","stamp","validate","schema","$hash","incomingDataHash","$meta","incomingMeta","_signatures","signatures","fields","removeMetaAndSchema","dataHashableFields","undefined","PayloadHasher","hash","timestamp","Date","now","hashableFields","Object","keys","length","dataHash","dataHashPairs","payloads","built","dataHashes","filterExclude","filterExcludeByHash","filterExcludeByDataHash","_a","hashes","filter","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","dataFields","isJsonObject","result","omitBy","clonedMeta","toAllHashMap","objs","toDataHashMap","toHashMap","withoutMeta","_$meta","_schema","_fields","_PayloadBuilder"]}
@@ -1,249 +1,2 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/Builder.ts
5
- import { assertEx as assertEx2 } from "@xylabs/assert";
6
- import { isJsonObject as isJsonObject2 } from "@xylabs/object";
7
- import { deepOmitPrefixedFields as deepOmitPrefixedFields2, PayloadHasher } from "@xyo-network/hash";
8
-
9
- // src/BuilderBase.ts
10
- import { assertEx } from "@xylabs/assert";
11
- import { isJsonObject, toJson } from "@xylabs/object";
12
- import { deepOmitPrefixedFields, removeEmptyFields } from "@xyo-network/hash";
13
- var removeMetaAndSchema = /* @__PURE__ */ __name((payload) => {
14
- const { ...result } = payload;
15
- delete result.$hash;
16
- delete result.$meta;
17
- delete result.schema;
18
- return result;
19
- }, "removeMetaAndSchema");
20
- var _PayloadBuilderBase = class _PayloadBuilderBase {
21
- options;
22
- _$meta;
23
- _fields;
24
- _schema;
25
- constructor(options) {
26
- this.options = options;
27
- const { schema, fields, meta } = options;
28
- this._schema = schema;
29
- this._fields = removeEmptyFields(fields ?? {});
30
- this._$meta = meta;
31
- }
32
- static dataHashableFields(schema, fields) {
33
- const cleanFields = fields ? removeEmptyFields(fields) : void 0;
34
- assertEx(cleanFields === void 0 || isJsonObject(cleanFields), () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`);
35
- return deepOmitPrefixedFields(deepOmitPrefixedFields({
36
- schema,
37
- ...cleanFields
38
- }, "$"), "_");
39
- }
40
- static metaFields(dataHash, otherMeta, stamp = true) {
41
- const meta = {
42
- ...otherMeta
43
- };
44
- if (!meta.timestamp && stamp) {
45
- meta.timestamp = meta.timestamp ?? Date.now();
46
- }
47
- return meta;
48
- }
49
- $meta(meta) {
50
- this._$meta = meta ?? this._fields.$meta;
51
- return this;
52
- }
53
- async dataHashableFields() {
54
- return await _PayloadBuilderBase.dataHashableFields(assertEx(this._schema, () => "Payload: Missing Schema"), this._fields);
55
- }
56
- //we do not require sending in $hash since it will be generated anyway
57
- fields(fields) {
58
- if (fields) {
59
- const { $meta, $hash, schema, ...fieldsOnly } = fields;
60
- if ($meta) {
61
- this.$meta($meta);
62
- }
63
- if (schema) {
64
- this.schema(schema);
65
- }
66
- this._fields = removeMetaAndSchema(fields);
67
- }
68
- return this;
69
- }
70
- schema(value) {
71
- this._schema = value;
72
- }
73
- async metaFields(dataHash, stamp = true) {
74
- return await _PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp);
75
- }
76
- };
77
- __name(_PayloadBuilderBase, "PayloadBuilderBase");
78
- var PayloadBuilderBase = _PayloadBuilderBase;
79
-
80
- // src/Builder.ts
81
- var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
82
- static async build(payload, options = {}) {
83
- if (Array.isArray(payload)) {
84
- return await Promise.all(payload.map((payload2) => this.build(payload2, options)));
85
- } else {
86
- const { stamp = false, validate = true } = options;
87
- const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload;
88
- const { _signatures } = payload;
89
- if (_signatures && !incomingMeta.signatures) {
90
- incomingMeta.signatures = _signatures;
91
- }
92
- const fields = removeMetaAndSchema(payload);
93
- const dataHashableFields = await _PayloadBuilder.dataHashableFields(schema, fields);
94
- const $hash = validate || incomingDataHash === void 0 ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash;
95
- const $meta = {
96
- ...incomingMeta
97
- };
98
- if ($meta.timestamp === void 0 && stamp) {
99
- $meta.timestamp = Date.now();
100
- }
101
- const hashableFields = {
102
- ...dataHashableFields,
103
- $hash,
104
- schema
105
- };
106
- if (Object.keys($meta).length > 0) {
107
- hashableFields.$meta = $meta;
108
- }
109
- return hashableFields;
110
- }
111
- }
112
- static async dataHash(payload, options) {
113
- return (await this.build(payload, options)).$hash;
114
- }
115
- static async dataHashPairs(payloads, options) {
116
- return await Promise.all(payloads.map(async (payload) => {
117
- const built = await _PayloadBuilder.build(payload, options);
118
- return [
119
- built,
120
- built.$hash
121
- ];
122
- }));
123
- }
124
- static async dataHashes(payloads, options) {
125
- return payloads ? await Promise.all(payloads.map(async (payload) => {
126
- const built = await _PayloadBuilder.build(payload, options);
127
- return built.$hash;
128
- })) : void 0;
129
- }
130
- static async filterExclude(payloads = [], hash) {
131
- return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash);
132
- }
133
- static async filterExcludeByDataHash(payloads = [], hash) {
134
- var _a;
135
- const hashes = Array.isArray(hash) ? hash : [
136
- hash
137
- ];
138
- return (_a = (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))) == null ? void 0 : _a.map((pair) => pair[0]);
139
- }
140
- static async filterIncludeByDataHash(payloads = [], hash) {
141
- var _a;
142
- const hashes = Array.isArray(hash) ? hash : [
143
- hash
144
- ];
145
- return (_a = (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))) == null ? void 0 : _a.map((pair) => pair[0]);
146
- }
147
- static async findByDataHash(payloads = [], hash) {
148
- var _a;
149
- return (_a = (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)) == null ? void 0 : _a[0];
150
- }
151
- static async hash(payload, options) {
152
- return await PayloadHasher.hash(await _PayloadBuilder.build(payload, options));
153
- }
154
- /**
155
- * Creates an array of payload/hash tuples based on the payloads passed in
156
- * @param objs Any array of payloads
157
- * @returns An array of payload/hash tuples
158
- */
159
- static async hashPairs(payloads, options) {
160
- return await Promise.all(payloads.map(async (payload) => {
161
- const built = await _PayloadBuilder.build(payload, options);
162
- return [
163
- built,
164
- await _PayloadBuilder.hash(built)
165
- ];
166
- }));
167
- }
168
- static async hashableFields(schema, fields, $meta, $hash, timestamp, stamp = false) {
169
- const dataFields = await this.dataHashableFields(schema, fields);
170
- assertEx2($meta === void 0 || isJsonObject2($meta), () => "$meta must be JsonObject");
171
- const result = deepOmitPrefixedFields2({
172
- ...dataFields,
173
- $hash: $hash ?? await _PayloadBuilder.dataHash(dataFields),
174
- schema
175
- }, "_");
176
- const clonedMeta = {
177
- ...$meta
178
- };
179
- if (timestamp) {
180
- clonedMeta.timestamp = timestamp;
181
- }
182
- if (clonedMeta.timestamp === void 0 && stamp) {
183
- clonedMeta.timestamp = Date.now();
184
- }
185
- if (Object.keys(clonedMeta).length > 0) {
186
- result.$meta = clonedMeta;
187
- }
188
- return result;
189
- }
190
- static async hashes(payloads) {
191
- return await PayloadHasher.hashes(payloads);
192
- }
193
- static async toAllHashMap(objs) {
194
- const result = {};
195
- for (const pair of await this.hashPairs(objs)) {
196
- result[pair[1]] = pair[0];
197
- result[pair[0].$hash] = pair[0];
198
- }
199
- return result;
200
- }
201
- static async toDataHashMap(objs) {
202
- const result = {};
203
- for (const pair of await this.dataHashPairs(objs)) {
204
- result[pair[1]] = pair[0];
205
- }
206
- return result;
207
- }
208
- /**
209
- * Creates an object map of payload hashes to payloads based on the payloads passed in
210
- * @param objs Any array of payloads
211
- * @returns A map of hashes to payloads
212
- */
213
- static async toHashMap(objs) {
214
- const result = {};
215
- for (const pair of await this.hashPairs(objs)) {
216
- result[pair[1]] = pair[0];
217
- }
218
- return result;
219
- }
220
- static withoutMeta(payloads) {
221
- if (Array.isArray(payloads)) {
222
- return payloads.map((payload) => this.withoutMeta(payload));
223
- } else {
224
- if (payloads) {
225
- const { $meta, ...result } = payloads;
226
- return result;
227
- }
228
- }
229
- }
230
- async build(options) {
231
- const dataHashableFields = await this.dataHashableFields();
232
- return await _PayloadBuilder.build({
233
- ...dataHashableFields,
234
- $meta: this._$meta,
235
- schema: this._schema
236
- }, options);
237
- }
238
- async hashableFields() {
239
- return await _PayloadBuilder.hashableFields(assertEx2(this._schema, () => "Payload: Missing Schema"), this._fields, this._$meta);
240
- }
241
- };
242
- __name(_PayloadBuilder, "PayloadBuilder");
243
- var PayloadBuilder = _PayloadBuilder;
244
- export {
245
- PayloadBuilder,
246
- PayloadBuilderBase,
247
- removeMetaAndSchema
248
- };
1
+ var A=Object.defineProperty;var m=(h,t)=>A(h,"name",{value:t,configurable:!0});import{assertEx as b}from"@xylabs/assert";import{isJsonObject as O}from"@xylabs/object";import{PayloadHasher as y}from"@xyo-network/hash";import{omitBy as E}from"@xylabs/lodash";import{assertEx as p}from"@xylabs/assert";import{isJsonObject as M,toJson as D}from"@xylabs/object";import{removeEmptyFields as F}from"@xyo-network/hash";import{omitBy as P}from"@xylabs/lodash";var w=m(h=>{let{...t}=h;return delete t.$hash,delete t.$meta,delete t.schema,t},"removeMetaAndSchema"),x=m(h=>(t,a)=>(p(typeof a=="string",()=>`Invalid key type [${a}, ${typeof a}]`),a.startsWith(h)),"omitByPredicate"),d=class d{options;_$meta;_fields;_schema;constructor(t){this.options=t;let{schema:a,fields:s,meta:e}=t;this._schema=a,this._fields=F(s??{}),this._$meta=e}static dataHashableFields(t,a){let s=a?F(a):void 0;return p(s===void 0||M(s),()=>`Fields must be JsonObject: ${JSON.stringify(D(s),null,2)}`),P(P({schema:t,...s},x("$")),x("_"))}static metaFields(t,a,s=!0){let e={...a};return!e.timestamp&&s&&(e.timestamp=e.timestamp??Date.now()),e}$meta(t){return this._$meta=t??this._fields.$meta,this}async dataHashableFields(){return await d.dataHashableFields(p(this._schema,()=>"Payload: Missing Schema"),this._fields)}fields(t){if(t){let{$meta:a,$hash:s,schema:e,...i}=t;a&&this.$meta(a),e&&this.schema(e),this._fields=w(t)}return this}schema(t){this._schema=t}async metaFields(t,a=!0){return await d.metaFields(t,this._$meta,a)}};m(d,"PayloadBuilderBase");var f=d;var j=m(h=>(t,a)=>(b(typeof a=="string",()=>`Invalid key type [${a}, ${typeof a}]`),a.startsWith(h)),"omitByPredicate"),r=class r extends f{static async build(t,a={}){if(Array.isArray(t))return await Promise.all(t.map(s=>this.build(s,a)));{let{stamp:s=!1,validate:e=!0}=a,{schema:i,$hash:n,$meta:o={}}=t,{_signatures:l}=t;l&&!o.signatures&&(o.signatures=l);let c=w(t),$=await r.dataHashableFields(i,c),g=e||n===void 0?await y.hash($):n,u={...o};u.timestamp===void 0&&s&&(u.timestamp=Date.now());let H={...$,$hash:g,schema:i};return Object.keys(u).length>0&&(H.$meta=u),H}}static async dataHash(t,a){return(await this.build(t,a)).$hash}static async dataHashPairs(t,a){return await Promise.all(t.map(async s=>{let e=await r.build(s,a);return[e,e.$hash]}))}static async dataHashes(t,a){return t?await Promise.all(t.map(async s=>(await r.build(s,a)).$hash)):void 0}static async filterExclude(t=[],a){return await y.filterExcludeByHash(await this.filterExcludeByDataHash(t,a),a)}static async filterExcludeByDataHash(t=[],a){var e;let s=Array.isArray(a)?a:[a];return(e=(await this.dataHashPairs(t)).filter(([i,n])=>!s.includes(n)))==null?void 0:e.map(i=>i[0])}static async filterIncludeByDataHash(t=[],a){var e;let s=Array.isArray(a)?a:[a];return(e=(await this.dataHashPairs(t)).filter(([i,n])=>s.includes(n)))==null?void 0:e.map(i=>i[0])}static async findByDataHash(t=[],a){var s;return(s=(await this.dataHashPairs(t)).find(([e,i])=>i===a))==null?void 0:s[0]}static async hash(t,a){return await y.hash(await r.build(t,a))}static async hashPairs(t,a){return await Promise.all(t.map(async s=>{let e=await r.build(s,a);return[e,await r.hash(e)]}))}static async hashableFields(t,a,s,e,i,n=!1){let o=await this.dataHashableFields(t,a);b(s===void 0||O(s),()=>"$meta must be JsonObject");let l=E({...o,$hash:e??await r.dataHash(o),schema:t},j("_")),c={...s};return i&&(c.timestamp=i),c.timestamp===void 0&&n&&(c.timestamp=Date.now()),Object.keys(c).length>0&&(l.$meta=c),l}static async hashes(t){return await y.hashes(t)}static async toAllHashMap(t){let a={};for(let s of await this.hashPairs(t))a[s[1]]=s[0],a[s[0].$hash]=s[0];return a}static async toDataHashMap(t){let a={};for(let s of await this.dataHashPairs(t))a[s[1]]=s[0];return a}static async toHashMap(t){let a={};for(let s of await this.hashPairs(t))a[s[1]]=s[0];return a}static withoutMeta(t){if(Array.isArray(t))return t.map(a=>this.withoutMeta(a));if(t){let{$meta:a,...s}=t;return s}}async build(t){let a=await this.dataHashableFields();return await r.build({...a,$meta:this._$meta,schema:this._schema},t)}async hashableFields(){return await r.hashableFields(b(this._schema,()=>"Payload: Missing Schema"),this._fields,this._$meta)}};m(r,"PayloadBuilder");var _=r;export{_ as PayloadBuilder,f as PayloadBuilderBase,w as removeMetaAndSchema};
249
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'\nimport { deepOmitPrefixedFields, PayloadHasher } from '@xyo-network/hash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase'\nimport { PayloadBuilderOptions } from './Options'\n\nexport interface BuildOptions {\n stamp?: boolean\n validate?: boolean\n}\n\nexport class PayloadBuilder<\n T extends Payload = Payload<AnyObject>,\n O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,\n> extends PayloadBuilderBase<T, O> {\n static async build<T extends Payload = Payload<AnyObject>>(payload: T, options?: BuildOptions): Promise<WithMeta<T>>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T[], options?: BuildOptions): Promise<WithMeta<T>[]>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T | T[], options: BuildOptions = {}) {\n if (Array.isArray(payload)) {\n return await Promise.all(payload.map((payload) => this.build(payload, options)))\n } else {\n const { stamp = false, validate = true } = options\n const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload as WithMeta<T>\n\n //check for legacy signatures\n const { _signatures } = payload as { _signatures?: JsonArray }\n if (_signatures && !incomingMeta.signatures) {\n incomingMeta.signatures = _signatures\n }\n\n const fields = removeMetaAndSchema(payload)\n const dataHashableFields = await PayloadBuilder.dataHashableFields(schema, fields)\n const $hash = validate || incomingDataHash === undefined ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash\n const $meta: JsonObject = { ...incomingMeta }\n if ($meta.timestamp === undefined && stamp) {\n $meta.timestamp = Date.now()\n }\n const hashableFields: WithMeta<Payload> = { ...dataHashableFields, $hash, schema }\n\n if (Object.keys($meta).length > 0) {\n hashableFields.$meta = $meta\n }\n\n return hashableFields as WithMeta<T>\n }\n }\n\n static async dataHash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return (await this.build(payload, options)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined, options?: BuildOptions): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[], options?: BuildOptions): Promise<Hash[] | undefined> {\n return payloads ?\n await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return built.$hash\n }),\n )\n : undefined\n }\n\n static async filterExclude<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash)\n }\n\n static async filterExcludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n static async hash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return await PayloadHasher.hash(await PayloadBuilder.build(payload, options))\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 Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map<Promise<[WithMeta<T>, Hash]>>(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\n }\n\n static async hashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n $meta?: JsonObject,\n $hash?: Hash,\n timestamp?: number,\n stamp = false,\n ): Promise<WithMeta<T>> {\n const dataFields = await this.dataHashableFields<T>(schema, fields)\n assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')\n const result: WithMeta<T> = deepOmitPrefixedFields<WithMeta<T>>(\n {\n ...dataFields,\n $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),\n schema,\n } as WithMeta<T>,\n '_',\n )\n\n const clonedMeta = { ...$meta }\n\n if (timestamp) {\n clonedMeta.timestamp = timestamp\n }\n\n if (clonedMeta.timestamp === undefined && stamp) {\n clonedMeta.timestamp = Date.now()\n }\n\n if (Object.keys(clonedMeta).length > 0) {\n result.$meta = clonedMeta\n }\n\n return result\n }\n\n static async hashes(payloads: undefined): Promise<undefined>\n static async hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async hashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return await PayloadHasher.hashes(payloads)\n }\n\n static async toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n result[pair[0].$hash] = pair[0]\n }\n return result\n }\n\n static async toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.dataHashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n /**\n * Creates an object map of payload hashes to payloads based on the payloads passed in\n * @param objs Any array of payloads\n * @returns A map of hashes to payloads\n */\n static async toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n static withoutMeta(payload: undefined): undefined\n static withoutMeta<T extends PayloadWithMeta>(payload: T): Omit<T, '$meta'>\n static withoutMeta<T extends PayloadWithMeta>(payloads: T[]): Omit<T, '$meta'>[]\n static withoutMeta<T extends PayloadWithMeta>(payloads: T | T[]) {\n if (Array.isArray(payloads)) {\n return payloads.map((payload) => this.withoutMeta(payload))\n } else {\n if (payloads) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, ...result } = payloads\n return result as Omit<T, '$meta'>\n }\n }\n }\n\n async build(options?: BuildOptions): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n return await PayloadBuilder.build<T>({ ...dataHashableFields, $meta: this._$meta, schema: this._schema } as Payload as T, options)\n }\n\n async hashableFields() {\n return await PayloadBuilder.hashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n this._$meta,\n )\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { deepOmitPrefixedFields, removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderOptions } from './Options'\n\nexport type WithOptionalSchema<T extends Payload> = Omit<T, 'schema'> & Partial<T>\n\nexport type WithoutSchema<T extends WithOptionalSchema<Payload>> = Omit<T, 'schema'>\n\nexport type WithoutMeta<T extends WithOptionalMeta<Payload>> = Omit<T, '$hash' | '$meta'>\n\nexport const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSchema<WithOptionalMeta<T>>): WithoutSchema<WithoutMeta<T>> => {\n const { ...result } = payload\n delete result.$hash\n delete result.$meta\n delete result.schema\n return result as Omit<T, 'schema'>\n}\n\nexport class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: WithoutSchema<WithoutMeta<T>>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = removeEmptyFields(fields ?? {}) as WithoutSchema<WithoutMeta<T>>\n this._$meta = meta\n }\n\n static dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promisable<Omit<T, '$hash' | '$meta'>> {\n const cleanFields = fields ? removeEmptyFields(fields) : undefined\n assertEx(\n cleanFields === undefined || isJsonObject(cleanFields),\n () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,\n )\n return deepOmitPrefixedFields(deepOmitPrefixedFields({ schema, ...cleanFields }, '$'), '_') as T\n }\n\n protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {\n const meta: JsonObject = { ...otherMeta }\n\n if (!meta.timestamp && stamp) {\n meta.timestamp = meta.timestamp ?? Date.now()\n }\n\n return meta\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta ?? (this._fields as WithMeta<T>).$meta\n return this\n }\n\n async dataHashableFields() {\n return await PayloadBuilderBase.dataHashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n )\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: WithOptionalSchema<WithOptionalMeta<T>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = removeMetaAndSchema<T>(fields)\n }\n return this\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n\n protected async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp)\n }\n}\n"],"mappings":";;;;AAAA,SAASA,YAAAA,iBAAgB;AAEzB,SAAoBC,gBAAAA,qBAA2C;AAC/D,SAASC,0BAAAA,yBAAwBC,qBAAqB;;;ACHtD,SAASC,gBAAgB;AAEzB,SAAoBC,cAA0BC,cAAc;AAE5D,SAASC,wBAAwBC,yBAAyB;AAWnD,IAAMC,sBAAsB,wBAAoBC,YAAAA;AACrD,QAAM,EAAE,GAAGC,OAAAA,IAAWD;AACtB,SAAOC,OAAOC;AACd,SAAOD,OAAOE;AACd,SAAOF,OAAOG;AACd,SAAOH;AACT,GANmC;AAQ5B,IAAMI,sBAAN,MAAMA,oBAAAA;;EACDC;EACAC;EACAC;EAEVC,YAAqBC,SAAY;SAAZA,UAAAA;AACnB,UAAM,EAAEN,QAAQO,QAAQC,KAAI,IAAKF;AACjC,SAAKF,UAAUJ;AACf,SAAKG,UAAUM,kBAAkBF,UAAU,CAAC,CAAA;AAC5C,SAAKL,SAASM;EAChB;EAEA,OAAOE,mBACLV,QACAO,QACwC;AACxC,UAAMI,cAAcJ,SAASE,kBAAkBF,MAAAA,IAAUK;AACzDC,aACEF,gBAAgBC,UAAaE,aAAaH,WAAAA,GAC1C,MAAM,8BAA8BI,KAAKC,UAAUC,OAAON,WAAAA,GAAc,MAAM,CAAA,CAAA,EAAI;AAEpF,WAAOO,uBAAuBA,uBAAuB;MAAElB;MAAQ,GAAGW;IAAY,GAAG,GAAA,GAAM,GAAA;EACzF;EAEA,OAAiBQ,WAAWC,UAAgBC,WAAwBC,QAAQ,MAA8B;AACxG,UAAMd,OAAmB;MAAE,GAAGa;IAAU;AAExC,QAAI,CAACb,KAAKe,aAAaD,OAAO;AAC5Bd,WAAKe,YAAYf,KAAKe,aAAaC,KAAKC,IAAG;IAC7C;AAEA,WAAOjB;EACT;EAEAT,MAAMS,MAAmB;AACvB,SAAKN,SAASM,QAAS,KAAKL,QAAwBJ;AACpD,WAAO;EACT;EAEA,MAAMW,qBAAqB;AACzB,WAAO,MAAMT,oBAAmBS,mBAC9BG,SAAS,KAAKT,SAAS,MAAM,yBAAA,GAC7B,KAAKD,OAAO;EAEhB;;EAGAI,OAAOA,QAAiD;AACtD,QAAIA,QAAQ;AAEV,YAAM,EAAER,OAAOD,OAAOE,QAAQ,GAAG0B,WAAAA,IAAenB;AAChD,UAAIR,OAAO;AACT,aAAKA,MAAMA,KAAAA;MACb;AACA,UAAIC,QAAQ;AACV,aAAKA,OAAOA,MAAAA;MACd;AACA,WAAKG,UAAUR,oBAAuBY,MAAAA;IACxC;AACA,WAAO;EACT;EAEAP,OAAO2B,OAAe;AACpB,SAAKvB,UAAUuB;EACjB;EAEA,MAAgBR,WAAWC,UAAgBE,QAAQ,MAA2B;AAC5E,WAAO,MAAMrB,oBAAmBkB,WAAWC,UAAU,KAAKlB,QAAQoB,KAAAA;EACpE;AACF;AArEarB;AAAN,IAAMA,qBAAN;;;ADTA,IAAM2B,kBAAN,MAAMA,wBAGHC,mBAAAA;EAGR,aAAaC,MAA8CC,SAAkBC,UAAwB,CAAC,GAAG;AACvG,QAAIC,MAAMC,QAAQH,OAAAA,GAAU;AAC1B,aAAO,MAAMI,QAAQC,IAAIL,QAAQM,IAAI,CAACN,aAAY,KAAKD,MAAMC,UAASC,OAAAA,CAAAA,CAAAA;IACxE,OAAO;AACL,YAAM,EAAEM,QAAQ,OAAOC,WAAW,KAAI,IAAKP;AAC3C,YAAM,EAAEQ,QAAQC,OAAOC,kBAAkBC,OAAOC,eAAe,CAAC,EAAC,IAAKb;AAGtE,YAAM,EAAEc,YAAW,IAAKd;AACxB,UAAIc,eAAe,CAACD,aAAaE,YAAY;AAC3CF,qBAAaE,aAAaD;MAC5B;AAEA,YAAME,SAASC,oBAAoBjB,OAAAA;AACnC,YAAMkB,qBAAqB,MAAMrB,gBAAeqB,mBAAmBT,QAAQO,MAAAA;AAC3E,YAAMN,QAAQF,YAAYG,qBAAqBQ,SAAY,MAAMC,cAAcC,KAAKH,kBAAAA,IAAsBP;AAC1G,YAAMC,QAAoB;QAAE,GAAGC;MAAa;AAC5C,UAAID,MAAMU,cAAcH,UAAaZ,OAAO;AAC1CK,cAAMU,YAAYC,KAAKC,IAAG;MAC5B;AACA,YAAMC,iBAAoC;QAAE,GAAGP;QAAoBR;QAAOD;MAAO;AAEjF,UAAIiB,OAAOC,KAAKf,KAAAA,EAAOgB,SAAS,GAAG;AACjCH,uBAAeb,QAAQA;MACzB;AAEA,aAAOa;IACT;EACF;EAEA,aAAaI,SAA4B7B,SAAYC,SAAuC;AAC1F,YAAQ,MAAM,KAAKF,MAAMC,SAASC,OAAAA,GAAUS;EAC9C;EAEA,aAAaoB,cAAiCC,UAAe9B,SAAwD;AACnH,WAAO,MAAMG,QAAQC,IACnB0B,SAASzB,IAAI,OAAON,YAAAA;AAClB,YAAMgC,QAAQ,MAAMnC,gBAAeE,MAAMC,SAASC,OAAAA;AAClD,aAAO;QAAC+B;QAAOA,MAAMtB;;IACvB,CAAA,CAAA;EAEJ;EAIA,aAAauB,WAA8BF,UAAgB9B,SAAqD;AAC9G,WAAO8B,WACH,MAAM3B,QAAQC,IACZ0B,SAASzB,IAAI,OAAON,YAAAA;AAClB,YAAMgC,QAAQ,MAAMnC,gBAAeE,MAAMC,SAASC,OAAAA;AAClD,aAAO+B,MAAMtB;IACf,CAAA,CAAA,IAEFS;EACN;EAEA,aAAae,cAAiCH,WAAgB,CAAA,GAAIV,MAAmC;AACnG,WAAO,MAAMD,cAAce,oBAAoB,MAAM,KAAKC,wBAAwBL,UAAUV,IAAAA,GAAOA,IAAAA;EACrG;EAEA,aAAae,wBAA2CL,WAAgB,CAAA,GAAIV,MAAmC;AAhFjH;AAiFI,UAAMgB,SAASnC,MAAMC,QAAQkB,IAAAA,IAAQA,OAAO;MAACA;;AAC7C,YAAQ,YAAM,KAAKS,cAAcC,QAAAA,GAAWO,OAAO,CAAC,CAACC,GAAGC,OAAAA,MAAa,CAACH,OAAOI,SAASD,OAAAA,CAAAA,MAA9E,mBAAyFlC,IAAI,CAACoC,SAASA,KAAK,CAAA;EACtH;EAEA,aAAaC,wBAA2CZ,WAAgB,CAAA,GAAIV,MAAmC;AArFjH;AAsFI,UAAMgB,SAASnC,MAAMC,QAAQkB,IAAAA,IAAQA,OAAO;MAACA;;AAC7C,YAAQ,YAAM,KAAKS,cAAcC,QAAAA,GAAWO,OAAO,CAAC,CAACC,GAAGC,OAAAA,MAAaH,OAAOI,SAASD,OAAAA,CAAAA,MAA7E,mBAAwFlC,IAAI,CAACoC,SAASA,KAAK,CAAA;EACrH;EAEA,aAAaE,eAAkCb,WAAgB,CAAA,GAAIV,MAAoC;AA1FzG;AA2FI,YAAQ,YAAM,KAAKS,cAAcC,QAAAA,GAAWc,KAAK,CAAC,CAACN,GAAGC,OAAAA,MAAaA,YAAYnB,IAAAA,MAAvE,mBAA+E;EACzF;EAEA,aAAaA,KAAwBrB,SAAYC,SAAuC;AACtF,WAAO,MAAMmB,cAAcC,KAAK,MAAMxB,gBAAeE,MAAMC,SAASC,OAAAA,CAAAA;EACtE;;;;;;EAOA,aAAa6C,UAA6Bf,UAAe9B,SAAwD;AAC/G,WAAO,MAAMG,QAAQC,IACnB0B,SAASzB,IAAkC,OAAON,YAAAA;AAChD,YAAMgC,QAAQ,MAAMnC,gBAAeE,MAAMC,SAASC,OAAAA;AAClD,aAAO;QAAC+B;QAAO,MAAMnC,gBAAewB,KAAKW,KAAAA;;IAC3C,CAAA,CAAA;EAEJ;EAEA,aAAaP,eACXhB,QACAO,QACAJ,OACAF,OACAY,WACAf,QAAQ,OACc;AACtB,UAAMwC,aAAa,MAAM,KAAK7B,mBAAsBT,QAAQO,MAAAA;AAC5DgC,IAAAA,UAASpC,UAAUO,UAAa8B,cAAarC,KAAAA,GAAQ,MAAM,0BAAA;AAC3D,UAAMsC,SAAsBC,wBAC1B;MACE,GAAGJ;MACHrC,OAAOA,SAAU,MAAMb,gBAAegC,SAASkB,UAAAA;MAC/CtC;IACF,GACA,GAAA;AAGF,UAAM2C,aAAa;MAAE,GAAGxC;IAAM;AAE9B,QAAIU,WAAW;AACb8B,iBAAW9B,YAAYA;IACzB;AAEA,QAAI8B,WAAW9B,cAAcH,UAAaZ,OAAO;AAC/C6C,iBAAW9B,YAAYC,KAAKC,IAAG;IACjC;AAEA,QAAIE,OAAOC,KAAKyB,UAAAA,EAAYxB,SAAS,GAAG;AACtCsB,aAAOtC,QAAQwC;IACjB;AAEA,WAAOF;EACT;EAIA,aAAab,OAA0BN,UAA6C;AAClF,WAAO,MAAMX,cAAciB,OAAON,QAAAA;EACpC;EAEA,aAAasB,aAAgCC,MAA+C;AAC1F,UAAMJ,SAAoC,CAAC;AAC3C,eAAWR,QAAQ,MAAM,KAAKI,UAAUQ,IAAAA,GAAO;AAC7CJ,aAAOR,KAAK,CAAA,CAAE,IAAIA,KAAK,CAAA;AACvBQ,aAAOR,KAAK,CAAA,EAAGhC,KAAK,IAAIgC,KAAK,CAAA;IAC/B;AACA,WAAOQ;EACT;EAEA,aAAaK,cAAiCD,MAA+C;AAC3F,UAAMJ,SAAoC,CAAC;AAC3C,eAAWR,QAAQ,MAAM,KAAKZ,cAAcwB,IAAAA,GAAO;AACjDJ,aAAOR,KAAK,CAAA,CAAE,IAAIA,KAAK,CAAA;IACzB;AACA,WAAOQ;EACT;;;;;;EAOA,aAAaM,UAA6BF,MAA+C;AACvF,UAAMJ,SAAoC,CAAC;AAC3C,eAAWR,QAAQ,MAAM,KAAKI,UAAUQ,IAAAA,GAAO;AAC7CJ,aAAOR,KAAK,CAAA,CAAE,IAAIA,KAAK,CAAA;IACzB;AACA,WAAOQ;EACT;EAKA,OAAOO,YAAuC1B,UAAmB;AAC/D,QAAI7B,MAAMC,QAAQ4B,QAAAA,GAAW;AAC3B,aAAOA,SAASzB,IAAI,CAACN,YAAY,KAAKyD,YAAYzD,OAAAA,CAAAA;IACpD,OAAO;AACL,UAAI+B,UAAU;AAEZ,cAAM,EAAEnB,OAAO,GAAGsC,OAAAA,IAAWnB;AAC7B,eAAOmB;MACT;IACF;EACF;EAEA,MAAMnD,MAAME,SAA8C;AACxD,UAAMiB,qBAAqB,MAAM,KAAKA,mBAAkB;AACxD,WAAO,MAAMrB,gBAAeE,MAAS;MAAE,GAAGmB;MAAoBN,OAAO,KAAK8C;MAAQjD,QAAQ,KAAKkD;IAAQ,GAAmB1D,OAAAA;EAC5H;EAEA,MAAMwB,iBAAiB;AACrB,WAAO,MAAM5B,gBAAe4B,eAC1BuB,UAAS,KAAKW,SAAS,MAAM,yBAAA,GAC7B,KAAKC,SACL,KAAKF,MAAM;EAEf;AACF;AAlMU5D;AAHH,IAAMD,iBAAN;","names":["assertEx","isJsonObject","deepOmitPrefixedFields","PayloadHasher","assertEx","isJsonObject","toJson","deepOmitPrefixedFields","removeEmptyFields","removeMetaAndSchema","payload","result","$hash","$meta","schema","PayloadBuilderBase","_$meta","_fields","_schema","constructor","options","fields","meta","removeEmptyFields","dataHashableFields","cleanFields","undefined","assertEx","isJsonObject","JSON","stringify","toJson","deepOmitPrefixedFields","metaFields","dataHash","otherMeta","stamp","timestamp","Date","now","fieldsOnly","value","PayloadBuilder","PayloadBuilderBase","build","payload","options","Array","isArray","Promise","all","map","stamp","validate","schema","$hash","incomingDataHash","$meta","incomingMeta","_signatures","signatures","fields","removeMetaAndSchema","dataHashableFields","undefined","PayloadHasher","hash","timestamp","Date","now","hashableFields","Object","keys","length","dataHash","dataHashPairs","payloads","built","dataHashes","filterExclude","filterExcludeByHash","filterExcludeByDataHash","hashes","filter","_","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","dataFields","assertEx","isJsonObject","result","deepOmitPrefixedFields","clonedMeta","toAllHashMap","objs","toDataHashMap","toHashMap","withoutMeta","_$meta","_schema","_fields"]}
1
+ {"version":3,"sources":["../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { omitBy } from '@xylabs/lodash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase'\nimport { PayloadBuilderOptions } from './Options'\n\nexport interface BuildOptions {\n stamp?: boolean\n validate?: boolean\n}\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 PayloadBuilder<\n T extends Payload = Payload<AnyObject>,\n O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,\n> extends PayloadBuilderBase<T, O> {\n static async build<T extends Payload = Payload<AnyObject>>(payload: T, options?: BuildOptions): Promise<WithMeta<T>>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T[], options?: BuildOptions): Promise<WithMeta<T>[]>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T | T[], options: BuildOptions = {}) {\n if (Array.isArray(payload)) {\n return await Promise.all(payload.map((payload) => this.build(payload, options)))\n } else {\n const { stamp = false, validate = true } = options\n const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload as WithMeta<T>\n\n //check for legacy signatures\n const { _signatures } = payload as { _signatures?: JsonArray }\n if (_signatures && !incomingMeta.signatures) {\n incomingMeta.signatures = _signatures\n }\n\n const fields = removeMetaAndSchema(payload)\n const dataHashableFields = await PayloadBuilder.dataHashableFields(schema, fields)\n const $hash = validate || incomingDataHash === undefined ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash\n const $meta: JsonObject = { ...incomingMeta }\n if ($meta.timestamp === undefined && stamp) {\n $meta.timestamp = Date.now()\n }\n const hashableFields: WithMeta<Payload> = { ...dataHashableFields, $hash, schema }\n\n if (Object.keys($meta).length > 0) {\n hashableFields.$meta = $meta\n }\n\n return hashableFields as WithMeta<T>\n }\n }\n\n static async dataHash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return (await this.build(payload, options)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined, options?: BuildOptions): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[], options?: BuildOptions): Promise<Hash[] | undefined> {\n return payloads ?\n await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return built.$hash\n }),\n )\n : undefined\n }\n\n static async filterExclude<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash)\n }\n\n static async filterExcludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n static async hash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return await PayloadHasher.hash(await PayloadBuilder.build(payload, options))\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 Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map<Promise<[WithMeta<T>, Hash]>>(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\n }\n\n static async hashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n $meta?: JsonObject,\n $hash?: Hash,\n timestamp?: number,\n stamp = false,\n ): Promise<WithMeta<T>> {\n const dataFields = await this.dataHashableFields<T>(schema, fields)\n assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')\n const result: WithMeta<T> = omitBy(\n {\n ...dataFields,\n $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),\n schema,\n } as WithMeta<T>,\n omitByPredicate('_'),\n ) as WithMeta<T>\n\n const clonedMeta = { ...$meta }\n\n if (timestamp) {\n clonedMeta.timestamp = timestamp\n }\n\n if (clonedMeta.timestamp === undefined && stamp) {\n clonedMeta.timestamp = Date.now()\n }\n\n if (Object.keys(clonedMeta).length > 0) {\n result.$meta = clonedMeta\n }\n\n return result\n }\n\n static async hashes(payloads: undefined): Promise<undefined>\n static async hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async hashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return await PayloadHasher.hashes(payloads)\n }\n\n static async toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n result[pair[0].$hash] = pair[0]\n }\n return result\n }\n\n static async toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.dataHashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n /**\n * Creates an object map of payload hashes to payloads based on the payloads passed in\n * @param objs Any array of payloads\n * @returns A map of hashes to payloads\n */\n static async toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n static withoutMeta(payload: undefined): undefined\n static withoutMeta<T extends PayloadWithMeta>(payload: T): Omit<T, '$meta'>\n static withoutMeta<T extends PayloadWithMeta>(payloads: T[]): Omit<T, '$meta'>[]\n static withoutMeta<T extends PayloadWithMeta>(payloads: T | T[]) {\n if (Array.isArray(payloads)) {\n return payloads.map((payload) => this.withoutMeta(payload))\n } else {\n if (payloads) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, ...result } = payloads\n return result as Omit<T, '$meta'>\n }\n }\n }\n\n async build(options?: BuildOptions): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n return await PayloadBuilder.build<T>({ ...dataHashableFields, $meta: this._$meta, schema: this._schema } as Payload as T, options)\n }\n\n async hashableFields() {\n return await PayloadBuilder.hashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n this._$meta,\n )\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'\nimport { omitBy } from '@xylabs/lodash'\n\nimport { PayloadBuilderOptions } from './Options'\n\nexport type WithOptionalSchema<T extends Payload> = Omit<T, 'schema'> & Partial<T>\n\nexport type WithoutSchema<T extends WithOptionalSchema<Payload>> = Omit<T, 'schema'>\n\nexport type WithoutMeta<T extends WithOptionalMeta<Payload>> = Omit<T, '$hash' | '$meta'>\n\nexport const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSchema<WithOptionalMeta<T>>): WithoutSchema<WithoutMeta<T>> => {\n const { ...result } = payload\n delete result.$hash\n delete result.$meta\n delete result.schema\n return result as Omit<T, 'schema'>\n}\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 PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: WithoutSchema<WithoutMeta<T>>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = removeEmptyFields(fields ?? {}) as WithoutSchema<WithoutMeta<T>>\n this._$meta = meta\n }\n\n static dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promisable<Omit<T, '$hash' | '$meta'>> {\n const cleanFields = fields ? removeEmptyFields(fields) : undefined\n assertEx(\n cleanFields === undefined || isJsonObject(cleanFields),\n () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,\n )\n return omitBy(omitBy({ schema, ...cleanFields }, omitByPredicate('$')), omitByPredicate('_')) as unknown as T\n }\n\n protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {\n const meta: JsonObject = { ...otherMeta }\n\n if (!meta.timestamp && stamp) {\n meta.timestamp = meta.timestamp ?? Date.now()\n }\n\n return meta\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta ?? (this._fields as WithMeta<T>).$meta\n return this\n }\n\n async dataHashableFields() {\n return await PayloadBuilderBase.dataHashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n )\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: WithOptionalSchema<WithOptionalMeta<T>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = removeMetaAndSchema<T>(fields)\n }\n return this\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n\n protected async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp)\n }\n}\n"],"mappings":"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","names":["assertEx","isJsonObject","PayloadHasher","omitBy","assertEx","isJsonObject","toJson","removeEmptyFields","omitBy","removeMetaAndSchema","__name","payload","result","$hash","$meta","schema","omitByPredicate","prefix","_","key","assertEx","startsWith","PayloadBuilderBase","_$meta","_fields","_schema","constructor","options","fields","meta","removeEmptyFields","dataHashableFields","cleanFields","undefined","isJsonObject","JSON","stringify","toJson","omitBy","metaFields","dataHash","otherMeta","stamp","timestamp","Date","now","fieldsOnly","value","_PayloadBuilderBase","omitByPredicate","__name","prefix","_","key","assertEx","startsWith","PayloadBuilder","PayloadBuilderBase","build","payload","options","Array","isArray","Promise","all","map","stamp","validate","schema","$hash","incomingDataHash","$meta","incomingMeta","_signatures","signatures","fields","removeMetaAndSchema","dataHashableFields","undefined","PayloadHasher","hash","timestamp","Date","now","hashableFields","Object","keys","length","dataHash","dataHashPairs","payloads","built","dataHashes","filterExclude","filterExcludeByHash","filterExcludeByDataHash","_a","hashes","filter","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","dataFields","isJsonObject","result","omitBy","clonedMeta","toAllHashMap","objs","toDataHashMap","toHashMap","withoutMeta","_$meta","_schema","_fields","_PayloadBuilder"]}
package/package.json CHANGED
@@ -12,16 +12,17 @@
12
12
  "dependencies": {
13
13
  "@xylabs/assert": "^3.5.1",
14
14
  "@xylabs/hex": "^3.5.1",
15
+ "@xylabs/lodash": "^3.5.1",
15
16
  "@xylabs/logger": "^3.5.1",
16
17
  "@xylabs/object": "^3.5.1",
17
18
  "@xylabs/promise": "^3.5.1",
18
- "@xyo-network/hash": "~2.106.0",
19
- "@xyo-network/payload-model": "~2.106.0"
19
+ "@xyo-network/hash": "~2.107.1",
20
+ "@xyo-network/payload-model": "~2.107.1"
20
21
  },
21
22
  "devDependencies": {
22
- "@xylabs/ts-scripts-yarn3": "^3.11.2",
23
- "@xylabs/tsconfig": "^3.11.2",
24
- "typescript": "^5.4.5"
23
+ "@xylabs/ts-scripts-yarn3": "^3.11.9",
24
+ "@xylabs/tsconfig": "^3.11.9",
25
+ "typescript": "^5.5.2"
25
26
  },
26
27
  "description": "Primary SDK for using XYO Protocol 2.0",
27
28
  "exports": {
@@ -62,6 +63,6 @@
62
63
  },
63
64
  "sideEffects": false,
64
65
  "types": "dist/node/index.d.ts",
65
- "version": "2.106.0",
66
+ "version": "2.107.1",
66
67
  "type": "module"
67
68
  }
package/src/Builder.ts CHANGED
@@ -1,7 +1,8 @@
1
1
  import { assertEx } from '@xylabs/assert'
2
2
  import { Hash } from '@xylabs/hex'
3
3
  import { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'
4
- import { deepOmitPrefixedFields, PayloadHasher } from '@xyo-network/hash'
4
+ import { PayloadHasher } from '@xyo-network/hash'
5
+ import { omitBy } from '@xylabs/lodash'
5
6
  import { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'
6
7
 
7
8
  import { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase'
@@ -12,6 +13,11 @@ export interface BuildOptions {
12
13
  validate?: boolean
13
14
  }
14
15
 
16
+ const omitByPredicate = (prefix: string) => (_: unknown, key: string) => {
17
+ assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)
18
+ return key.startsWith(prefix)
19
+ }
20
+
15
21
  export class PayloadBuilder<
16
22
  T extends Payload = Payload<AnyObject>,
17
23
  O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,
@@ -120,14 +126,14 @@ export class PayloadBuilder<
120
126
  ): Promise<WithMeta<T>> {
121
127
  const dataFields = await this.dataHashableFields<T>(schema, fields)
122
128
  assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')
123
- const result: WithMeta<T> = deepOmitPrefixedFields<WithMeta<T>>(
129
+ const result: WithMeta<T> = omitBy(
124
130
  {
125
131
  ...dataFields,
126
132
  $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),
127
133
  schema,
128
134
  } as WithMeta<T>,
129
- '_',
130
- )
135
+ omitByPredicate('_'),
136
+ ) as WithMeta<T>
131
137
 
132
138
  const clonedMeta = { ...$meta }
133
139
 
@@ -2,8 +2,9 @@ import { assertEx } from '@xylabs/assert'
2
2
  import { Hash } from '@xylabs/hex'
3
3
  import { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'
4
4
  import { Promisable } from '@xylabs/promise'
5
- import { deepOmitPrefixedFields, removeEmptyFields } from '@xyo-network/hash'
5
+ import { removeEmptyFields } from '@xyo-network/hash'
6
6
  import { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'
7
+ import { omitBy } from '@xylabs/lodash'
7
8
 
8
9
  import { PayloadBuilderOptions } from './Options'
9
10
 
@@ -21,6 +22,11 @@ export const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSche
21
22
  return result as Omit<T, 'schema'>
22
23
  }
23
24
 
25
+ const omitByPredicate = (prefix: string) => (_: unknown, key: string) => {
26
+ assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)
27
+ return key.startsWith(prefix)
28
+ }
29
+
24
30
  export class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {
25
31
  protected _$meta?: JsonObject
26
32
  protected _fields?: WithoutSchema<WithoutMeta<T>>
@@ -42,7 +48,7 @@ export class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extend
42
48
  cleanFields === undefined || isJsonObject(cleanFields),
43
49
  () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,
44
50
  )
45
- return deepOmitPrefixedFields(deepOmitPrefixedFields({ schema, ...cleanFields }, '$'), '_') as T
51
+ return omitBy(omitBy({ schema, ...cleanFields }, omitByPredicate('$')), omitByPredicate('_')) as unknown as T
46
52
  }
47
53
 
48
54
  protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {