@seedprotocol/sdk 0.2.31 → 0.2.33
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/dist/{ArweaveClient-C-HZgUWJ.js → ArweaveClient-BXD_aTsx.js} +2 -2
- package/dist/{ArweaveClient-rTTCUjiu.js.map → ArweaveClient-BXD_aTsx.js.map} +1 -1
- package/dist/{ArweaveClient-rTTCUjiu.js → ArweaveClient-CkcZD_QE.js} +2 -2
- package/dist/{ArweaveClient-C-HZgUWJ.js.map → ArweaveClient-CkcZD_QE.js.map} +1 -1
- package/dist/{Db-CPpw7pPl.js → Db-CRAJJwNf.js} +11 -9
- package/dist/{Db-CPpw7pPl.js.map → Db-CRAJJwNf.js.map} +1 -1
- package/dist/Db-DJQELGcv.js +390 -0
- package/dist/Db-DJQELGcv.js.map +1 -0
- package/dist/{EasClient-CKv5Eyao.js → EasClient-BNwSwDTO.js} +2 -2
- package/dist/{EasClient-nvmz2kCc.js.map → EasClient-BNwSwDTO.js.map} +1 -1
- package/dist/{EasClient-nvmz2kCc.js → EasClient-epqE9aWI.js} +2 -2
- package/dist/{EasClient-CKv5Eyao.js.map → EasClient-epqE9aWI.js.map} +1 -1
- package/dist/{FileManager-EGwM_VHY.js → FileManager-CXk83EW5.js} +4 -4
- package/dist/FileManager-CXk83EW5.js.map +1 -0
- package/dist/{FileManager-Bm_fGCH1.js → FileManager-DXi-X7r5.js} +2 -2
- package/dist/{FileManager-Bm_fGCH1.js.map → FileManager-DXi-X7r5.js.map} +1 -1
- package/dist/{Item-DJFIzrGb.js → Item-BOhP5-1O.js} +5 -9
- package/dist/{Item-DJFIzrGb.js.map → Item-BOhP5-1O.js.map} +1 -1
- package/dist/{ItemProperty-DabiYJLq.js → ItemProperty-DCg4lfHD.js} +5 -9
- package/dist/{ItemProperty-DabiYJLq.js.map → ItemProperty-DCg4lfHD.js.map} +1 -1
- package/dist/{QueryClient-CkqXe8Nk.js → QueryClient-Ckl99FYC.js} +2 -2
- package/dist/{QueryClient-CkqXe8Nk.js.map → QueryClient-Ckl99FYC.js.map} +1 -1
- package/dist/{QueryClient-pzZAYWa0.js → QueryClient-Do0C7Jnt.js} +2 -2
- package/dist/{QueryClient-pzZAYWa0.js.map → QueryClient-Do0C7Jnt.js.map} +1 -1
- package/dist/bin.js +6 -5
- package/dist/bin.js.map +1 -1
- package/dist/{constants-BjOTXEgm.js → constants-BakHTrB9.js} +2 -2
- package/dist/{constants-BjOTXEgm.js.map → constants-BakHTrB9.js.map} +1 -1
- package/dist/{index-D3qJ54jj.js → index-BHO9xsvZ.js} +50 -292
- package/dist/index-BHO9xsvZ.js.map +1 -0
- package/dist/{index-MhbsovAK.js → index-CL38MNKB.js} +5 -9
- package/dist/index-CL38MNKB.js.map +1 -0
- package/dist/main.js +6 -10
- package/dist/main.js.map +1 -1
- package/dist/{seed.schema.config-DCFBkB3M.js → seed.schema.config-CpD6BtqH.js} +5 -9
- package/dist/seed.schema.config-CpD6BtqH.js.map +1 -0
- package/dist/src/BaseDb.ts +4 -0
- package/dist/src/BaseItem.ts +4 -0
- package/dist/src/Db.ts +5 -0
- package/dist/src/FileManager.ts +2 -2
- package/dist/src/IItem.ts +2 -1
- package/dist/src/SeedProtocolSdk.d.ts +0 -15
- package/dist/src/content-hash.ts +30 -0
- package/dist/src/create.ts +2 -2
- package/dist/src/download.ts +1 -1
- package/dist/src/getItem.ts +2 -3
- package/dist/src/getPublishPayload.ts +2 -8
- package/dist/src/image-resize.ts +28 -0
- package/dist/src/migrate.ts +3 -241
- package/dist/src/preparePublishRequestData.ts +2 -2
- package/dist/src/requestAll.ts +3 -3
- package/dist/src/saveImageSrc.ts +4 -0
- package/dist/src/upload.ts +2 -2
- package/dist/types/src/Item/BaseItem.d.ts +11 -1
- package/dist/types/src/Item/BaseItem.d.ts.map +1 -1
- package/dist/types/src/ItemProperty/service/actors/saveValueToDb/saveImageSrc.d.ts.map +1 -1
- package/dist/types/src/browser/db/Db.d.ts +2 -0
- package/dist/types/src/browser/db/Db.d.ts.map +1 -1
- package/dist/types/src/browser/index.d.ts.map +1 -1
- package/dist/types/src/browser/react/item.d.ts +3 -2
- package/dist/types/src/browser/react/item.d.ts.map +1 -1
- package/dist/types/src/browser/workers/content-hash.d.ts +2 -0
- package/dist/types/src/browser/workers/content-hash.d.ts.map +1 -0
- package/dist/types/src/browser/workers/image-resize.d.ts +2 -0
- package/dist/types/src/browser/workers/image-resize.d.ts.map +1 -0
- package/dist/types/src/db/Db/BaseDb.d.ts +1 -0
- package/dist/types/src/db/Db/BaseDb.d.ts.map +1 -1
- package/dist/types/src/db/read/getItem.d.ts.map +1 -1
- package/dist/types/src/db/read/getPublishPayload.d.ts +2 -2
- package/dist/types/src/db/read/getPublishPayload.d.ts.map +1 -1
- package/dist/types/src/helpers/ArweaveClient/queries.d.ts.map +1 -0
- package/dist/types/src/helpers/index.d.ts +1 -3
- package/dist/types/src/helpers/index.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/interfaces/IItem.d.ts +1 -0
- package/dist/types/src/interfaces/IItem.d.ts.map +1 -1
- package/dist/types/src/node/db/Db.d.ts +3 -0
- package/dist/types/src/node/db/Db.d.ts.map +1 -1
- package/dist/types/src/services/db/actors/migrate.d.ts +0 -1
- package/dist/types/src/services/db/actors/migrate.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +0 -31
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/package.json +7 -14
- package/dist/Db-DW4cvius.js +0 -138
- package/dist/Db-DW4cvius.js.map +0 -1
- package/dist/FileManager-EGwM_VHY.js.map +0 -1
- package/dist/index-D3qJ54jj.js.map +0 -1
- package/dist/index-MhbsovAK.js.map +0 -1
- package/dist/seed.schema.config-DCFBkB3M.js.map +0 -1
- package/dist/src/logger.ts +0 -33
- package/dist/types/src/browser/arweave/queries.d.ts.map +0 -1
- package/dist/types/src/helpers/logger.d.ts +0 -7
- package/dist/types/src/helpers/logger.d.ts.map +0 -1
- /package/dist/types/src/{browser/arweave → helpers/ArweaveClient}/queries.d.ts +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { B as BaseArweaveClient, A as ARWEAVE_ENDPOINT } from './constants-
|
|
1
|
+
import { B as BaseArweaveClient, A as ARWEAVE_ENDPOINT } from './constants-BakHTrB9.js';
|
|
2
2
|
import { GraphQLClient } from 'graphql-request';
|
|
3
3
|
import '@ethereum-attestation-service/eas-sdk';
|
|
4
4
|
|
|
@@ -10,4 +10,4 @@ class ArweaveClient extends BaseArweaveClient {
|
|
|
10
10
|
BaseArweaveClient.setPlatformClass(ArweaveClient);
|
|
11
11
|
|
|
12
12
|
export { ArweaveClient };
|
|
13
|
-
//# sourceMappingURL=ArweaveClient-
|
|
13
|
+
//# sourceMappingURL=ArweaveClient-BXD_aTsx.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArweaveClient-
|
|
1
|
+
{"version":3,"file":"ArweaveClient-BXD_aTsx.js","sources":["../../src/browser/helpers/ArweaveClient.ts"],"sourcesContent":["import { BaseArweaveClient } from \"@/helpers/ArweaveClient/BaseArweaveClient\";\nimport { ARWEAVE_ENDPOINT } from \"@/services/internal/constants\";\nimport { GraphQLClient } from \"graphql-request\";\n\nclass ArweaveClient extends BaseArweaveClient {\n static getArweaveClient(): GraphQLClient {\n return new GraphQLClient(ARWEAVE_ENDPOINT)\n }\n}\n\nBaseArweaveClient.setPlatformClass(ArweaveClient)\n\nexport { ArweaveClient }"],"names":[],"mappings":";;;;AAIA,MAAM,aAAc,SAAQ,iBAAiB,CAAA;AAC3C,IAAA,OAAO,gBAAgB,GAAA;AACrB,QAAA,OAAO,IAAI,aAAa,CAAC,gBAAgB,CAAC;;AAE7C;AAED,iBAAiB,CAAC,gBAAgB,CAAC,aAAa,CAAC;;;;"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { B as BaseArweaveClient, A as ARWEAVE_ENDPOINT } from './constants-
|
|
1
|
+
import { B as BaseArweaveClient, A as ARWEAVE_ENDPOINT } from './constants-BakHTrB9.js';
|
|
2
2
|
import { GraphQLClient } from 'graphql-request';
|
|
3
3
|
import '@ethereum-attestation-service/eas-sdk';
|
|
4
4
|
|
|
@@ -10,4 +10,4 @@ class ArweaveClient extends BaseArweaveClient {
|
|
|
10
10
|
BaseArweaveClient.setPlatformClass(ArweaveClient);
|
|
11
11
|
|
|
12
12
|
export { ArweaveClient };
|
|
13
|
-
//# sourceMappingURL=ArweaveClient-
|
|
13
|
+
//# sourceMappingURL=ArweaveClient-CkcZD_QE.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArweaveClient-
|
|
1
|
+
{"version":3,"file":"ArweaveClient-CkcZD_QE.js","sources":["../../src/node/helpers/ArweaveClient.ts"],"sourcesContent":["import { BaseArweaveClient } from '@/helpers/ArweaveClient/BaseArweaveClient';\nimport { ARWEAVE_ENDPOINT } from '@/services/internal/constants';\nimport { GraphQLClient } from 'graphql-request';\n\nclass ArweaveClient extends BaseArweaveClient {\n static getArweaveClient(): GraphQLClient {\n return new GraphQLClient(ARWEAVE_ENDPOINT);\n }\n}\n\nBaseArweaveClient.setPlatformClass(ArweaveClient);\n\nexport { ArweaveClient }; "],"names":[],"mappings":";;;;AAIA,MAAM,aAAc,SAAQ,iBAAiB,CAAA;AAC3C,IAAA,OAAO,gBAAgB,GAAA;AACrB,QAAA,OAAO,IAAI,aAAa,CAAC,gBAAgB,CAAC;;AAE7C;AAED,iBAAiB,CAAC,gBAAgB,CAAC,aAAa,CAAC;;;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __awaiter } from 'tslib';
|
|
2
|
-
import { b as BaseDb } from './index-
|
|
2
|
+
import { b as BaseDb } from './index-BHO9xsvZ.js';
|
|
3
3
|
import { defineConfig } from 'drizzle-kit';
|
|
4
4
|
import dotenv from 'dotenv';
|
|
5
5
|
import process from 'node:process';
|
|
@@ -9,30 +9,26 @@ import Database from 'better-sqlite3';
|
|
|
9
9
|
import 'immer';
|
|
10
10
|
import 'reflect-metadata';
|
|
11
11
|
import '@sinclair/typebox';
|
|
12
|
+
import 'eventemitter3';
|
|
12
13
|
import 'drizzle-orm';
|
|
13
14
|
import 'react';
|
|
14
|
-
import 'dayjs';
|
|
15
15
|
import 'nanoid';
|
|
16
16
|
import 'nanoid-dictionary';
|
|
17
17
|
import '@zenfs/core';
|
|
18
18
|
import 'debug';
|
|
19
19
|
import 'drizzle-orm/sqlite-core';
|
|
20
|
-
import './constants-
|
|
20
|
+
import './constants-BakHTrB9.js';
|
|
21
21
|
import '@ethereum-attestation-service/eas-sdk';
|
|
22
22
|
import 'xstate';
|
|
23
23
|
import 'pluralize';
|
|
24
|
-
import 'eventemitter3';
|
|
25
24
|
import 'lodash-es';
|
|
26
25
|
import '@statelyai/inspect';
|
|
27
|
-
import 'drizzle-orm/sqlite-proxy';
|
|
28
|
-
import 'drizzle-orm/sqlite-proxy/migrator';
|
|
29
|
-
import 'drizzle-orm/migrator';
|
|
30
26
|
import 'node:fs';
|
|
31
27
|
import '@zenfs/dom';
|
|
32
28
|
import 'arweave';
|
|
29
|
+
import 'rxjs';
|
|
33
30
|
import 'use-immer';
|
|
34
31
|
import '@xstate/react';
|
|
35
|
-
import 'rxjs';
|
|
36
32
|
|
|
37
33
|
dotenv.config();
|
|
38
34
|
let sdkRoot = './node_modules/@seedprotocol/sdk';
|
|
@@ -107,8 +103,14 @@ class Db extends BaseDb {
|
|
|
107
103
|
};
|
|
108
104
|
});
|
|
109
105
|
}
|
|
106
|
+
static migrate(pathToDbDir, dbName, dbId) {
|
|
107
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
108
|
+
const nodeDbConfig = getConfig(pathToDbDir);
|
|
109
|
+
return drizzle(nodeDbConfig);
|
|
110
|
+
});
|
|
111
|
+
}
|
|
110
112
|
}
|
|
111
113
|
BaseDb.setPlatformClass(Db);
|
|
112
114
|
|
|
113
115
|
export { Db };
|
|
114
|
-
//# sourceMappingURL=Db-
|
|
116
|
+
//# sourceMappingURL=Db-CRAJJwNf.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Db-
|
|
1
|
+
{"version":3,"file":"Db-CRAJJwNf.js","sources":["../../src/node/db/node.app.db.config.ts","../../src/node/db/Db.ts"],"sourcesContent":["import { defineConfig } from 'drizzle-kit'\nimport dotenv from 'dotenv'\nimport process from 'node:process'\nimport path from 'path'\nimport { DrizzleConfig } from 'drizzle-orm'\n\ndotenv.config()\n\nlet sdkRoot = './node_modules/@seedprotocol/sdk'\n\nif (process.env.IS_SEED_DEV) {\n sdkRoot = './src'\n}\n\nlet dotSeedDir = path.join(process.cwd(), '.seed')\n\nif (process.env.IS_SEED_DEV) {\n dotSeedDir = path.join(\n process.cwd(),\n '__tests__',\n '__mocks__',\n 'browser',\n 'project',\n '.seed',\n )\n}\n\nlet schemaDir = `${sdkRoot}/dist/seedSchema/*.ts`\n\nif (process.env.IS_SEED_DEV) {\n schemaDir = `${sdkRoot}/seedSchema/*.ts`\n}\n\nexport default defineConfig({\n schema: schemaDir,\n dialect: 'sqlite',\n out: `${dotSeedDir}/db`,\n dbCredentials: {\n url: `${dotSeedDir}/db/app_db.sqlite3`,\n },\n}) as DrizzleConfig\n","import { BaseDb } from \"@/db/Db/BaseDb\";\nimport { IDb } from \"@/interfaces\";\nimport nodeAppDbConfig from \"./node.app.db.config\";\nimport { drizzle } from \"drizzle-orm/better-sqlite3\";\nimport { defineConfig, } from \"drizzle-kit\";\nimport path from \"path\";\nimport { DrizzleConfig, } from \"drizzle-orm\";\nimport Database from \"better-sqlite3\";\n\nconst getConfig = (filesDir: string) => {\n\n const dotSeedDir = path.join(filesDir, '.seed')\n let schemaDir = `${dotSeedDir}/schema/*Schema.ts`\n\n const nodeDbConfig = defineConfig({\n schema: schemaDir,\n dialect: 'sqlite',\n out: `${dotSeedDir}/db`,\n dbCredentials: {\n url: `${dotSeedDir}/db/app_db.sqlite3`,\n }\n }) as DrizzleConfig & { dbCredentials: { url: string } }\n\n return nodeDbConfig\n}\n\nclass Db extends BaseDb implements IDb {\n constructor() {\n super()\n }\n\n static getAppDb() {\n return drizzle(nodeAppDbConfig)\n }\n\n static isAppDbReady() {\n return true\n }\n\n static async prepareDb(filesDir: string) {\n const nodeDbConfig = getConfig(filesDir)\n\n let db\n\n try {\n db = drizzle(nodeDbConfig)\n } catch (error) {\n console.error(error)\n }\n\n try {\n const client = new Database(nodeDbConfig.dbCredentials.url)\n db = drizzle({ client })\n } catch (error) {\n console.error(error)\n }\n\n return db\n }\n\n static async connectToDb(pathToDir: string, dbName: string) {\n\n const nodeDbConfig = getConfig(pathToDir)\n\n return {\n id: drizzle(nodeDbConfig).$client.name\n }\n }\n\n static async migrate(pathToDbDir: string, dbName: string, dbId: string) {\n const nodeDbConfig = getConfig(pathToDbDir)\n return drizzle(nodeDbConfig)\n }\n}\n\nBaseDb.setPlatformClass(Db)\n\nexport { Db }"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,390 @@
|
|
|
1
|
+
import { __awaiter } from 'tslib';
|
|
2
|
+
import { b as BaseDb, w as waitForFile } from './index-BHO9xsvZ.js';
|
|
3
|
+
import { sql } from 'drizzle-orm';
|
|
4
|
+
import debug from 'debug';
|
|
5
|
+
import fs from '@zenfs/core';
|
|
6
|
+
import { readMigrationFiles } from 'drizzle-orm/migrator';
|
|
7
|
+
import { drizzle } from 'drizzle-orm/sqlite-proxy';
|
|
8
|
+
import { migrate } from 'drizzle-orm/sqlite-proxy/migrator';
|
|
9
|
+
import { d as BROWSER_FS_TOP_DIR } from './constants-BakHTrB9.js';
|
|
10
|
+
import 'immer';
|
|
11
|
+
import 'reflect-metadata';
|
|
12
|
+
import '@sinclair/typebox';
|
|
13
|
+
import 'eventemitter3';
|
|
14
|
+
import 'react';
|
|
15
|
+
import 'nanoid';
|
|
16
|
+
import 'nanoid-dictionary';
|
|
17
|
+
import 'drizzle-orm/sqlite-core';
|
|
18
|
+
import 'xstate';
|
|
19
|
+
import 'pluralize';
|
|
20
|
+
import 'lodash-es';
|
|
21
|
+
import '@statelyai/inspect';
|
|
22
|
+
import 'node:fs';
|
|
23
|
+
import '@zenfs/dom';
|
|
24
|
+
import 'path';
|
|
25
|
+
import 'arweave';
|
|
26
|
+
import 'rxjs';
|
|
27
|
+
import '@ethereum-attestation-service/eas-sdk';
|
|
28
|
+
import 'use-immer';
|
|
29
|
+
import '@xstate/react';
|
|
30
|
+
|
|
31
|
+
let sqlite3InitModule;
|
|
32
|
+
let sqliteWasmClient;
|
|
33
|
+
let isPreparing = false;
|
|
34
|
+
const getSqliteWasmClient = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
35
|
+
if (sqliteWasmClient) {
|
|
36
|
+
return sqliteWasmClient;
|
|
37
|
+
}
|
|
38
|
+
if (typeof window === 'undefined') {
|
|
39
|
+
throw new Error('validateInput called from non-browser context');
|
|
40
|
+
}
|
|
41
|
+
if (isPreparing) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
isPreparing = true;
|
|
45
|
+
if (!sqlite3InitModule) {
|
|
46
|
+
sqlite3InitModule = yield import('@sqlite.org/sqlite-wasm');
|
|
47
|
+
}
|
|
48
|
+
if (!window.sqlite3Worker1Promiser) {
|
|
49
|
+
yield sqlite3InitModule();
|
|
50
|
+
}
|
|
51
|
+
if (!window.sqlite3Worker1Promiser) {
|
|
52
|
+
console.error('window.sqlite3Worker1Promiser not found');
|
|
53
|
+
isPreparing = false;
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
try {
|
|
57
|
+
sqliteWasmClient = yield window.sqlite3Worker1Promiser.v2().catch((err) => {
|
|
58
|
+
console.error('Error initializing sqliteWasmClient:', err);
|
|
59
|
+
isPreparing = false;
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
console.error('Error initializing sqliteWasmClient:', err);
|
|
64
|
+
isPreparing = false;
|
|
65
|
+
}
|
|
66
|
+
return sqliteWasmClient;
|
|
67
|
+
});
|
|
68
|
+
let appDb;
|
|
69
|
+
const setAppDb = (db) => {
|
|
70
|
+
appDb = db;
|
|
71
|
+
};
|
|
72
|
+
const getAppDb = () => {
|
|
73
|
+
if (!appDb) {
|
|
74
|
+
throw new Error('getAppDb: appDb is undefined');
|
|
75
|
+
}
|
|
76
|
+
return appDb;
|
|
77
|
+
};
|
|
78
|
+
const isAppDbReady = () => {
|
|
79
|
+
return !!appDb;
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
class SqliteConnectionManager {
|
|
83
|
+
constructor(sqliteModule, idleTimeout = 300000) {
|
|
84
|
+
// Default idle timeout: 5 minutes
|
|
85
|
+
this.sqliteModule = sqliteModule;
|
|
86
|
+
this.idleTimeout = idleTimeout;
|
|
87
|
+
this.databases = {};
|
|
88
|
+
this.idleTimers = {};
|
|
89
|
+
}
|
|
90
|
+
resetIdleTimer(dbName) {
|
|
91
|
+
if (this.idleTimers[dbName]) {
|
|
92
|
+
clearTimeout(this.idleTimers[dbName]);
|
|
93
|
+
}
|
|
94
|
+
this.idleTimers[dbName] = setTimeout(() => {
|
|
95
|
+
this.closeConnection(dbName);
|
|
96
|
+
}, this.idleTimeout);
|
|
97
|
+
}
|
|
98
|
+
getConnection(dbName) {
|
|
99
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
100
|
+
if (this.databases[dbName]) {
|
|
101
|
+
this.resetIdleTimer(dbName);
|
|
102
|
+
return this.databases[dbName];
|
|
103
|
+
}
|
|
104
|
+
const db = new this.sqliteModule();
|
|
105
|
+
yield db.open(dbName);
|
|
106
|
+
this.databases[dbName] = db;
|
|
107
|
+
this.resetIdleTimer(dbName);
|
|
108
|
+
return db;
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
execute(dbName_1, sql_1) {
|
|
112
|
+
return __awaiter(this, arguments, void 0, function* (dbName, sql, params = []) {
|
|
113
|
+
const db = yield this.getConnection(dbName);
|
|
114
|
+
const result = db.exec(sql, params);
|
|
115
|
+
this.resetIdleTimer(dbName);
|
|
116
|
+
return result;
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
closeConnection(dbName) {
|
|
120
|
+
if (this.databases[dbName]) {
|
|
121
|
+
this.databases[dbName].close();
|
|
122
|
+
delete this.databases[dbName];
|
|
123
|
+
if (this.idleTimers[dbName]) {
|
|
124
|
+
clearTimeout(this.idleTimers[dbName]);
|
|
125
|
+
delete this.idleTimers[dbName];
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
const logger = debug('app:browser:db:Db');
|
|
132
|
+
const dbExec = (dbId_1, params_1, sql_1, dbName_1, ...args_1) => __awaiter(void 0, [dbId_1, params_1, sql_1, dbName_1, ...args_1], void 0, function* (dbId, params, sql, dbName, retries = 2) {
|
|
133
|
+
const rowsToReturnRaw = [];
|
|
134
|
+
const sqliteWasmClient = yield getSqliteWasmClient();
|
|
135
|
+
// For a single exec command, the callback potentially gets called several times -- once for each row.
|
|
136
|
+
// So we need to collect all rows into a final array to return (execResult).
|
|
137
|
+
const rowsToReturn = yield new Promise((resolve, reject) => {
|
|
138
|
+
sqliteWasmClient('exec', {
|
|
139
|
+
dbId,
|
|
140
|
+
sql,
|
|
141
|
+
bind: params,
|
|
142
|
+
callback: (result) => {
|
|
143
|
+
// Checks if this is the final callback of the query
|
|
144
|
+
if (!result || !result.row || !result.rowNumber) {
|
|
145
|
+
const returnResult = [];
|
|
146
|
+
// Before returning the array, we process it to match the expected output format
|
|
147
|
+
// const rowsToReturnProcessed = rowsToReturnRaw.reduce((acc, curr) => {
|
|
148
|
+
// if (
|
|
149
|
+
// Array.isArray(curr.row) &&
|
|
150
|
+
// curr.row?.length > 0 &&
|
|
151
|
+
// curr.columnNames.length > 0
|
|
152
|
+
// ) {
|
|
153
|
+
// const returnObj: ReturnObj = {
|
|
154
|
+
// database: dbName,
|
|
155
|
+
// }
|
|
156
|
+
//
|
|
157
|
+
// const values = []
|
|
158
|
+
//
|
|
159
|
+
// curr.columnNames.forEach((colName, index: number) => {
|
|
160
|
+
// if (curr.row && curr.row[index]) {
|
|
161
|
+
// returnObj[colName] = curr.row[index]
|
|
162
|
+
// values.push(curr.row[index])
|
|
163
|
+
// }
|
|
164
|
+
// })
|
|
165
|
+
// // rowsValueStrings.push(`(${values.join(', ')})`)
|
|
166
|
+
// acc.push(returnObj)
|
|
167
|
+
// }
|
|
168
|
+
// return acc
|
|
169
|
+
// }, [] as string[])
|
|
170
|
+
for (const currRow of rowsToReturnRaw) {
|
|
171
|
+
// const values: string[] = []
|
|
172
|
+
// currRow.columnNames.forEach((colName, index: number) => {
|
|
173
|
+
// if (currRow.row) {
|
|
174
|
+
// values.push(currRow.row[index])
|
|
175
|
+
// }
|
|
176
|
+
// })
|
|
177
|
+
// logger(`[db/actors] [dbExec] currRow`, currRow)
|
|
178
|
+
returnResult.push(currRow.row);
|
|
179
|
+
}
|
|
180
|
+
resolve(returnResult);
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
// If not the final response, add this row to the return array
|
|
184
|
+
rowsToReturnRaw.push(result);
|
|
185
|
+
}
|
|
186
|
+
},
|
|
187
|
+
}).catch((error) => __awaiter(void 0, void 0, void 0, function* () {
|
|
188
|
+
reject(error);
|
|
189
|
+
}));
|
|
190
|
+
});
|
|
191
|
+
// logger(`[db/actors] [dbExec] rowsToReturn`, rowsToReturn)
|
|
192
|
+
// logger(`[db/actors] [dbExec] rowsValues`, rowsValues)
|
|
193
|
+
return rowsToReturn || [];
|
|
194
|
+
});
|
|
195
|
+
class Db extends BaseDb {
|
|
196
|
+
constructor() {
|
|
197
|
+
super();
|
|
198
|
+
}
|
|
199
|
+
static getAppDb() {
|
|
200
|
+
return getAppDb();
|
|
201
|
+
}
|
|
202
|
+
static isAppDbReady() {
|
|
203
|
+
return isAppDbReady();
|
|
204
|
+
}
|
|
205
|
+
static prepareDb(filesDir) {
|
|
206
|
+
return new Promise((resolve, reject) => {
|
|
207
|
+
const interval = setInterval(() => {
|
|
208
|
+
// TODO: Add a timeout
|
|
209
|
+
// TODO: Add a cancel token to the promise so we can prevent more loops starting while we're checking the successful outcome
|
|
210
|
+
getSqliteWasmClient().then((sqliteWasmClient) => {
|
|
211
|
+
if (sqliteWasmClient) {
|
|
212
|
+
clearInterval(interval);
|
|
213
|
+
const manager = new SqliteConnectionManager(sqliteWasmClient);
|
|
214
|
+
resolve(manager);
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
}, 200);
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
static connectToDb(pathToDir, dbName) {
|
|
221
|
+
return new Promise((resolve, reject) => {
|
|
222
|
+
const interval = setInterval(() => {
|
|
223
|
+
// TODO: Add a timeout
|
|
224
|
+
// TODO: Add a cancel token to the promise so we can prevent more loops starting while we're checking the successful outcome
|
|
225
|
+
getSqliteWasmClient().then((sqliteWasmClient) => {
|
|
226
|
+
if (!sqliteWasmClient) {
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
//@ts-ignore
|
|
230
|
+
sqliteWasmClient('config-get', {}).then((response) => {
|
|
231
|
+
logger(response);
|
|
232
|
+
logger('Running SQLite3 version', response.result.version.libVersion);
|
|
233
|
+
//@ts-ignore
|
|
234
|
+
sqliteWasmClient('open', {
|
|
235
|
+
filename: `file:${pathToDir}/db/${dbName}.sqlite3?vfs=opfs`,
|
|
236
|
+
}).then((response) => {
|
|
237
|
+
logger(response);
|
|
238
|
+
const dbId = response.dbId;
|
|
239
|
+
logger('OPFS is available, created persisted database at', response.result.filename.replace(/^file:(.*?)\?vfs=opfs$/, '$1'));
|
|
240
|
+
if (dbId) {
|
|
241
|
+
clearInterval(interval);
|
|
242
|
+
resolve(dbId);
|
|
243
|
+
}
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
});
|
|
247
|
+
}, 500);
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
static migrate(pathToDbDir, dbName, dbId) {
|
|
251
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
252
|
+
const schemaGlobString = `${BROWSER_FS_TOP_DIR}/schema/*`;
|
|
253
|
+
const drizzleDb = drizzle((sql, params, method) => __awaiter(this, void 0, void 0, function* () {
|
|
254
|
+
try {
|
|
255
|
+
// logger(
|
|
256
|
+
// `executing sql on ${dbName} with id: ${dbId} and method: ${method}`,
|
|
257
|
+
// sql,
|
|
258
|
+
// )
|
|
259
|
+
const finalResult = yield dbExec(dbId, params, sql, dbName);
|
|
260
|
+
// logger(`finalResult with method: ${method}`, finalResult)
|
|
261
|
+
// Drizzle always waits for {rows: string[][]} or {rows: string[]} for the return value.
|
|
262
|
+
// When the method is get, you should return a value as {rows: string[]}.
|
|
263
|
+
// Otherwise, you should return {rows: string[][]}.
|
|
264
|
+
return { rows: finalResult };
|
|
265
|
+
}
|
|
266
|
+
catch (e) {
|
|
267
|
+
console.error('Error from sqlite proxy server: ', JSON.stringify(e));
|
|
268
|
+
return { rows: [] };
|
|
269
|
+
}
|
|
270
|
+
}), {
|
|
271
|
+
schema: schemaGlobString,
|
|
272
|
+
// logger: true,
|
|
273
|
+
});
|
|
274
|
+
try {
|
|
275
|
+
const migrations = readMigrationFiles({
|
|
276
|
+
migrationsFolder: pathToDbDir,
|
|
277
|
+
});
|
|
278
|
+
if (migrations.length > 0) {
|
|
279
|
+
const incomingMigrationHashes = migrations.map((migration) => migration.hash);
|
|
280
|
+
let existingMigrationHashes;
|
|
281
|
+
let rows = [];
|
|
282
|
+
try {
|
|
283
|
+
const query = yield drizzleDb.run(sql.raw(`SELECT hash, created_at
|
|
284
|
+
FROM main.__drizzle_migrations;`));
|
|
285
|
+
rows = query.rows;
|
|
286
|
+
}
|
|
287
|
+
catch (e) {
|
|
288
|
+
rows = [];
|
|
289
|
+
}
|
|
290
|
+
if (rows && rows.length > 0) {
|
|
291
|
+
existingMigrationHashes = rows.map((row) => row[0]);
|
|
292
|
+
}
|
|
293
|
+
if (existingMigrationHashes) {
|
|
294
|
+
let shouldRebuildDb = false;
|
|
295
|
+
for (const existingHash of existingMigrationHashes) {
|
|
296
|
+
if (!incomingMigrationHashes.includes(existingHash)) {
|
|
297
|
+
shouldRebuildDb = true;
|
|
298
|
+
break;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
if (shouldRebuildDb) {
|
|
302
|
+
yield fs.promises.unlink(`${pathToDbDir}/${dbName}.sqlite3`);
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
yield migrate(drizzleDb, (queriesToRun) => __awaiter(this, void 0, void 0, function* () {
|
|
307
|
+
// logger('queriesToRun', queriesToRun)
|
|
308
|
+
for (const query of queriesToRun) {
|
|
309
|
+
// logger('query', query)
|
|
310
|
+
yield drizzleDb.run(sql.raw(query));
|
|
311
|
+
}
|
|
312
|
+
}), {
|
|
313
|
+
migrationsFolder: pathToDbDir,
|
|
314
|
+
});
|
|
315
|
+
}
|
|
316
|
+
catch (error) {
|
|
317
|
+
// console.error('Error migrating database: ', error)
|
|
318
|
+
// window.location.reload()
|
|
319
|
+
// const handle = await navigator.storage.getDirectory()
|
|
320
|
+
//
|
|
321
|
+
// await configureSingle({
|
|
322
|
+
// backend: WebAccess,
|
|
323
|
+
// handle,
|
|
324
|
+
// })
|
|
325
|
+
yield waitForFile(`${pathToDbDir}/meta/_journal.json`);
|
|
326
|
+
yield this.migrate(pathToDbDir, dbName);
|
|
327
|
+
}
|
|
328
|
+
setAppDb(drizzleDb);
|
|
329
|
+
// const createTempTableQuery = await appDb.run(
|
|
330
|
+
// sql.raw(
|
|
331
|
+
// `CREATE TEMP TABLE IF NOT EXISTS temp_last_inserted_id (id INTEGER, table TEXT);`,
|
|
332
|
+
// ),
|
|
333
|
+
// )
|
|
334
|
+
//
|
|
335
|
+
// logger(
|
|
336
|
+
// '[db/actors] [migrate] createTempTableQuery',
|
|
337
|
+
// createTempTableQuery,
|
|
338
|
+
// )
|
|
339
|
+
// const triggersQuery = await appDb.run(
|
|
340
|
+
// sql.raw(
|
|
341
|
+
// `SELECT name
|
|
342
|
+
// FROM main.sqlite_master
|
|
343
|
+
// WHERE type = 'trigger';`,
|
|
344
|
+
// ),
|
|
345
|
+
// )
|
|
346
|
+
//
|
|
347
|
+
// logger('[db/actors] [migrate] triggersQuery', triggersQuery)
|
|
348
|
+
//
|
|
349
|
+
// const triggers = triggersQuery.rows.map((row) => row[0])
|
|
350
|
+
//
|
|
351
|
+
// const tablesQuery = await appDb.run(
|
|
352
|
+
// sql.raw(
|
|
353
|
+
// `SELECT name
|
|
354
|
+
// FROM main.sqlite_master
|
|
355
|
+
// WHERE type = 'table';`,
|
|
356
|
+
// ),
|
|
357
|
+
// )
|
|
358
|
+
//
|
|
359
|
+
// logger('[db/actors] [migrate] tablesQuery', tablesQuery)
|
|
360
|
+
//
|
|
361
|
+
// const tableNames = tablesQuery.rows.map((row) => row[0])
|
|
362
|
+
// logger('[db/actors] [migrate] tableNames', tableNames)
|
|
363
|
+
// for (const tableName of tableNames) {
|
|
364
|
+
// const triggerName = `after_insert_${tableName}`
|
|
365
|
+
// if (triggers.includes(triggerName)) {
|
|
366
|
+
// continue
|
|
367
|
+
// }
|
|
368
|
+
// const createTriggerQuery = await appDb.run(
|
|
369
|
+
// sql.raw(
|
|
370
|
+
// `CREATE TRIGGER after_insert_${tableName}
|
|
371
|
+
// AFTER INSERT ON ${tableName}
|
|
372
|
+
// BEGIN
|
|
373
|
+
// DELETE FROM temp_last_inserted_id;
|
|
374
|
+
// INSERT INTO temp_last_inserted_id (id) VALUES (new.id);
|
|
375
|
+
// END;`,
|
|
376
|
+
// ),
|
|
377
|
+
// )
|
|
378
|
+
//
|
|
379
|
+
// logger(
|
|
380
|
+
// '[db/actors] [migrate] createTriggerQuery',
|
|
381
|
+
// createTriggerQuery,
|
|
382
|
+
// )
|
|
383
|
+
// }
|
|
384
|
+
});
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
BaseDb.setPlatformClass(Db);
|
|
388
|
+
|
|
389
|
+
export { Db, dbExec };
|
|
390
|
+
//# sourceMappingURL=Db-DJQELGcv.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Db-DJQELGcv.js","sources":["../../src/browser/db/sqlWasmClient.ts","../../src/services/db/connectionManager.ts","../../src/browser/db/Db.ts"],"sourcesContent":["import { SqliteConnectionManager } from '@/services/db'\nimport {\n SqliteRemoteDatabase,\n SqliteRemoteResult,\n} from 'drizzle-orm/sqlite-proxy'\nimport { sql } from 'drizzle-orm'\n\nlet sqlite3InitModule: any\nlet sqliteWasmClient: any\nlet manager: SqliteConnectionManager | undefined\nlet isPreparing = false\n\nexport const setSqliteWasmClient = (client: any) => {\n sqliteWasmClient = client\n}\n\nexport const getSqliteWasmClient = async () => {\n if (sqliteWasmClient) {\n return sqliteWasmClient\n }\n if (typeof window === 'undefined') {\n throw new Error('validateInput called from non-browser context')\n }\n\n if (isPreparing) {\n return\n }\n\n isPreparing = true\n\n if (!sqlite3InitModule) {\n sqlite3InitModule = await import('@sqlite.org/sqlite-wasm')\n }\n\n if (!window.sqlite3Worker1Promiser) {\n await sqlite3InitModule()\n }\n\n if (!window.sqlite3Worker1Promiser) {\n console.error('window.sqlite3Worker1Promiser not found')\n isPreparing = false\n return\n }\n\n try {\n sqliteWasmClient = await window.sqlite3Worker1Promiser.v2().catch((err) => {\n console.error('Error initializing sqliteWasmClient:', err)\n isPreparing = false\n })\n } catch (err) {\n console.error('Error initializing sqliteWasmClient:', err)\n isPreparing = false\n }\n return sqliteWasmClient\n}\n\nexport const getManager = () => {\n return manager\n}\n\nexport const setManager = (m: any) => {\n manager = m\n}\nlet appDb: SqliteRemoteDatabase<Record<string, unknown>> | undefined\nexport const setAppDb = (db: SqliteRemoteDatabase<Record<string, unknown>>) => {\n appDb = db\n}\nexport const getAppDb = () => {\n if (!appDb) {\n throw new Error('getAppDb: appDb is undefined')\n }\n\n return appDb\n}\nexport const isAppDbReady = () => {\n return !!appDb\n}\ntype RunQueryForStatement = (\n statement: string,\n) => Promise<SqliteRemoteResult<unknown>>\n\nexport const runQueryForStatement: RunQueryForStatement = async (\n statement: string,\n) => {\n const appDb = getAppDb()\n\n return appDb.run(sql.raw(statement))\n}\n","type SqliteDatabase = {\n open: (filename: string) => Promise<void>\n exec: (sql: string, params?: any[]) => any\n close: () => void\n}\n\nclass SqliteConnectionManager {\n private sqliteModule: SqliteDatabase\n private idleTimeout: number\n private databases: { [key: string]: SqliteDatabase }\n private idleTimers: { [key: string]: NodeJS.Timeout }\n\n constructor(sqliteModule: SqliteDatabase, idleTimeout: number = 300000) {\n // Default idle timeout: 5 minutes\n this.sqliteModule = sqliteModule\n this.idleTimeout = idleTimeout\n this.databases = {}\n this.idleTimers = {}\n }\n\n private resetIdleTimer(dbName: string): void {\n if (this.idleTimers[dbName]) {\n clearTimeout(this.idleTimers[dbName])\n }\n\n this.idleTimers[dbName] = setTimeout(() => {\n this.closeConnection(dbName)\n }, this.idleTimeout)\n }\n\n private async getConnection(dbName: string): Promise<SqliteDatabase> {\n if (this.databases[dbName]) {\n this.resetIdleTimer(dbName)\n return this.databases[dbName]\n }\n\n const db = new this.sqliteModule()\n await db.open(dbName)\n this.databases[dbName] = db\n this.resetIdleTimer(dbName)\n return db\n }\n\n public async execute(\n dbName: string,\n sql: string,\n params: any[] = [],\n ): Promise<any> {\n const db = await this.getConnection(dbName)\n const result = db.exec(sql, params)\n this.resetIdleTimer(dbName)\n return result\n }\n\n public closeConnection(dbName: string): void {\n if (this.databases[dbName]) {\n this.databases[dbName].close()\n delete this.databases[dbName]\n if (this.idleTimers[dbName]) {\n clearTimeout(this.idleTimers[dbName])\n delete this.idleTimers[dbName]\n }\n }\n }\n}\n\nexport { SqliteConnectionManager }\n","import { BaseDb } from \"@/db/Db/BaseDb\";\nimport { IDb } from \"@/interfaces/IDb\";\nimport { getAppDb, getSqliteWasmClient, isAppDbReady, setAppDb } from \"./sqlWasmClient\";\nimport { SqliteConnectionManager } from \"@/services/db\";\nimport debug from \"debug\";\nimport { waitForFile } from \"@/helpers/files\";\nimport fs from \"@zenfs/core\";\nimport { sql } from \"drizzle-orm\";\nimport { readMigrationFiles } from \"drizzle-orm/migrator\";\nimport { drizzle } from \"drizzle-orm/sqlite-proxy\";\nimport { migrate as drizzleMigrate } from \"drizzle-orm/sqlite-proxy/migrator\";\nimport { BROWSER_FS_TOP_DIR } from \"@/services/internal/constants\";\nconst logger = debug('app:browser:db:Db')\n\nexport const dbExec = async (dbId, params, sql, dbName, retries = 2) => {\n const rowsToReturnRaw: SqliteWasmResult[] = []\n const rowsValues: string[][] = []\n\n const sqliteWasmClient = await getSqliteWasmClient()\n\n // For a single exec command, the callback potentially gets called several times -- once for each row.\n // So we need to collect all rows into a final array to return (execResult).\n const rowsToReturn = await new Promise((resolve, reject) => {\n sqliteWasmClient('exec', {\n dbId,\n sql,\n bind: params,\n callback: (result) => {\n // Checks if this is the final callback of the query\n if (!result || !result.row || !result.rowNumber) {\n const returnResult = []\n // Before returning the array, we process it to match the expected output format\n // const rowsToReturnProcessed = rowsToReturnRaw.reduce((acc, curr) => {\n // if (\n // Array.isArray(curr.row) &&\n // curr.row?.length > 0 &&\n // curr.columnNames.length > 0\n // ) {\n // const returnObj: ReturnObj = {\n // database: dbName,\n // }\n //\n // const values = []\n //\n // curr.columnNames.forEach((colName, index: number) => {\n // if (curr.row && curr.row[index]) {\n // returnObj[colName] = curr.row[index]\n // values.push(curr.row[index])\n // }\n // })\n // // rowsValueStrings.push(`(${values.join(', ')})`)\n // acc.push(returnObj)\n // }\n // return acc\n // }, [] as string[])\n for (const currRow of rowsToReturnRaw) {\n // const values: string[] = []\n // currRow.columnNames.forEach((colName, index: number) => {\n // if (currRow.row) {\n // values.push(currRow.row[index])\n // }\n // })\n // logger(`[db/actors] [dbExec] currRow`, currRow)\n returnResult.push(currRow.row)\n }\n resolve(returnResult)\n } else {\n // If not the final response, add this row to the return array\n rowsToReturnRaw.push(result)\n }\n },\n }).catch(async (error) => {\n reject(error)\n })\n })\n\n // logger(`[db/actors] [dbExec] rowsToReturn`, rowsToReturn)\n // logger(`[db/actors] [dbExec] rowsValues`, rowsValues)\n\n return rowsToReturn || []\n}\n\nclass Db extends BaseDb implements IDb {\n constructor() {\n super()\n }\n\n static getAppDb() {\n return getAppDb()\n }\n\n static isAppDbReady() {\n return isAppDbReady()\n }\n\n static prepareDb(filesDir: string) {\n\n return new Promise((resolve, reject) => {\n let sqliteWasmClient\n const interval = setInterval(() => {\n // TODO: Add a timeout\n // TODO: Add a cancel token to the promise so we can prevent more loops starting while we're checking the successful outcome\n getSqliteWasmClient().then((sqliteWasmClient) => {\n\n if (sqliteWasmClient) {\n clearInterval(interval)\n const manager = new SqliteConnectionManager(sqliteWasmClient)\n resolve(manager)\n }\n })\n\n }, 200)\n })\n }\n\n static connectToDb(pathToDir: string, dbName: string) {\n\n return new Promise((resolve, reject) => {\n const interval = setInterval(() => {\n\n // TODO: Add a timeout\n // TODO: Add a cancel token to the promise so we can prevent more loops starting while we're checking the successful outcome\n getSqliteWasmClient().then((sqliteWasmClient) => {\n\n if (!sqliteWasmClient) {\n return\n }\n\n //@ts-ignore\n sqliteWasmClient('config-get', {}).then((response) => {\n logger(response)\n logger('Running SQLite3 version', response.result.version.libVersion)\n\n //@ts-ignore\n sqliteWasmClient('open', {\n filename: `file:${pathToDir}/db/${dbName}.sqlite3?vfs=opfs`,\n }).then((response: { dbId: string, result: { filename: string } }) => {\n\n logger(response)\n const dbId = response.dbId\n logger(\n 'OPFS is available, created persisted database at',\n response.result.filename.replace(/^file:(.*?)\\?vfs=opfs$/, '$1'),\n )\n\n if (dbId) {\n clearInterval(interval)\n resolve(dbId)\n }\n })\n })\n })\n }, 500)\n })\n }\n\n static async migrate(pathToDbDir: string, dbName: string, dbId: string): Promise<void> {\n\n const schemaGlobString = `${BROWSER_FS_TOP_DIR}/schema/*`\n\n const drizzleDb = drizzle(\n async (sql, params, method) => {\n try {\n // logger(\n // `executing sql on ${dbName} with id: ${dbId} and method: ${method}`,\n // sql,\n // )\n\n const finalResult = await dbExec(dbId, params, sql, dbName)\n\n // logger(`finalResult with method: ${method}`, finalResult)\n // Drizzle always waits for {rows: string[][]} or {rows: string[]} for the return value.\n\n // When the method is get, you should return a value as {rows: string[]}.\n // Otherwise, you should return {rows: string[][]}.\n\n return { rows: finalResult }\n } catch (e: any) {\n console.error('Error from sqlite proxy server: ', JSON.stringify(e))\n return { rows: [] }\n }\n },\n {\n schema: schemaGlobString,\n // logger: true,\n },\n )\n\n try {\n const migrations = readMigrationFiles({\n migrationsFolder: pathToDbDir,\n })\n\n if (migrations.length > 0) {\n const incomingMigrationHashes = migrations.map(\n (migration) => migration.hash,\n )\n\n let existingMigrationHashes\n let rows = []\n\n try {\n const query = await drizzleDb.run(\n sql.raw(\n `SELECT hash, created_at\n FROM main.__drizzle_migrations;`,\n ),\n )\n\n rows = query.rows\n } catch (e) {\n rows = []\n }\n\n if (rows && rows.length > 0) {\n existingMigrationHashes = rows.map((row) => row[0])\n }\n\n if (existingMigrationHashes) {\n let shouldRebuildDb = false\n for (const existingHash of existingMigrationHashes) {\n if (!incomingMigrationHashes.includes(existingHash)) {\n shouldRebuildDb = true\n break\n }\n }\n if (shouldRebuildDb) {\n await fs.promises.unlink(`${pathToDbDir}/${dbName}.sqlite3`)\n }\n }\n }\n\n await drizzleMigrate(\n drizzleDb,\n async (queriesToRun) => {\n // logger('queriesToRun', queriesToRun)\n for (const query of queriesToRun) {\n // logger('query', query)\n await drizzleDb.run(sql.raw(query))\n }\n },\n {\n migrationsFolder: pathToDbDir,\n },\n )\n } catch (error) {\n // console.error('Error migrating database: ', error)\n // window.location.reload()\n // const handle = await navigator.storage.getDirectory()\n //\n // await configureSingle({\n // backend: WebAccess,\n // handle,\n // })\n\n await waitForFile(`${pathToDbDir}/meta/_journal.json`)\n\n await this.migrate(pathToDbDir, dbName)\n\n }\n\n setAppDb(drizzleDb)\n // const createTempTableQuery = await appDb.run(\n // sql.raw(\n // `CREATE TEMP TABLE IF NOT EXISTS temp_last_inserted_id (id INTEGER, table TEXT);`,\n // ),\n // )\n //\n // logger(\n // '[db/actors] [migrate] createTempTableQuery',\n // createTempTableQuery,\n // )\n\n // const triggersQuery = await appDb.run(\n // sql.raw(\n // `SELECT name\n // FROM main.sqlite_master\n // WHERE type = 'trigger';`,\n // ),\n // )\n //\n // logger('[db/actors] [migrate] triggersQuery', triggersQuery)\n //\n // const triggers = triggersQuery.rows.map((row) => row[0])\n //\n // const tablesQuery = await appDb.run(\n // sql.raw(\n // `SELECT name\n // FROM main.sqlite_master\n // WHERE type = 'table';`,\n // ),\n // )\n //\n // logger('[db/actors] [migrate] tablesQuery', tablesQuery)\n //\n // const tableNames = tablesQuery.rows.map((row) => row[0])\n // logger('[db/actors] [migrate] tableNames', tableNames)\n // for (const tableName of tableNames) {\n // const triggerName = `after_insert_${tableName}`\n // if (triggers.includes(triggerName)) {\n // continue\n // }\n // const createTriggerQuery = await appDb.run(\n // sql.raw(\n // `CREATE TRIGGER after_insert_${tableName}\n // AFTER INSERT ON ${tableName}\n // BEGIN\n // DELETE FROM temp_last_inserted_id;\n // INSERT INTO temp_last_inserted_id (id) VALUES (new.id);\n // END;`,\n // ),\n // )\n //\n // logger(\n // '[db/actors] [migrate] createTriggerQuery',\n // createTriggerQuery,\n // )\n // }\n }\n}\n\nBaseDb.setPlatformClass(Db)\n\nexport { Db }"],"names":["drizzleMigrate"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,IAAI,iBAAsB;AAC1B,IAAI,gBAAqB;AAEzB,IAAI,WAAW,GAAG,KAAK;AAMhB,MAAM,mBAAmB,GAAG,MAAW,SAAA,CAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,aAAA;IAC5C,IAAI,gBAAgB,EAAE;AACpB,QAAA,OAAO,gBAAgB;;AAEzB,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AACjC,QAAA,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC;;IAGlE,IAAI,WAAW,EAAE;QACf;;IAGF,WAAW,GAAG,IAAI;IAElB,IAAI,CAAC,iBAAiB,EAAE;AACtB,QAAA,iBAAiB,GAAG,MAAM,OAAO,yBAAyB,CAAC;;AAG7D,IAAA,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE;QAClC,MAAM,iBAAiB,EAAE;;AAG3B,IAAA,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE;AAClC,QAAA,OAAO,CAAC,KAAK,CAAC,yCAAyC,CAAC;QACxD,WAAW,GAAG,KAAK;QACnB;;AAGF,IAAA,IAAI;AACF,QAAA,gBAAgB,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,KAAI;AACxE,YAAA,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,GAAG,CAAC;YAC1D,WAAW,GAAG,KAAK;AACrB,SAAC,CAAC;;IACF,OAAO,GAAG,EAAE;AACZ,QAAA,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,GAAG,CAAC;QAC1D,WAAW,GAAG,KAAK;;AAErB,IAAA,OAAO,gBAAgB;AACzB,CAAC,CAAA;AASD,IAAI,KAAgE;AAC7D,MAAM,QAAQ,GAAG,CAAC,EAAiD,KAAI;IAC5E,KAAK,GAAG,EAAE;AACZ,CAAC;AACM,MAAM,QAAQ,GAAG,MAAK;IAC3B,IAAI,CAAC,KAAK,EAAE;AACV,QAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC;;AAGjD,IAAA,OAAO,KAAK;AACd,CAAC;AACM,MAAM,YAAY,GAAG,MAAK;IAC/B,OAAO,CAAC,CAAC,KAAK;AAChB,CAAC;;ACtED,MAAM,uBAAuB,CAAA;IAM3B,WAAY,CAAA,YAA4B,EAAE,WAAA,GAAsB,MAAM,EAAA;;AAEpE,QAAA,IAAI,CAAC,YAAY,GAAG,YAAY;AAChC,QAAA,IAAI,CAAC,WAAW,GAAG,WAAW;AAC9B,QAAA,IAAI,CAAC,SAAS,GAAG,EAAE;AACnB,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE;;AAGd,IAAA,cAAc,CAAC,MAAc,EAAA;AACnC,QAAA,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YAC3B,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;;QAGvC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,UAAU,CAAC,MAAK;AACxC,YAAA,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC;AAC9B,SAAC,EAAE,IAAI,CAAC,WAAW,CAAC;;AAGR,IAAA,aAAa,CAAC,MAAc,EAAA;;AACxC,YAAA,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;AAC1B,gBAAA,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;AAC3B,gBAAA,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;;AAG/B,YAAA,MAAM,EAAE,GAAG,IAAI,IAAI,CAAC,YAAY,EAAE;AAClC,YAAA,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;AACrB,YAAA,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,EAAE;AAC3B,YAAA,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;AAC3B,YAAA,OAAO,EAAE;SACV,CAAA;AAAA;IAEY,OAAO,CAAA,QAAA,EAAA,KAAA,EAAA;AAClB,QAAA,OAAA,SAAA,CAAA,IAAA,EAAA,SAAA,EAAA,KAAA,CAAA,EAAA,WAAA,MAAc,EACd,GAAW,EACX,MAAA,GAAgB,EAAE,EAAA;YAElB,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YAC3C,MAAM,MAAM,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC;AACnC,YAAA,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;AAC3B,YAAA,OAAO,MAAM;SACd,CAAA;AAAA;AAEM,IAAA,eAAe,CAAC,MAAc,EAAA;AACnC,QAAA,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE;AAC9B,YAAA,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;AAC7B,YAAA,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;gBAC3B,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AACrC,gBAAA,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;;;;AAIrC;;ACpDD,MAAM,MAAM,GAAG,KAAK,CAAC,mBAAmB,CAAC;AAE5B,MAAA,MAAM,GAAG,CAAA,MAAA,EAAA,QAAA,EAAA,KAAA,EAAA,QAAA,EAAA,GAAA,MAAA,KAAO,SAAA,CAAA,KAAA,CAAA,EAAA,CAAA,MAAA,EAAA,QAAA,EAAA,KAAA,EAAA,QAAA,EAAA,GAAA,MAAA,CAAA,EAAA,KAAA,CAAA,EAAA,WAAA,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,GAAG,CAAC,EAAA;IACjE,MAAM,eAAe,GAAuB,EAAE;AAG9C,IAAA,MAAM,gBAAgB,GAAG,MAAM,mBAAmB,EAAE;;;IAIpD,MAAM,YAAY,GAAG,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,KAAI;QACzD,gBAAgB,CAAC,MAAM,EAAE;YACvB,IAAI;YACJ,GAAG;AACH,YAAA,IAAI,EAAE,MAAM;AACZ,YAAA,QAAQ,EAAE,CAAC,MAAM,KAAI;;AAEnB,gBAAA,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;oBAC/C,MAAM,YAAY,GAAG,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;AAyBvB,oBAAA,KAAK,MAAM,OAAO,IAAI,eAAe,EAAE;;;;;;;;AAQrC,wBAAA,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;;oBAEhC,OAAO,CAAC,YAAY,CAAC;;qBAChB;;AAEL,oBAAA,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC;;aAE/B;AACF,SAAA,CAAC,CAAC,KAAK,CAAC,CAAO,KAAK,KAAI,SAAA,CAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,aAAA;YACvB,MAAM,CAAC,KAAK,CAAC;SACd,CAAA,CAAC;AACJ,KAAC,CAAC;;;IAKF,OAAO,YAAY,IAAI,EAAE;AAC3B,CAAC;AAED,MAAM,EAAG,SAAQ,MAAM,CAAA;AACrB,IAAA,WAAA,GAAA;AACE,QAAA,KAAK,EAAE;;AAGT,IAAA,OAAO,QAAQ,GAAA;QACb,OAAO,QAAQ,EAAE;;AAGnB,IAAA,OAAO,YAAY,GAAA;QACjB,OAAO,YAAY,EAAE;;IAGvB,OAAO,SAAS,CAAC,QAAgB,EAAA;QAE/B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,KAAI;AAErC,YAAA,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAK;;;AAGhC,gBAAA,mBAAmB,EAAE,CAAC,IAAI,CAAC,CAAC,gBAAgB,KAAI;oBAE9C,IAAI,gBAAgB,EAAE;wBACpB,aAAa,CAAC,QAAQ,CAAC;AACvB,wBAAA,MAAM,OAAO,GAAG,IAAI,uBAAuB,CAAC,gBAAgB,CAAC;wBAC7D,OAAO,CAAC,OAAO,CAAC;;AAEpB,iBAAC,CAAC;aAEH,EAAE,GAAG,CAAC;AACT,SAAC,CAAC;;AAGJ,IAAA,OAAO,WAAW,CAAC,SAAiB,EAAE,MAAc,EAAA;QAElD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,KAAI;AACrC,YAAA,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAK;;;AAIhC,gBAAA,mBAAmB,EAAE,CAAC,IAAI,CAAC,CAAC,gBAAgB,KAAI;oBAE9C,IAAI,CAAC,gBAAgB,EAAE;wBACrB;;;oBAIF,gBAAgB,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAI;wBACnD,MAAM,CAAC,QAAQ,CAAC;wBAChB,MAAM,CAAC,yBAAyB,EAAE,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC;;wBAGrE,gBAAgB,CAAC,MAAM,EAAE;AACvB,4BAAA,QAAQ,EAAE,CAAA,KAAA,EAAQ,SAAS,CAAA,IAAA,EAAO,MAAM,CAAmB,iBAAA,CAAA;AAC5D,yBAAA,CAAC,CAAC,IAAI,CAAC,CAAC,QAAwD,KAAI;4BAEnE,MAAM,CAAC,QAAQ,CAAC;AAChB,4BAAA,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI;AAC1B,4BAAA,MAAM,CACJ,kDAAkD,EAClD,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,wBAAwB,EAAE,IAAI,CAAC,CACjE;4BAED,IAAI,IAAI,EAAE;gCACR,aAAa,CAAC,QAAQ,CAAC;gCACvB,OAAO,CAAC,IAAI,CAAC;;AAEjB,yBAAC,CAAC;AACJ,qBAAC,CAAC;AACJ,iBAAC,CAAC;aACH,EAAE,GAAG,CAAC;AACT,SAAC,CAAC;;AAGJ,IAAA,OAAa,OAAO,CAAC,WAAmB,EAAE,MAAc,EAAE,IAAY,EAAA;;AAEpE,YAAA,MAAM,gBAAgB,GAAG,CAAG,EAAA,kBAAkB,WAAW;YAEzD,MAAM,SAAS,GAAG,OAAO,CACvB,CAAO,GAAG,EAAE,MAAM,EAAE,MAAM,KAAI,SAAA,CAAA,IAAA,EAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,aAAA;AAC5B,gBAAA,IAAI;;;;;AAMF,oBAAA,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC;;;;;AAQ3D,oBAAA,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE;;gBAC5B,OAAO,CAAM,EAAE;AACf,oBAAA,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AACpE,oBAAA,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE;;AAEvB,aAAC,CAAA,EACD;AACE,gBAAA,MAAM,EAAE,gBAAgB;;AAEzB,aAAA,CACF;AAED,YAAA,IAAI;gBACF,MAAM,UAAU,GAAG,kBAAkB,CAAC;AACpC,oBAAA,gBAAgB,EAAE,WAAW;AAC9B,iBAAA,CAAC;AAEF,gBAAA,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;AACzB,oBAAA,MAAM,uBAAuB,GAAG,UAAU,CAAC,GAAG,CAC5C,CAAC,SAAS,KAAK,SAAS,CAAC,IAAI,CAC9B;AAED,oBAAA,IAAI,uBAAuB;oBAC3B,IAAI,IAAI,GAAG,EAAE;AAEb,oBAAA,IAAI;wBACF,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,GAAG,CAC/B,GAAG,CAAC,GAAG,CACL,CAAA;AACiC,8CAAA,CAAA,CAClC,CACF;AAED,wBAAA,IAAI,GAAG,KAAK,CAAC,IAAI;;oBACjB,OAAO,CAAC,EAAE;wBACV,IAAI,GAAG,EAAE;;oBAGX,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;AAC3B,wBAAA,uBAAuB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;;oBAGrD,IAAI,uBAAuB,EAAE;wBAC3B,IAAI,eAAe,GAAG,KAAK;AAC3B,wBAAA,KAAK,MAAM,YAAY,IAAI,uBAAuB,EAAE;4BAClD,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;gCACnD,eAAe,GAAG,IAAI;gCACtB;;;wBAGJ,IAAI,eAAe,EAAE;AACnB,4BAAA,MAAM,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAG,EAAA,WAAW,CAAI,CAAA,EAAA,MAAM,CAAU,QAAA,CAAA,CAAC;;;;AAKlE,gBAAA,MAAMA,OAAc,CAClB,SAAS,EACT,CAAO,YAAY,KAAI,SAAA,CAAA,IAAA,EAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,aAAA;;AAErB,oBAAA,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE;;wBAEhC,MAAM,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;;AAEvC,iBAAC,CAAA,EACD;AACE,oBAAA,gBAAgB,EAAE,WAAW;AAC9B,iBAAA,CACF;;YACD,OAAO,KAAK,EAAE;;;;;;;;;AAUd,gBAAA,MAAM,WAAW,CAAC,CAAA,EAAG,WAAW,CAAA,mBAAA,CAAqB,CAAC;gBAEtD,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM,CAAC;;YAIzC,QAAQ,CAAC,SAAS,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAyDpB,CAAA;AAAA;AACF;AAED,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC;;;;"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { a as BaseEasClient, E as EAS_ENDPOINT } from './constants-
|
|
1
|
+
import { a as BaseEasClient, E as EAS_ENDPOINT } from './constants-BakHTrB9.js';
|
|
2
2
|
import { GraphQLClient } from 'graphql-request';
|
|
3
3
|
import '@ethereum-attestation-service/eas-sdk';
|
|
4
4
|
|
|
@@ -10,4 +10,4 @@ class EasClient extends BaseEasClient {
|
|
|
10
10
|
BaseEasClient.setPlatformClass(EasClient);
|
|
11
11
|
|
|
12
12
|
export { EasClient };
|
|
13
|
-
//# sourceMappingURL=EasClient-
|
|
13
|
+
//# sourceMappingURL=EasClient-BNwSwDTO.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EasClient-
|
|
1
|
+
{"version":3,"file":"EasClient-BNwSwDTO.js","sources":["../../src/browser/helpers/EasClient.ts"],"sourcesContent":["import { BaseEasClient } from '../../helpers/EasClient/BaseEasClient'\nimport { GraphQLClient } from 'graphql-request'\nimport { EAS_ENDPOINT } from '@/services/internal/constants'\n\nclass EasClient extends BaseEasClient {\n static getEasClient(): GraphQLClient {\n return new GraphQLClient(EAS_ENDPOINT)\n }\n}\n\nBaseEasClient.setPlatformClass(EasClient)\n\nexport { EasClient }"],"names":[],"mappings":";;;;AAIA,MAAM,SAAU,SAAQ,aAAa,CAAA;AACnC,IAAA,OAAO,YAAY,GAAA;AACjB,QAAA,OAAO,IAAI,aAAa,CAAC,YAAY,CAAC;;AAEzC;AAED,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAAC;;;;"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { a as BaseEasClient, E as EAS_ENDPOINT } from './constants-
|
|
1
|
+
import { a as BaseEasClient, E as EAS_ENDPOINT } from './constants-BakHTrB9.js';
|
|
2
2
|
import { GraphQLClient } from 'graphql-request';
|
|
3
3
|
import '@ethereum-attestation-service/eas-sdk';
|
|
4
4
|
|
|
@@ -10,4 +10,4 @@ class EasClient extends BaseEasClient {
|
|
|
10
10
|
BaseEasClient.setPlatformClass(EasClient);
|
|
11
11
|
|
|
12
12
|
export { EasClient };
|
|
13
|
-
//# sourceMappingURL=EasClient-
|
|
13
|
+
//# sourceMappingURL=EasClient-epqE9aWI.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EasClient-
|
|
1
|
+
{"version":3,"file":"EasClient-epqE9aWI.js","sources":["../../src/node/helpers/EasClient.ts"],"sourcesContent":["import { BaseEasClient } from \"@/helpers/EasClient/BaseEasClient\"\nimport { EAS_ENDPOINT } from \"@/services/internal/constants\"\nimport { GraphQLClient } from \"graphql-request\"\n\nclass EasClient extends BaseEasClient {\n static getEasClient() {\n return new GraphQLClient(EAS_ENDPOINT)\n }\n}\n\nBaseEasClient.setPlatformClass(EasClient)\n\nexport { EasClient }"],"names":[],"mappings":";;;;AAIA,MAAM,SAAU,SAAQ,aAAa,CAAA;AACnC,IAAA,OAAO,YAAY,GAAA;AACjB,QAAA,OAAO,IAAI,aAAa,CAAC,YAAY,CAAC;;AAEzC;AAED,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAAC;;;;"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { __awaiter } from 'tslib';
|
|
2
|
-
import
|
|
3
|
-
import { c as BaseFileManager } from './constants-
|
|
2
|
+
import * as fsAsync from 'fs/promises';
|
|
3
|
+
import { c as BaseFileManager } from './constants-BakHTrB9.js';
|
|
4
4
|
import '@ethereum-attestation-service/eas-sdk';
|
|
5
5
|
|
|
6
6
|
class FileManager extends BaseFileManager {
|
|
7
7
|
static readFileAsBuffer(filePath) {
|
|
8
8
|
return __awaiter(this, void 0, void 0, function* () {
|
|
9
|
-
return yield
|
|
9
|
+
return yield fsAsync.readFile(filePath);
|
|
10
10
|
});
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
13
|
BaseFileManager.setPlatformClass(FileManager);
|
|
14
14
|
|
|
15
15
|
export { FileManager };
|
|
16
|
-
//# sourceMappingURL=FileManager-
|
|
16
|
+
//# sourceMappingURL=FileManager-CXk83EW5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileManager-CXk83EW5.js","sources":["../../src/node/helpers/FileManager.ts"],"sourcesContent":["import * as fsAsync from 'fs/promises';\nimport { BaseFileManager } from '@/helpers/FileManager/BaseFileManager';\n\nclass FileManager extends BaseFileManager {\n static async readFileAsBuffer(filePath: string): Promise<Buffer> {\n return await fsAsync.readFile(filePath);\n }\n\n}\n\nBaseFileManager.setPlatformClass(FileManager);\n\nexport { FileManager }; "],"names":[],"mappings":";;;;;AAGA,MAAM,WAAY,SAAQ,eAAe,CAAA;IACvC,OAAa,gBAAgB,CAAC,QAAgB,EAAA;;AAC5C,YAAA,OAAO,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;SACxC,CAAA;AAAA;AAEF;AAED,eAAe,CAAC,gBAAgB,CAAC,WAAW,CAAC;;;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __awaiter } from 'tslib';
|
|
2
|
-
import { c as BaseFileManager } from './constants-
|
|
2
|
+
import { c as BaseFileManager } from './constants-BakHTrB9.js';
|
|
3
3
|
import { fs } from '@zenfs/core';
|
|
4
4
|
import '@ethereum-attestation-service/eas-sdk';
|
|
5
5
|
|
|
@@ -25,4 +25,4 @@ class FileManager extends BaseFileManager {
|
|
|
25
25
|
BaseFileManager.setPlatformClass(FileManager);
|
|
26
26
|
|
|
27
27
|
export { FileManager };
|
|
28
|
-
//# sourceMappingURL=FileManager-
|
|
28
|
+
//# sourceMappingURL=FileManager-DXi-X7r5.js.map
|