@xyo-network/file-browser-plugin 2.87.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +165 -0
- package/README.md +13 -0
- package/dist/browser/BrowserFileWitness.d.cts +20 -0
- package/dist/browser/BrowserFileWitness.d.cts.map +1 -0
- package/dist/browser/BrowserFileWitness.d.mts +20 -0
- package/dist/browser/BrowserFileWitness.d.mts.map +1 -0
- package/dist/browser/BrowserFileWitness.d.ts +20 -0
- package/dist/browser/BrowserFileWitness.d.ts.map +1 -0
- package/dist/browser/Config.d.cts +8 -0
- package/dist/browser/Config.d.cts.map +1 -0
- package/dist/browser/Config.d.mts +8 -0
- package/dist/browser/Config.d.mts.map +1 -0
- package/dist/browser/Config.d.ts +8 -0
- package/dist/browser/Config.d.ts.map +1 -0
- package/dist/browser/Params.d.cts +4 -0
- package/dist/browser/Params.d.cts.map +1 -0
- package/dist/browser/Params.d.mts +4 -0
- package/dist/browser/Params.d.mts.map +1 -0
- package/dist/browser/Params.d.ts +4 -0
- package/dist/browser/Params.d.ts.map +1 -0
- package/dist/browser/Payload.d.cts +14 -0
- package/dist/browser/Payload.d.cts.map +1 -0
- package/dist/browser/Payload.d.mts +14 -0
- package/dist/browser/Payload.d.mts.map +1 -0
- package/dist/browser/Payload.d.ts +14 -0
- package/dist/browser/Payload.d.ts.map +1 -0
- package/dist/browser/PluginBrowser.d.cts +3 -0
- package/dist/browser/PluginBrowser.d.cts.map +1 -0
- package/dist/browser/PluginBrowser.d.mts +3 -0
- package/dist/browser/PluginBrowser.d.mts.map +1 -0
- package/dist/browser/PluginBrowser.d.ts +3 -0
- package/dist/browser/PluginBrowser.d.ts.map +1 -0
- package/dist/browser/Schema.d.cts +3 -0
- package/dist/browser/Schema.d.cts.map +1 -0
- package/dist/browser/Schema.d.mts +3 -0
- package/dist/browser/Schema.d.mts.map +1 -0
- package/dist/browser/Schema.d.ts +3 -0
- package/dist/browser/Schema.d.ts.map +1 -0
- package/dist/browser/Witness.d.cts +12 -0
- package/dist/browser/Witness.d.cts.map +1 -0
- package/dist/browser/Witness.d.mts +12 -0
- package/dist/browser/Witness.d.mts.map +1 -0
- package/dist/browser/Witness.d.ts +12 -0
- package/dist/browser/Witness.d.ts.map +1 -0
- package/dist/browser/index.cjs +125 -0
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts +7 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.d.mts +7 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +7 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +92 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/util/GenerateDataUri.d.cts +2 -0
- package/dist/browser/util/GenerateDataUri.d.cts.map +1 -0
- package/dist/browser/util/GenerateDataUri.d.mts +2 -0
- package/dist/browser/util/GenerateDataUri.d.mts.map +1 -0
- package/dist/browser/util/GenerateDataUri.d.ts +2 -0
- package/dist/browser/util/GenerateDataUri.d.ts.map +1 -0
- package/dist/browser/util/index.d.cts +2 -0
- package/dist/browser/util/index.d.cts.map +1 -0
- package/dist/browser/util/index.d.mts +2 -0
- package/dist/browser/util/index.d.mts.map +1 -0
- package/dist/browser/util/index.d.ts +2 -0
- package/dist/browser/util/index.d.ts.map +1 -0
- package/dist/node/BrowserFileWitness.d.cts +20 -0
- package/dist/node/BrowserFileWitness.d.cts.map +1 -0
- package/dist/node/BrowserFileWitness.d.mts +20 -0
- package/dist/node/BrowserFileWitness.d.mts.map +1 -0
- package/dist/node/BrowserFileWitness.d.ts +20 -0
- package/dist/node/BrowserFileWitness.d.ts.map +1 -0
- package/dist/node/Config.d.cts +8 -0
- package/dist/node/Config.d.cts.map +1 -0
- package/dist/node/Config.d.mts +8 -0
- package/dist/node/Config.d.mts.map +1 -0
- package/dist/node/Config.d.ts +8 -0
- package/dist/node/Config.d.ts.map +1 -0
- package/dist/node/Params.d.cts +4 -0
- package/dist/node/Params.d.cts.map +1 -0
- package/dist/node/Params.d.mts +4 -0
- package/dist/node/Params.d.mts.map +1 -0
- package/dist/node/Params.d.ts +4 -0
- package/dist/node/Params.d.ts.map +1 -0
- package/dist/node/Payload.d.cts +14 -0
- package/dist/node/Payload.d.cts.map +1 -0
- package/dist/node/Payload.d.mts +14 -0
- package/dist/node/Payload.d.mts.map +1 -0
- package/dist/node/Payload.d.ts +14 -0
- package/dist/node/Payload.d.ts.map +1 -0
- package/dist/node/PluginBrowser.d.cts +3 -0
- package/dist/node/PluginBrowser.d.cts.map +1 -0
- package/dist/node/PluginBrowser.d.mts +3 -0
- package/dist/node/PluginBrowser.d.mts.map +1 -0
- package/dist/node/PluginBrowser.d.ts +3 -0
- package/dist/node/PluginBrowser.d.ts.map +1 -0
- package/dist/node/Schema.d.cts +3 -0
- package/dist/node/Schema.d.cts.map +1 -0
- package/dist/node/Schema.d.mts +3 -0
- package/dist/node/Schema.d.mts.map +1 -0
- package/dist/node/Schema.d.ts +3 -0
- package/dist/node/Schema.d.ts.map +1 -0
- package/dist/node/Witness.d.cts +12 -0
- package/dist/node/Witness.d.cts.map +1 -0
- package/dist/node/Witness.d.mts +12 -0
- package/dist/node/Witness.d.mts.map +1 -0
- package/dist/node/Witness.d.ts +12 -0
- package/dist/node/Witness.d.ts.map +1 -0
- package/dist/node/index.cjs +134 -0
- package/dist/node/index.cjs.map +1 -0
- package/dist/node/index.d.cts +7 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +7 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +7 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +93 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/util/GenerateDataUri.d.cts +2 -0
- package/dist/node/util/GenerateDataUri.d.cts.map +1 -0
- package/dist/node/util/GenerateDataUri.d.mts +2 -0
- package/dist/node/util/GenerateDataUri.d.mts.map +1 -0
- package/dist/node/util/GenerateDataUri.d.ts +2 -0
- package/dist/node/util/GenerateDataUri.d.ts.map +1 -0
- package/dist/node/util/index.d.cts +2 -0
- package/dist/node/util/index.d.cts.map +1 -0
- package/dist/node/util/index.d.mts +2 -0
- package/dist/node/util/index.d.mts.map +1 -0
- package/dist/node/util/index.d.ts +2 -0
- package/dist/node/util/index.d.ts.map +1 -0
- package/package.json +71 -0
- package/src/BrowserFileWitness.ts +62 -0
- package/src/Config.ts +9 -0
- package/src/Params.ts +3 -0
- package/src/Payload.ts +19 -0
- package/src/PluginBrowser.ts +16 -0
- package/src/Schema.ts +2 -0
- package/src/Witness.ts +19 -0
- package/src/index.ts +6 -0
- package/src/util/GenerateDataUri.ts +5 -0
- package/src/util/index.ts +1 -0
- package/typedoc.json +5 -0
- package/xy.config.ts +15 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/BrowserFileWitness.ts","../../src/Config.ts","../../src/Schema.ts","../../src/util/GenerateDataUri.ts","../../src/Witness.ts","../../src/PluginBrowser.ts"],"sourcesContent":["export * from './BrowserFileWitness'\nexport * from './Config'\nexport * from './Params'\nexport { BrowserFilePlugin, BrowserFilePlugin as default } from './PluginBrowser'\nexport * from './Schema'\nexport * from './Witness'\n","import { assertEx } from '@xylabs/assert'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport shajs from 'sha.js'\n\nimport { FileWitnessConfigSchema } from './Config'\nimport { BrowserFileWitnessAdditionalParams } from './Params'\nimport { FilePayload } from './Payload'\nimport { FileSchema } from './Schema'\nimport { generateDataUri } from './util'\nimport { FileWitness, FileWitnessParams } from './Witness'\n\ntype BrowserFileWitnessParams = FileWitnessParams & BrowserFileWitnessAdditionalParams\n\nexport class BrowserFileWitness extends FileWitness<BrowserFileWitnessParams> {\n static override configSchemas = [FileWitnessConfigSchema]\n\n protected override async observeHandler() {\n try {\n const [payload] = await this.witnessBrowserFile()\n console.log(`BrowserFileWitness: ${await PayloadBuilder.dataHash(payload)}`)\n return [payload]\n } catch (e) {\n throw new Error(`Error reading file: ${e}`)\n }\n }\n\n private readBinaryFile(file: File): Promise<Uint8Array> {\n return new Promise((resolve, reject) => {\n const fileReader = new FileReader()\n fileReader.addEventListener('load', (event) => {\n const arrayBuffer = event.target?.result as ArrayBuffer\n resolve(new Uint8Array(arrayBuffer))\n })\n // eslint-disable-next-line unicorn/prefer-add-event-listener\n fileReader.onerror = () => reject(fileReader.error)\n // eslint-disable-next-line unicorn/prefer-blob-reading-methods\n fileReader.readAsArrayBuffer(file)\n })\n }\n\n private async witnessBrowserFile(): Promise<[FilePayload, Uint8Array]> {\n const file = assertEx(this.params.file, 'File is missing from params')\n const fileBinary = await this.readBinaryFile(file)\n const result = new Uint8Array(fileBinary)\n const hash = shajs('sha256').update(result).digest('hex').padStart(64, '0')\n\n return [\n {\n hash,\n length: fileBinary.byteLength,\n meta: {\n name: file.name,\n type: file.type,\n },\n modified: file.lastModified,\n schema: FileSchema,\n uri: this.config.storage === 'data-uri' ? generateDataUri(fileBinary) : file.name,\n },\n fileBinary,\n ]\n }\n}\n","import { WitnessConfig } from '@xyo-network/witness-model'\n\nexport type FileWitnessConfigSchema = 'network.xyo.file.witness.config'\nexport const FileWitnessConfigSchema: FileWitnessConfigSchema = 'network.xyo.file.witness.config'\n\nexport type FileWitnessConfig = WitnessConfig<{\n schema: FileWitnessConfigSchema\n storage?: 'data-uri'\n}>\n","export type FileSchema = 'network.xyo.file'\nexport const FileSchema: FileSchema = 'network.xyo.file'\n","import { base64 } from '@scure/base'\n\nexport const generateDataUri = (data: Uint8Array): string => {\n return `data:application/octet-stream;base64,${base64.encode(data)}`\n}\n","import { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessModule, WitnessParams } from '@xyo-network/witness-model'\n\nimport { FileWitnessConfig, FileWitnessConfigSchema } from './Config'\nimport { FileSchema } from './Schema'\n\nexport type FileWitnessParams = WitnessParams<AnyConfigSchema<FileWitnessConfig>>\n\n// Abstract so that derived classes provide a type for the file param and methods to parse it\nexport abstract class FileWitness<TParams extends FileWitnessParams = FileWitnessParams> extends AbstractWitness<TParams> implements WitnessModule {\n static override configSchemas = [FileWitnessConfigSchema]\n\n protected override observeHandler(payloads?: Payload[]): Promisable<Payload[]> {\n return [{ ...payloads?.[0], schema: FileSchema }]\n }\n}\n","import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { BrowserFileWitness } from './BrowserFileWitness'\nimport { FileSchema } from './Schema'\n\nexport const BrowserFilePlugin = () =>\n createPayloadSetWitnessPlugin<BrowserFileWitness>(\n { required: { [FileSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await BrowserFileWitness.create(params)\n return result\n },\n },\n )\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,oBAAyB;AACzB,6BAA+B;AAC/B,iBAAkB;;;ACCX,IAAM,0BAAmD;;;ACFzD,IAAM,aAAyB;;;ACDtC,kBAAuB;AAEhB,IAAM,kBAAkB,CAAC,SAA6B;AAC3D,SAAO,wCAAwC,mBAAO,OAAO,IAAI,CAAC;AACpE;;;ACHA,8BAAgC;AAWzB,IAAe,cAAf,cAA0F,wCAAkD;AAAA,EACjJ,OAAgB,gBAAgB,CAAC,uBAAuB;AAAA,EAErC,eAAe,UAA6C;AAC7E,WAAO,CAAC,EAAE,GAAG,WAAW,CAAC,GAAG,QAAQ,WAAW,CAAC;AAAA,EAClD;AACF;;;AJLO,IAAM,qBAAN,cAAiC,YAAsC;AAAA,EAC5E,OAAgB,gBAAgB,CAAC,uBAAuB;AAAA,EAExD,MAAyB,iBAAiB;AACxC,QAAI;AACF,YAAM,CAAC,OAAO,IAAI,MAAM,KAAK,mBAAmB;AAChD,cAAQ,IAAI,uBAAuB,MAAM,sCAAe,SAAS,OAAO,CAAC,EAAE;AAC3E,aAAO,CAAC,OAAO;AAAA,IACjB,SAAS,GAAG;AACV,YAAM,IAAI,MAAM,uBAAuB,CAAC,EAAE;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,eAAe,MAAiC;AACtD,WAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,YAAM,aAAa,IAAI,WAAW;AAClC,iBAAW,iBAAiB,QAAQ,CAAC,UAAU;AAC7C,cAAM,cAAc,MAAM,QAAQ;AAClC,gBAAQ,IAAI,WAAW,WAAW,CAAC;AAAA,MACrC,CAAC;AAED,iBAAW,UAAU,MAAM,OAAO,WAAW,KAAK;AAElD,iBAAW,kBAAkB,IAAI;AAAA,IACnC,CAAC;AAAA,EACH;AAAA,EAEA,MAAc,qBAAyD;AACrE,UAAM,WAAO,wBAAS,KAAK,OAAO,MAAM,6BAA6B;AACrE,UAAM,aAAa,MAAM,KAAK,eAAe,IAAI;AACjD,UAAM,SAAS,IAAI,WAAW,UAAU;AACxC,UAAM,WAAO,WAAAA,SAAM,QAAQ,EAAE,OAAO,MAAM,EAAE,OAAO,KAAK,EAAE,SAAS,IAAI,GAAG;AAE1E,WAAO;AAAA,MACL;AAAA,QACE;AAAA,QACA,QAAQ,WAAW;AAAA,QACnB,MAAM;AAAA,UACJ,MAAM,KAAK;AAAA,UACX,MAAM,KAAK;AAAA,QACb;AAAA,QACA,UAAU,KAAK;AAAA,QACf,QAAQ;AAAA,QACR,KAAK,KAAK,OAAO,YAAY,aAAa,gBAAgB,UAAU,IAAI,KAAK;AAAA,MAC/E;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACF;;;AK7DA,2BAAiC;AACjC,+BAA8C;AAKvC,IAAM,oBAAoB,UAC/B;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,UAAU,GAAG,EAAE,GAAG,QAAQ,sCAAiB;AAAA,EAC1D;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,mBAAmB,OAAO,MAAM;AACrD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":["shajs"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './BrowserFileWitness';
|
|
2
|
+
export * from './Config';
|
|
3
|
+
export * from './Params';
|
|
4
|
+
export { BrowserFilePlugin, BrowserFilePlugin as default } from './PluginBrowser';
|
|
5
|
+
export * from './Schema';
|
|
6
|
+
export * from './Witness';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAA;AACpC,cAAc,UAAU,CAAA;AACxB,cAAc,UAAU,CAAA;AACxB,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,IAAI,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACjF,cAAc,UAAU,CAAA;AACxB,cAAc,WAAW,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './BrowserFileWitness';
|
|
2
|
+
export * from './Config';
|
|
3
|
+
export * from './Params';
|
|
4
|
+
export { BrowserFilePlugin, BrowserFilePlugin as default } from './PluginBrowser';
|
|
5
|
+
export * from './Schema';
|
|
6
|
+
export * from './Witness';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAA;AACpC,cAAc,UAAU,CAAA;AACxB,cAAc,UAAU,CAAA;AACxB,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,IAAI,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACjF,cAAc,UAAU,CAAA;AACxB,cAAc,WAAW,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './BrowserFileWitness';
|
|
2
|
+
export * from './Config';
|
|
3
|
+
export * from './Params';
|
|
4
|
+
export { BrowserFilePlugin, BrowserFilePlugin as default } from './PluginBrowser';
|
|
5
|
+
export * from './Schema';
|
|
6
|
+
export * from './Witness';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAA;AACpC,cAAc,UAAU,CAAA;AACxB,cAAc,UAAU,CAAA;AACxB,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,IAAI,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACjF,cAAc,UAAU,CAAA;AACxB,cAAc,WAAW,CAAA"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
// src/BrowserFileWitness.ts
|
|
2
|
+
import { assertEx } from "@xylabs/assert";
|
|
3
|
+
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
4
|
+
import shajs from "sha.js";
|
|
5
|
+
|
|
6
|
+
// src/Config.ts
|
|
7
|
+
var FileWitnessConfigSchema = "network.xyo.file.witness.config";
|
|
8
|
+
|
|
9
|
+
// src/Schema.ts
|
|
10
|
+
var FileSchema = "network.xyo.file";
|
|
11
|
+
|
|
12
|
+
// src/util/GenerateDataUri.ts
|
|
13
|
+
import { base64 } from "@scure/base";
|
|
14
|
+
var generateDataUri = (data) => {
|
|
15
|
+
return `data:application/octet-stream;base64,${base64.encode(data)}`;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
// src/Witness.ts
|
|
19
|
+
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
20
|
+
var FileWitness = class extends AbstractWitness {
|
|
21
|
+
static configSchemas = [FileWitnessConfigSchema];
|
|
22
|
+
observeHandler(payloads) {
|
|
23
|
+
return [{ ...payloads?.[0], schema: FileSchema }];
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
// src/BrowserFileWitness.ts
|
|
28
|
+
var BrowserFileWitness = class extends FileWitness {
|
|
29
|
+
static configSchemas = [FileWitnessConfigSchema];
|
|
30
|
+
async observeHandler() {
|
|
31
|
+
try {
|
|
32
|
+
const [payload] = await this.witnessBrowserFile();
|
|
33
|
+
console.log(`BrowserFileWitness: ${await PayloadBuilder.dataHash(payload)}`);
|
|
34
|
+
return [payload];
|
|
35
|
+
} catch (e) {
|
|
36
|
+
throw new Error(`Error reading file: ${e}`);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
readBinaryFile(file) {
|
|
40
|
+
return new Promise((resolve, reject) => {
|
|
41
|
+
const fileReader = new FileReader();
|
|
42
|
+
fileReader.addEventListener("load", (event) => {
|
|
43
|
+
const arrayBuffer = event.target?.result;
|
|
44
|
+
resolve(new Uint8Array(arrayBuffer));
|
|
45
|
+
});
|
|
46
|
+
fileReader.onerror = () => reject(fileReader.error);
|
|
47
|
+
fileReader.readAsArrayBuffer(file);
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
async witnessBrowserFile() {
|
|
51
|
+
const file = assertEx(this.params.file, "File is missing from params");
|
|
52
|
+
const fileBinary = await this.readBinaryFile(file);
|
|
53
|
+
const result = new Uint8Array(fileBinary);
|
|
54
|
+
const hash = shajs("sha256").update(result).digest("hex").padStart(64, "0");
|
|
55
|
+
return [
|
|
56
|
+
{
|
|
57
|
+
hash,
|
|
58
|
+
length: fileBinary.byteLength,
|
|
59
|
+
meta: {
|
|
60
|
+
name: file.name,
|
|
61
|
+
type: file.type
|
|
62
|
+
},
|
|
63
|
+
modified: file.lastModified,
|
|
64
|
+
schema: FileSchema,
|
|
65
|
+
uri: this.config.storage === "data-uri" ? generateDataUri(fileBinary) : file.name
|
|
66
|
+
},
|
|
67
|
+
fileBinary
|
|
68
|
+
];
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
// src/PluginBrowser.ts
|
|
73
|
+
import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
74
|
+
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
75
|
+
var BrowserFilePlugin = () => createPayloadSetWitnessPlugin(
|
|
76
|
+
{ required: { [FileSchema]: 1 }, schema: PayloadSetSchema },
|
|
77
|
+
{
|
|
78
|
+
witness: async (params) => {
|
|
79
|
+
const result = await BrowserFileWitness.create(params);
|
|
80
|
+
return result;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
);
|
|
84
|
+
export {
|
|
85
|
+
BrowserFilePlugin,
|
|
86
|
+
BrowserFileWitness,
|
|
87
|
+
FileSchema,
|
|
88
|
+
FileWitness,
|
|
89
|
+
FileWitnessConfigSchema,
|
|
90
|
+
BrowserFilePlugin as default
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/BrowserFileWitness.ts","../../src/Config.ts","../../src/Schema.ts","../../src/util/GenerateDataUri.ts","../../src/Witness.ts","../../src/PluginBrowser.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport shajs from 'sha.js'\n\nimport { FileWitnessConfigSchema } from './Config'\nimport { BrowserFileWitnessAdditionalParams } from './Params'\nimport { FilePayload } from './Payload'\nimport { FileSchema } from './Schema'\nimport { generateDataUri } from './util'\nimport { FileWitness, FileWitnessParams } from './Witness'\n\ntype BrowserFileWitnessParams = FileWitnessParams & BrowserFileWitnessAdditionalParams\n\nexport class BrowserFileWitness extends FileWitness<BrowserFileWitnessParams> {\n static override configSchemas = [FileWitnessConfigSchema]\n\n protected override async observeHandler() {\n try {\n const [payload] = await this.witnessBrowserFile()\n console.log(`BrowserFileWitness: ${await PayloadBuilder.dataHash(payload)}`)\n return [payload]\n } catch (e) {\n throw new Error(`Error reading file: ${e}`)\n }\n }\n\n private readBinaryFile(file: File): Promise<Uint8Array> {\n return new Promise((resolve, reject) => {\n const fileReader = new FileReader()\n fileReader.addEventListener('load', (event) => {\n const arrayBuffer = event.target?.result as ArrayBuffer\n resolve(new Uint8Array(arrayBuffer))\n })\n // eslint-disable-next-line unicorn/prefer-add-event-listener\n fileReader.onerror = () => reject(fileReader.error)\n // eslint-disable-next-line unicorn/prefer-blob-reading-methods\n fileReader.readAsArrayBuffer(file)\n })\n }\n\n private async witnessBrowserFile(): Promise<[FilePayload, Uint8Array]> {\n const file = assertEx(this.params.file, 'File is missing from params')\n const fileBinary = await this.readBinaryFile(file)\n const result = new Uint8Array(fileBinary)\n const hash = shajs('sha256').update(result).digest('hex').padStart(64, '0')\n\n return [\n {\n hash,\n length: fileBinary.byteLength,\n meta: {\n name: file.name,\n type: file.type,\n },\n modified: file.lastModified,\n schema: FileSchema,\n uri: this.config.storage === 'data-uri' ? generateDataUri(fileBinary) : file.name,\n },\n fileBinary,\n ]\n }\n}\n","import { WitnessConfig } from '@xyo-network/witness-model'\n\nexport type FileWitnessConfigSchema = 'network.xyo.file.witness.config'\nexport const FileWitnessConfigSchema: FileWitnessConfigSchema = 'network.xyo.file.witness.config'\n\nexport type FileWitnessConfig = WitnessConfig<{\n schema: FileWitnessConfigSchema\n storage?: 'data-uri'\n}>\n","export type FileSchema = 'network.xyo.file'\nexport const FileSchema: FileSchema = 'network.xyo.file'\n","import { base64 } from '@scure/base'\n\nexport const generateDataUri = (data: Uint8Array): string => {\n return `data:application/octet-stream;base64,${base64.encode(data)}`\n}\n","import { Promisable } from '@xylabs/promise'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessModule, WitnessParams } from '@xyo-network/witness-model'\n\nimport { FileWitnessConfig, FileWitnessConfigSchema } from './Config'\nimport { FileSchema } from './Schema'\n\nexport type FileWitnessParams = WitnessParams<AnyConfigSchema<FileWitnessConfig>>\n\n// Abstract so that derived classes provide a type for the file param and methods to parse it\nexport abstract class FileWitness<TParams extends FileWitnessParams = FileWitnessParams> extends AbstractWitness<TParams> implements WitnessModule {\n static override configSchemas = [FileWitnessConfigSchema]\n\n protected override observeHandler(payloads?: Payload[]): Promisable<Payload[]> {\n return [{ ...payloads?.[0], schema: FileSchema }]\n }\n}\n","import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { BrowserFileWitness } from './BrowserFileWitness'\nimport { FileSchema } from './Schema'\n\nexport const BrowserFilePlugin = () =>\n createPayloadSetWitnessPlugin<BrowserFileWitness>(\n { required: { [FileSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await BrowserFileWitness.create(params)\n return result\n },\n },\n )\n"],"mappings":";AAAA,SAAS,gBAAgB;AACzB,SAAS,sBAAsB;AAC/B,OAAO,WAAW;;;ACCX,IAAM,0BAAmD;;;ACFzD,IAAM,aAAyB;;;ACDtC,SAAS,cAAc;AAEhB,IAAM,kBAAkB,CAAC,SAA6B;AAC3D,SAAO,wCAAwC,OAAO,OAAO,IAAI,CAAC;AACpE;;;ACHA,SAAS,uBAAuB;AAWzB,IAAe,cAAf,cAA0F,gBAAkD;AAAA,EACjJ,OAAgB,gBAAgB,CAAC,uBAAuB;AAAA,EAErC,eAAe,UAA6C;AAC7E,WAAO,CAAC,EAAE,GAAG,WAAW,CAAC,GAAG,QAAQ,WAAW,CAAC;AAAA,EAClD;AACF;;;AJLO,IAAM,qBAAN,cAAiC,YAAsC;AAAA,EAC5E,OAAgB,gBAAgB,CAAC,uBAAuB;AAAA,EAExD,MAAyB,iBAAiB;AACxC,QAAI;AACF,YAAM,CAAC,OAAO,IAAI,MAAM,KAAK,mBAAmB;AAChD,cAAQ,IAAI,uBAAuB,MAAM,eAAe,SAAS,OAAO,CAAC,EAAE;AAC3E,aAAO,CAAC,OAAO;AAAA,IACjB,SAAS,GAAG;AACV,YAAM,IAAI,MAAM,uBAAuB,CAAC,EAAE;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,eAAe,MAAiC;AACtD,WAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,YAAM,aAAa,IAAI,WAAW;AAClC,iBAAW,iBAAiB,QAAQ,CAAC,UAAU;AAC7C,cAAM,cAAc,MAAM,QAAQ;AAClC,gBAAQ,IAAI,WAAW,WAAW,CAAC;AAAA,MACrC,CAAC;AAED,iBAAW,UAAU,MAAM,OAAO,WAAW,KAAK;AAElD,iBAAW,kBAAkB,IAAI;AAAA,IACnC,CAAC;AAAA,EACH;AAAA,EAEA,MAAc,qBAAyD;AACrE,UAAM,OAAO,SAAS,KAAK,OAAO,MAAM,6BAA6B;AACrE,UAAM,aAAa,MAAM,KAAK,eAAe,IAAI;AACjD,UAAM,SAAS,IAAI,WAAW,UAAU;AACxC,UAAM,OAAO,MAAM,QAAQ,EAAE,OAAO,MAAM,EAAE,OAAO,KAAK,EAAE,SAAS,IAAI,GAAG;AAE1E,WAAO;AAAA,MACL;AAAA,QACE;AAAA,QACA,QAAQ,WAAW;AAAA,QACnB,MAAM;AAAA,UACJ,MAAM,KAAK;AAAA,UACX,MAAM,KAAK;AAAA,QACb;AAAA,QACA,UAAU,KAAK;AAAA,QACf,QAAQ;AAAA,QACR,KAAK,KAAK,OAAO,YAAY,aAAa,gBAAgB,UAAU,IAAI,KAAK;AAAA,MAC/E;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACF;;;AK7DA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;AAKvC,IAAM,oBAAoB,MAC/B;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,UAAU,GAAG,EAAE,GAAG,QAAQ,iBAAiB;AAAA,EAC1D;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,mBAAmB,OAAO,MAAM;AACrD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GenerateDataUri.d.ts","sourceRoot":"","sources":["../../../src/util/GenerateDataUri.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,eAAe,SAAU,UAAU,KAAG,MAElD,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GenerateDataUri.d.ts","sourceRoot":"","sources":["../../../src/util/GenerateDataUri.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,eAAe,SAAU,UAAU,KAAG,MAElD,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GenerateDataUri.d.ts","sourceRoot":"","sources":["../../../src/util/GenerateDataUri.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,eAAe,SAAU,UAAU,KAAG,MAElD,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/util/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/util/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/util/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { BrowserFileWitnessAdditionalParams } from './Params';
|
|
2
|
+
import { FileWitness, FileWitnessParams } from './Witness';
|
|
3
|
+
type BrowserFileWitnessParams = FileWitnessParams & BrowserFileWitnessAdditionalParams;
|
|
4
|
+
export declare class BrowserFileWitness extends FileWitness<BrowserFileWitnessParams> {
|
|
5
|
+
static configSchemas: "network.xyo.file.witness.config"[];
|
|
6
|
+
protected observeHandler(): Promise<(import("@xyo-network/payload-model").SchemaFields & object & {
|
|
7
|
+
created?: number | undefined;
|
|
8
|
+
hash: string;
|
|
9
|
+
length: number;
|
|
10
|
+
meta?: Record<string, string | number> | undefined;
|
|
11
|
+
modified?: number | undefined;
|
|
12
|
+
uri: string;
|
|
13
|
+
} & {
|
|
14
|
+
schema: "network.xyo.file";
|
|
15
|
+
})[]>;
|
|
16
|
+
private readBinaryFile;
|
|
17
|
+
private witnessBrowserFile;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=BrowserFileWitness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BrowserFileWitness.d.ts","sourceRoot":"","sources":["../../src/BrowserFileWitness.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,kCAAkC,EAAE,MAAM,UAAU,CAAA;AAI7D,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAA;AAE1D,KAAK,wBAAwB,GAAG,iBAAiB,GAAG,kCAAkC,CAAA;AAEtF,qBAAa,kBAAmB,SAAQ,WAAW,CAAC,wBAAwB,CAAC;IAC3E,OAAgB,aAAa,sCAA4B;cAEhC,cAAc;;;;;;;;;;IAUvC,OAAO,CAAC,cAAc;YAcR,kBAAkB;CAqBjC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { BrowserFileWitnessAdditionalParams } from './Params';
|
|
2
|
+
import { FileWitness, FileWitnessParams } from './Witness';
|
|
3
|
+
type BrowserFileWitnessParams = FileWitnessParams & BrowserFileWitnessAdditionalParams;
|
|
4
|
+
export declare class BrowserFileWitness extends FileWitness<BrowserFileWitnessParams> {
|
|
5
|
+
static configSchemas: "network.xyo.file.witness.config"[];
|
|
6
|
+
protected observeHandler(): Promise<(import("@xyo-network/payload-model").SchemaFields & object & {
|
|
7
|
+
created?: number | undefined;
|
|
8
|
+
hash: string;
|
|
9
|
+
length: number;
|
|
10
|
+
meta?: Record<string, string | number> | undefined;
|
|
11
|
+
modified?: number | undefined;
|
|
12
|
+
uri: string;
|
|
13
|
+
} & {
|
|
14
|
+
schema: "network.xyo.file";
|
|
15
|
+
})[]>;
|
|
16
|
+
private readBinaryFile;
|
|
17
|
+
private witnessBrowserFile;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=BrowserFileWitness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BrowserFileWitness.d.ts","sourceRoot":"","sources":["../../src/BrowserFileWitness.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,kCAAkC,EAAE,MAAM,UAAU,CAAA;AAI7D,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAA;AAE1D,KAAK,wBAAwB,GAAG,iBAAiB,GAAG,kCAAkC,CAAA;AAEtF,qBAAa,kBAAmB,SAAQ,WAAW,CAAC,wBAAwB,CAAC;IAC3E,OAAgB,aAAa,sCAA4B;cAEhC,cAAc;;;;;;;;;;IAUvC,OAAO,CAAC,cAAc;YAcR,kBAAkB;CAqBjC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { BrowserFileWitnessAdditionalParams } from './Params';
|
|
2
|
+
import { FileWitness, FileWitnessParams } from './Witness';
|
|
3
|
+
type BrowserFileWitnessParams = FileWitnessParams & BrowserFileWitnessAdditionalParams;
|
|
4
|
+
export declare class BrowserFileWitness extends FileWitness<BrowserFileWitnessParams> {
|
|
5
|
+
static configSchemas: "network.xyo.file.witness.config"[];
|
|
6
|
+
protected observeHandler(): Promise<(import("@xyo-network/payload-model").SchemaFields & object & {
|
|
7
|
+
created?: number | undefined;
|
|
8
|
+
hash: string;
|
|
9
|
+
length: number;
|
|
10
|
+
meta?: Record<string, string | number> | undefined;
|
|
11
|
+
modified?: number | undefined;
|
|
12
|
+
uri: string;
|
|
13
|
+
} & {
|
|
14
|
+
schema: "network.xyo.file";
|
|
15
|
+
})[]>;
|
|
16
|
+
private readBinaryFile;
|
|
17
|
+
private witnessBrowserFile;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=BrowserFileWitness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BrowserFileWitness.d.ts","sourceRoot":"","sources":["../../src/BrowserFileWitness.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,kCAAkC,EAAE,MAAM,UAAU,CAAA;AAI7D,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAA;AAE1D,KAAK,wBAAwB,GAAG,iBAAiB,GAAG,kCAAkC,CAAA;AAEtF,qBAAa,kBAAmB,SAAQ,WAAW,CAAC,wBAAwB,CAAC;IAC3E,OAAgB,aAAa,sCAA4B;cAEhC,cAAc;;;;;;;;;;IAUvC,OAAO,CAAC,cAAc;YAcR,kBAAkB;CAqBjC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { WitnessConfig } from '@xyo-network/witness-model';
|
|
2
|
+
export type FileWitnessConfigSchema = 'network.xyo.file.witness.config';
|
|
3
|
+
export declare const FileWitnessConfigSchema: FileWitnessConfigSchema;
|
|
4
|
+
export type FileWitnessConfig = WitnessConfig<{
|
|
5
|
+
schema: FileWitnessConfigSchema;
|
|
6
|
+
storage?: 'data-uri';
|
|
7
|
+
}>;
|
|
8
|
+
//# sourceMappingURL=Config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Config.d.ts","sourceRoot":"","sources":["../../src/Config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAE1D,MAAM,MAAM,uBAAuB,GAAG,iCAAiC,CAAA;AACvE,eAAO,MAAM,uBAAuB,EAAE,uBAA2D,CAAA;AAEjG,MAAM,MAAM,iBAAiB,GAAG,aAAa,CAAC;IAC5C,MAAM,EAAE,uBAAuB,CAAA;IAC/B,OAAO,CAAC,EAAE,UAAU,CAAA;CACrB,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { WitnessConfig } from '@xyo-network/witness-model';
|
|
2
|
+
export type FileWitnessConfigSchema = 'network.xyo.file.witness.config';
|
|
3
|
+
export declare const FileWitnessConfigSchema: FileWitnessConfigSchema;
|
|
4
|
+
export type FileWitnessConfig = WitnessConfig<{
|
|
5
|
+
schema: FileWitnessConfigSchema;
|
|
6
|
+
storage?: 'data-uri';
|
|
7
|
+
}>;
|
|
8
|
+
//# sourceMappingURL=Config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Config.d.ts","sourceRoot":"","sources":["../../src/Config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAE1D,MAAM,MAAM,uBAAuB,GAAG,iCAAiC,CAAA;AACvE,eAAO,MAAM,uBAAuB,EAAE,uBAA2D,CAAA;AAEjG,MAAM,MAAM,iBAAiB,GAAG,aAAa,CAAC;IAC5C,MAAM,EAAE,uBAAuB,CAAA;IAC/B,OAAO,CAAC,EAAE,UAAU,CAAA;CACrB,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { WitnessConfig } from '@xyo-network/witness-model';
|
|
2
|
+
export type FileWitnessConfigSchema = 'network.xyo.file.witness.config';
|
|
3
|
+
export declare const FileWitnessConfigSchema: FileWitnessConfigSchema;
|
|
4
|
+
export type FileWitnessConfig = WitnessConfig<{
|
|
5
|
+
schema: FileWitnessConfigSchema;
|
|
6
|
+
storage?: 'data-uri';
|
|
7
|
+
}>;
|
|
8
|
+
//# sourceMappingURL=Config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Config.d.ts","sourceRoot":"","sources":["../../src/Config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAE1D,MAAM,MAAM,uBAAuB,GAAG,iCAAiC,CAAA;AACvE,eAAO,MAAM,uBAAuB,EAAE,uBAA2D,CAAA;AAEjG,MAAM,MAAM,iBAAiB,GAAG,aAAa,CAAC;IAC5C,MAAM,EAAE,uBAAuB,CAAA;IAC/B,OAAO,CAAC,EAAE,UAAU,CAAA;CACrB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Params.d.ts","sourceRoot":"","sources":["../../src/Params.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kCAAkC,GAAG;IAC/C,IAAI,CAAC,EAAE,IAAI,CAAA;CACZ,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Params.d.ts","sourceRoot":"","sources":["../../src/Params.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kCAAkC,GAAG;IAC/C,IAAI,CAAC,EAAE,IAAI,CAAA;CACZ,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Params.d.ts","sourceRoot":"","sources":["../../src/Params.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kCAAkC,GAAG;IAC/C,IAAI,CAAC,EAAE,IAAI,CAAA;CACZ,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
+
import { FileSchema } from './Schema';
|
|
3
|
+
export type BinaryDataHash = string;
|
|
4
|
+
/** @description File location and optional data */
|
|
5
|
+
export type FilePayload = Payload<{
|
|
6
|
+
created?: number;
|
|
7
|
+
hash: BinaryDataHash;
|
|
8
|
+
length: number;
|
|
9
|
+
/** @field Storage specific meta data */
|
|
10
|
+
meta?: Record<string, string | number>;
|
|
11
|
+
modified?: number;
|
|
12
|
+
uri: string;
|
|
13
|
+
}, FileSchema>;
|
|
14
|
+
//# sourceMappingURL=Payload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAErC,MAAM,MAAM,cAAc,GAAG,MAAM,CAAA;AAEnC,mDAAmD;AACnD,MAAM,MAAM,WAAW,GAAG,OAAO,CAC/B;IACE,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,cAAc,CAAA;IACpB,MAAM,EAAE,MAAM,CAAA;IACd,wCAAwC;IACxC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,CAAA;IACtC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,GAAG,EAAE,MAAM,CAAA;CACZ,EACD,UAAU,CACX,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
+
import { FileSchema } from './Schema';
|
|
3
|
+
export type BinaryDataHash = string;
|
|
4
|
+
/** @description File location and optional data */
|
|
5
|
+
export type FilePayload = Payload<{
|
|
6
|
+
created?: number;
|
|
7
|
+
hash: BinaryDataHash;
|
|
8
|
+
length: number;
|
|
9
|
+
/** @field Storage specific meta data */
|
|
10
|
+
meta?: Record<string, string | number>;
|
|
11
|
+
modified?: number;
|
|
12
|
+
uri: string;
|
|
13
|
+
}, FileSchema>;
|
|
14
|
+
//# sourceMappingURL=Payload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAErC,MAAM,MAAM,cAAc,GAAG,MAAM,CAAA;AAEnC,mDAAmD;AACnD,MAAM,MAAM,WAAW,GAAG,OAAO,CAC/B;IACE,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,cAAc,CAAA;IACpB,MAAM,EAAE,MAAM,CAAA;IACd,wCAAwC;IACxC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,CAAA;IACtC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,GAAG,EAAE,MAAM,CAAA;CACZ,EACD,UAAU,CACX,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
+
import { FileSchema } from './Schema';
|
|
3
|
+
export type BinaryDataHash = string;
|
|
4
|
+
/** @description File location and optional data */
|
|
5
|
+
export type FilePayload = Payload<{
|
|
6
|
+
created?: number;
|
|
7
|
+
hash: BinaryDataHash;
|
|
8
|
+
length: number;
|
|
9
|
+
/** @field Storage specific meta data */
|
|
10
|
+
meta?: Record<string, string | number>;
|
|
11
|
+
modified?: number;
|
|
12
|
+
uri: string;
|
|
13
|
+
}, FileSchema>;
|
|
14
|
+
//# sourceMappingURL=Payload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAErC,MAAM,MAAM,cAAc,GAAG,MAAM,CAAA;AAEnC,mDAAmD;AACnD,MAAM,MAAM,WAAW,GAAG,OAAO,CAC/B;IACE,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,cAAc,CAAA;IACpB,MAAM,EAAE,MAAM,CAAA;IACd,wCAAwC;IACxC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,CAAA;IACtC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,GAAG,EAAE,MAAM,CAAA;CACZ,EACD,UAAU,CACX,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PluginBrowser.d.ts","sourceRoot":"","sources":["../../src/PluginBrowser.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAGzD,eAAO,MAAM,iBAAiB,4FAS3B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PluginBrowser.d.ts","sourceRoot":"","sources":["../../src/PluginBrowser.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAGzD,eAAO,MAAM,iBAAiB,4FAS3B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PluginBrowser.d.ts","sourceRoot":"","sources":["../../src/PluginBrowser.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAGzD,eAAO,MAAM,iBAAiB,4FAS3B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,kBAAkB,CAAA;AAC3C,eAAO,MAAM,UAAU,EAAE,UAA+B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,kBAAkB,CAAA;AAC3C,eAAO,MAAM,UAAU,EAAE,UAA+B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,kBAAkB,CAAA;AAC3C,eAAO,MAAM,UAAU,EAAE,UAA+B,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Promisable } from '@xylabs/promise';
|
|
2
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
3
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
4
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
5
|
+
import { WitnessModule, WitnessParams } from '@xyo-network/witness-model';
|
|
6
|
+
import { FileWitnessConfig } from './Config';
|
|
7
|
+
export type FileWitnessParams = WitnessParams<AnyConfigSchema<FileWitnessConfig>>;
|
|
8
|
+
export declare abstract class FileWitness<TParams extends FileWitnessParams = FileWitnessParams> extends AbstractWitness<TParams> implements WitnessModule {
|
|
9
|
+
static configSchemas: "network.xyo.file.witness.config"[];
|
|
10
|
+
protected observeHandler(payloads?: Payload[]): Promisable<Payload[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAEzE,OAAO,EAAE,iBAAiB,EAA2B,MAAM,UAAU,CAAA;AAGrE,MAAM,MAAM,iBAAiB,GAAG,aAAa,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,CAAA;AAGjF,8BAAsB,WAAW,CAAC,OAAO,SAAS,iBAAiB,GAAG,iBAAiB,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAE,YAAW,aAAa;IAChJ,OAAgB,aAAa,sCAA4B;cAEtC,cAAc,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;CAG/E"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Promisable } from '@xylabs/promise';
|
|
2
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
3
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
4
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
5
|
+
import { WitnessModule, WitnessParams } from '@xyo-network/witness-model';
|
|
6
|
+
import { FileWitnessConfig } from './Config';
|
|
7
|
+
export type FileWitnessParams = WitnessParams<AnyConfigSchema<FileWitnessConfig>>;
|
|
8
|
+
export declare abstract class FileWitness<TParams extends FileWitnessParams = FileWitnessParams> extends AbstractWitness<TParams> implements WitnessModule {
|
|
9
|
+
static configSchemas: "network.xyo.file.witness.config"[];
|
|
10
|
+
protected observeHandler(payloads?: Payload[]): Promisable<Payload[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAEzE,OAAO,EAAE,iBAAiB,EAA2B,MAAM,UAAU,CAAA;AAGrE,MAAM,MAAM,iBAAiB,GAAG,aAAa,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,CAAA;AAGjF,8BAAsB,WAAW,CAAC,OAAO,SAAS,iBAAiB,GAAG,iBAAiB,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAE,YAAW,aAAa;IAChJ,OAAgB,aAAa,sCAA4B;cAEtC,cAAc,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;CAG/E"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Promisable } from '@xylabs/promise';
|
|
2
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
3
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
4
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
5
|
+
import { WitnessModule, WitnessParams } from '@xyo-network/witness-model';
|
|
6
|
+
import { FileWitnessConfig } from './Config';
|
|
7
|
+
export type FileWitnessParams = WitnessParams<AnyConfigSchema<FileWitnessConfig>>;
|
|
8
|
+
export declare abstract class FileWitness<TParams extends FileWitnessParams = FileWitnessParams> extends AbstractWitness<TParams> implements WitnessModule {
|
|
9
|
+
static configSchemas: "network.xyo.file.witness.config"[];
|
|
10
|
+
protected observeHandler(payloads?: Payload[]): Promisable<Payload[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAEzE,OAAO,EAAE,iBAAiB,EAA2B,MAAM,UAAU,CAAA;AAGrE,MAAM,MAAM,iBAAiB,GAAG,aAAa,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,CAAA;AAGjF,8BAAsB,WAAW,CAAC,OAAO,SAAS,iBAAiB,GAAG,iBAAiB,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAE,YAAW,aAAa;IAChJ,OAAgB,aAAa,sCAA4B;cAEtC,cAAc,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;CAG/E"}
|