@frictionless-ts/database 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/LICENSE.md +9 -0
  2. package/README.md +3 -0
  3. package/build/adapters/base.d.ts +20 -0
  4. package/build/adapters/base.js +66 -0
  5. package/build/adapters/create.d.ts +5 -0
  6. package/build/adapters/create.js +17 -0
  7. package/build/adapters/mysql.d.ts +10 -0
  8. package/build/adapters/mysql.js +90 -0
  9. package/build/adapters/mysql.spec.d.ts +1 -0
  10. package/build/adapters/mysql.spec.js +170 -0
  11. package/build/adapters/postgresql.d.ts +10 -0
  12. package/build/adapters/postgresql.js +100 -0
  13. package/build/adapters/postgresql.spec.d.ts +1 -0
  14. package/build/adapters/postgresql.spec.js +170 -0
  15. package/build/adapters/sqlite.bun.d.ts +2 -0
  16. package/build/adapters/sqlite.bun.js +7 -0
  17. package/build/adapters/sqlite.d.ts +11 -0
  18. package/build/adapters/sqlite.js +57 -0
  19. package/build/adapters/sqlite.node.d.ts +2 -0
  20. package/build/adapters/sqlite.node.js +43 -0
  21. package/build/adapters/sqlite.spec.d.ts +1 -0
  22. package/build/adapters/sqlite.spec.js +252 -0
  23. package/build/field/Field.d.ts +3 -0
  24. package/build/field/Field.js +2 -0
  25. package/build/field/Type.d.ts +2 -0
  26. package/build/field/Type.js +2 -0
  27. package/build/field/index.d.ts +2 -0
  28. package/build/field/index.js +2 -0
  29. package/build/index.d.ts +6 -0
  30. package/build/index.js +7 -0
  31. package/build/package/index.d.ts +2 -0
  32. package/build/package/index.js +3 -0
  33. package/build/package/load.d.ts +7 -0
  34. package/build/package/load.js +30 -0
  35. package/build/package/save.d.ts +10 -0
  36. package/build/package/save.js +28 -0
  37. package/build/plugin.d.ts +15 -0
  38. package/build/plugin.js +54 -0
  39. package/build/plugin.spec.d.ts +1 -0
  40. package/build/plugin.spec.js +328 -0
  41. package/build/resource/Format.d.ts +1 -0
  42. package/build/resource/Format.js +2 -0
  43. package/build/resource/index.d.ts +1 -0
  44. package/build/resource/index.js +2 -0
  45. package/build/schema/Schema.d.ts +4 -0
  46. package/build/schema/Schema.js +2 -0
  47. package/build/schema/index.d.ts +2 -0
  48. package/build/schema/index.js +2 -0
  49. package/build/schema/infer.d.ts +4 -0
  50. package/build/schema/infer.js +24 -0
  51. package/build/schema/infer.spec.d.ts +1 -0
  52. package/build/schema/infer.spec.js +25 -0
  53. package/build/table/index.d.ts +2 -0
  54. package/build/table/index.js +3 -0
  55. package/build/table/load.d.ts +6 -0
  56. package/build/table/load.js +29 -0
  57. package/build/table/load.spec.d.ts +1 -0
  58. package/build/table/load.spec.js +24 -0
  59. package/build/table/save.d.ts +4 -0
  60. package/build/table/save.js +57 -0
  61. package/build/table/save.spec.d.ts +1 -0
  62. package/build/table/save.spec.js +20 -0
  63. package/package.json +45 -0
@@ -0,0 +1,328 @@
1
+ import * as pl from "nodejs-polars";
2
+ import { beforeEach, describe, expect, it, vi } from "vitest";
3
+ import * as packageModule from "./package/index.js";
4
+ import { DatabasePlugin } from "./plugin.js";
5
+ import * as schemaModule from "./schema/index.js";
6
+ import * as tableModule from "./table/index.js";
7
+ vi.mock("./package/index.ts", () => ({
8
+ loadPackageFromDatabase: vi.fn(),
9
+ savePackageToDatabase: vi.fn(),
10
+ }));
11
+ vi.mock("./table/index.ts", () => ({
12
+ loadDatabaseTable: vi.fn(),
13
+ saveDatabaseTable: vi.fn(),
14
+ }));
15
+ vi.mock("./schema/index.ts", () => ({
16
+ inferDatabaseSchema: vi.fn(),
17
+ }));
18
+ describe("DatabasePlugin", () => {
19
+ let plugin;
20
+ let mockLoadPackageFromDatabase;
21
+ let mockSavePackageToDatabase;
22
+ let mockLoadDatabaseTable;
23
+ let mockSaveDatabaseTable;
24
+ let mockInferDatabaseSchema;
25
+ beforeEach(() => {
26
+ plugin = new DatabasePlugin();
27
+ mockLoadPackageFromDatabase = vi.mocked(packageModule.loadPackageFromDatabase);
28
+ mockSavePackageToDatabase = vi.mocked(packageModule.savePackageToDatabase);
29
+ mockLoadDatabaseTable = vi.mocked(tableModule.loadDatabaseTable);
30
+ mockSaveDatabaseTable = vi.mocked(tableModule.saveDatabaseTable);
31
+ mockInferDatabaseSchema = vi.mocked(schemaModule.inferDatabaseSchema);
32
+ vi.clearAllMocks();
33
+ });
34
+ describe("loadPackage", () => {
35
+ it("should load package from postgresql database", async () => {
36
+ const mockPackage = {
37
+ name: "test-package",
38
+ resources: [{ name: "test", data: [] }],
39
+ };
40
+ mockLoadPackageFromDatabase.mockResolvedValue(mockPackage);
41
+ const result = await plugin.loadPackage("postgresql://localhost/testdb");
42
+ expect(mockLoadPackageFromDatabase).toHaveBeenCalledWith("postgresql://localhost/testdb", { format: "postgresql" });
43
+ expect(result).toEqual(mockPackage);
44
+ });
45
+ it("should load package from mysql database", async () => {
46
+ const mockPackage = {
47
+ name: "test-package",
48
+ resources: [{ name: "test", data: [] }],
49
+ };
50
+ mockLoadPackageFromDatabase.mockResolvedValue(mockPackage);
51
+ const result = await plugin.loadPackage("mysql://localhost/testdb");
52
+ expect(mockLoadPackageFromDatabase).toHaveBeenCalledWith("mysql://localhost/testdb", { format: "mysql" });
53
+ expect(result).toEqual(mockPackage);
54
+ });
55
+ it("should load package from sqlite database", async () => {
56
+ const mockPackage = {
57
+ name: "test-package",
58
+ resources: [{ name: "test", data: [] }],
59
+ };
60
+ mockLoadPackageFromDatabase.mockResolvedValue(mockPackage);
61
+ const result = await plugin.loadPackage("sqlite://test.db");
62
+ expect(mockLoadPackageFromDatabase).toHaveBeenCalledWith("sqlite://test.db", {
63
+ format: "sqlite",
64
+ });
65
+ expect(result).toEqual(mockPackage);
66
+ });
67
+ it("should return undefined for non-database sources", async () => {
68
+ const result = await plugin.loadPackage("test.csv");
69
+ expect(mockLoadPackageFromDatabase).not.toHaveBeenCalled();
70
+ expect(result).toBeUndefined();
71
+ });
72
+ it("should return undefined for http urls", async () => {
73
+ const result = await plugin.loadPackage("https://example.com/data");
74
+ expect(mockLoadPackageFromDatabase).not.toHaveBeenCalled();
75
+ expect(result).toBeUndefined();
76
+ });
77
+ });
78
+ describe("savePackage", () => {
79
+ it("should save package to postgresql database", async () => {
80
+ const mockPackage = {
81
+ name: "test-package",
82
+ resources: [{ name: "test", data: [] }],
83
+ };
84
+ mockSavePackageToDatabase.mockResolvedValue(undefined);
85
+ await plugin.savePackage(mockPackage, {
86
+ target: "postgresql://localhost/testdb",
87
+ });
88
+ expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {
89
+ target: "postgresql://localhost/testdb",
90
+ format: "postgresql",
91
+ });
92
+ });
93
+ it("should save package to mysql database", async () => {
94
+ const mockPackage = {
95
+ name: "test-package",
96
+ resources: [{ name: "test", data: [] }],
97
+ };
98
+ mockSavePackageToDatabase.mockResolvedValue(undefined);
99
+ await plugin.savePackage(mockPackage, {
100
+ target: "mysql://localhost/testdb",
101
+ });
102
+ expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {
103
+ target: "mysql://localhost/testdb",
104
+ format: "mysql",
105
+ });
106
+ });
107
+ it("should save package to sqlite database", async () => {
108
+ const mockPackage = {
109
+ name: "test-package",
110
+ resources: [{ name: "test", data: [] }],
111
+ };
112
+ mockSavePackageToDatabase.mockResolvedValue(undefined);
113
+ await plugin.savePackage(mockPackage, { target: "sqlite://test.db" });
114
+ expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {
115
+ target: "sqlite://test.db",
116
+ format: "sqlite",
117
+ });
118
+ });
119
+ it("should return undefined for non-database targets", async () => {
120
+ const mockPackage = {
121
+ name: "test-package",
122
+ resources: [{ name: "test", data: [] }],
123
+ };
124
+ const result = await plugin.savePackage(mockPackage, {
125
+ target: "test.csv",
126
+ });
127
+ expect(mockSavePackageToDatabase).not.toHaveBeenCalled();
128
+ expect(result).toBeUndefined();
129
+ });
130
+ it("should pass through plugins option", async () => {
131
+ const mockPackage = {
132
+ name: "test-package",
133
+ resources: [{ name: "test", data: [] }],
134
+ };
135
+ const mockPlugins = [];
136
+ mockSavePackageToDatabase.mockResolvedValue(undefined);
137
+ await plugin.savePackage(mockPackage, {
138
+ target: "sqlite://test.db",
139
+ plugins: mockPlugins,
140
+ });
141
+ expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {
142
+ target: "sqlite://test.db",
143
+ format: "sqlite",
144
+ plugins: mockPlugins,
145
+ });
146
+ });
147
+ });
148
+ describe("loadTable", () => {
149
+ it("should load table from postgresql resource", async () => {
150
+ const resource = {
151
+ path: "postgresql://localhost/testdb",
152
+ };
153
+ const mockTable = pl.DataFrame().lazy();
154
+ mockLoadDatabaseTable.mockResolvedValue(mockTable);
155
+ const result = await plugin.loadTable(resource);
156
+ expect(mockLoadDatabaseTable).toHaveBeenCalledWith({
157
+ ...resource,
158
+ format: "postgresql",
159
+ });
160
+ expect(result).toEqual(mockTable);
161
+ });
162
+ it("should load table from mysql resource", async () => {
163
+ const resource = {
164
+ path: "mysql://localhost/testdb",
165
+ };
166
+ const mockTable = pl.DataFrame().lazy();
167
+ mockLoadDatabaseTable.mockResolvedValue(mockTable);
168
+ const result = await plugin.loadTable(resource);
169
+ expect(mockLoadDatabaseTable).toHaveBeenCalledWith({
170
+ ...resource,
171
+ format: "mysql",
172
+ });
173
+ expect(result).toEqual(mockTable);
174
+ });
175
+ it("should load table from sqlite resource", async () => {
176
+ const resource = {
177
+ path: "sqlite://test.db",
178
+ };
179
+ const mockTable = pl.DataFrame().lazy();
180
+ mockLoadDatabaseTable.mockResolvedValue(mockTable);
181
+ const result = await plugin.loadTable(resource);
182
+ expect(mockLoadDatabaseTable).toHaveBeenCalledWith({
183
+ ...resource,
184
+ format: "sqlite",
185
+ });
186
+ expect(result).toEqual(mockTable);
187
+ });
188
+ it("should return undefined for non-database resources", async () => {
189
+ const resource = {
190
+ path: "test.csv",
191
+ };
192
+ const result = await plugin.loadTable(resource);
193
+ expect(mockLoadDatabaseTable).not.toHaveBeenCalled();
194
+ expect(result).toBeUndefined();
195
+ });
196
+ it("should handle explicit format specification", async () => {
197
+ const resource = {
198
+ path: "test.txt",
199
+ format: "sqlite",
200
+ };
201
+ const mockTable = pl.DataFrame().lazy();
202
+ mockLoadDatabaseTable.mockResolvedValue(mockTable);
203
+ const result = await plugin.loadTable(resource);
204
+ expect(mockLoadDatabaseTable).toHaveBeenCalledWith({
205
+ ...resource,
206
+ format: "sqlite",
207
+ });
208
+ expect(result).toEqual(mockTable);
209
+ });
210
+ });
211
+ describe("saveTable", () => {
212
+ it("should save table to postgresql database", async () => {
213
+ const table = pl.DataFrame().lazy();
214
+ const options = { path: "postgresql://localhost/testdb" };
215
+ mockSaveDatabaseTable.mockResolvedValue("postgresql://localhost/testdb");
216
+ const result = await plugin.saveTable(table, options);
217
+ expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {
218
+ ...options,
219
+ format: "postgresql",
220
+ });
221
+ expect(result).toBe("postgresql://localhost/testdb");
222
+ });
223
+ it("should save table to mysql database", async () => {
224
+ const table = pl.DataFrame().lazy();
225
+ const options = { path: "mysql://localhost/testdb" };
226
+ mockSaveDatabaseTable.mockResolvedValue("mysql://localhost/testdb");
227
+ const result = await plugin.saveTable(table, options);
228
+ expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {
229
+ ...options,
230
+ format: "mysql",
231
+ });
232
+ expect(result).toBe("mysql://localhost/testdb");
233
+ });
234
+ it("should save table to sqlite database", async () => {
235
+ const table = pl.DataFrame().lazy();
236
+ const options = { path: "sqlite://test.db" };
237
+ mockSaveDatabaseTable.mockResolvedValue("sqlite://test.db");
238
+ const result = await plugin.saveTable(table, options);
239
+ expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {
240
+ ...options,
241
+ format: "sqlite",
242
+ });
243
+ expect(result).toBe("sqlite://test.db");
244
+ });
245
+ it("should return undefined for non-database paths", async () => {
246
+ const table = pl.DataFrame().lazy();
247
+ const options = { path: "output.csv" };
248
+ const result = await plugin.saveTable(table, options);
249
+ expect(mockSaveDatabaseTable).not.toHaveBeenCalled();
250
+ expect(result).toBeUndefined();
251
+ });
252
+ it("should handle explicit format specification", async () => {
253
+ const table = pl.DataFrame().lazy();
254
+ const options = { path: "test.txt", format: "sqlite" };
255
+ mockSaveDatabaseTable.mockResolvedValue("test.txt");
256
+ const result = await plugin.saveTable(table, options);
257
+ expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {
258
+ ...options,
259
+ format: "sqlite",
260
+ });
261
+ expect(result).toBe("test.txt");
262
+ });
263
+ });
264
+ describe("inferSchema", () => {
265
+ it("should infer schema for postgresql resource", async () => {
266
+ const resource = {
267
+ path: "postgresql://localhost/testdb",
268
+ };
269
+ const mockSchema = { fields: [] };
270
+ mockInferDatabaseSchema.mockResolvedValue(mockSchema);
271
+ const result = await plugin.inferSchema(resource);
272
+ expect(mockInferDatabaseSchema).toHaveBeenCalledWith({
273
+ ...resource,
274
+ format: "postgresql",
275
+ });
276
+ expect(result).toEqual(mockSchema);
277
+ });
278
+ it("should infer schema for mysql resource", async () => {
279
+ const resource = {
280
+ path: "mysql://localhost/testdb",
281
+ };
282
+ const mockSchema = { fields: [] };
283
+ mockInferDatabaseSchema.mockResolvedValue(mockSchema);
284
+ const result = await plugin.inferSchema(resource);
285
+ expect(mockInferDatabaseSchema).toHaveBeenCalledWith({
286
+ ...resource,
287
+ format: "mysql",
288
+ });
289
+ expect(result).toEqual(mockSchema);
290
+ });
291
+ it("should infer schema for sqlite resource", async () => {
292
+ const resource = {
293
+ path: "sqlite://test.db",
294
+ };
295
+ const mockSchema = { fields: [] };
296
+ mockInferDatabaseSchema.mockResolvedValue(mockSchema);
297
+ const result = await plugin.inferSchema(resource);
298
+ expect(mockInferDatabaseSchema).toHaveBeenCalledWith({
299
+ ...resource,
300
+ format: "sqlite",
301
+ });
302
+ expect(result).toEqual(mockSchema);
303
+ });
304
+ it("should return undefined for non-database resources", async () => {
305
+ const resource = {
306
+ path: "test.csv",
307
+ };
308
+ const result = await plugin.inferSchema(resource);
309
+ expect(mockInferDatabaseSchema).not.toHaveBeenCalled();
310
+ expect(result).toBeUndefined();
311
+ });
312
+ it("should handle explicit format specification", async () => {
313
+ const resource = {
314
+ path: "test.txt",
315
+ format: "sqlite",
316
+ };
317
+ const mockSchema = { fields: [] };
318
+ mockInferDatabaseSchema.mockResolvedValue(mockSchema);
319
+ const result = await plugin.inferSchema(resource);
320
+ expect(mockInferDatabaseSchema).toHaveBeenCalledWith({
321
+ ...resource,
322
+ format: "sqlite",
323
+ });
324
+ expect(result).toEqual(mockSchema);
325
+ });
326
+ });
327
+ });
328
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin.spec.js","sourceRoot":"","sources":["../plugin.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Package, Resource } from \"@frictionless-ts/metadata\"\nimport * as pl from \"nodejs-polars\"\nimport { beforeEach, describe, expect, it, vi } from \"vitest\"\nimport * as packageModule from \"./package/index.ts\"\nimport { DatabasePlugin } from \"./plugin.ts\"\nimport * as schemaModule from \"./schema/index.ts\"\nimport * as tableModule from \"./table/index.ts\"\n\nvi.mock(\"./package/index.ts\", () => ({\n  loadPackageFromDatabase: vi.fn(),\n  savePackageToDatabase: vi.fn(),\n}))\n\nvi.mock(\"./table/index.ts\", () => ({\n  loadDatabaseTable: vi.fn(),\n  saveDatabaseTable: vi.fn(),\n}))\n\nvi.mock(\"./schema/index.ts\", () => ({\n  inferDatabaseSchema: vi.fn(),\n}))\n\ndescribe(\"DatabasePlugin\", () => {\n  let plugin: DatabasePlugin\n  let mockLoadPackageFromDatabase: ReturnType<typeof vi.fn>\n  let mockSavePackageToDatabase: ReturnType<typeof vi.fn>\n  let mockLoadDatabaseTable: ReturnType<typeof vi.fn>\n  let mockSaveDatabaseTable: ReturnType<typeof vi.fn>\n  let mockInferDatabaseSchema: ReturnType<typeof vi.fn>\n\n  beforeEach(() => {\n    plugin = new DatabasePlugin()\n    mockLoadPackageFromDatabase = vi.mocked(\n      packageModule.loadPackageFromDatabase,\n    )\n    mockSavePackageToDatabase = vi.mocked(packageModule.savePackageToDatabase)\n    mockLoadDatabaseTable = vi.mocked(tableModule.loadDatabaseTable)\n    mockSaveDatabaseTable = vi.mocked(tableModule.saveDatabaseTable)\n    mockInferDatabaseSchema = vi.mocked(schemaModule.inferDatabaseSchema)\n    vi.clearAllMocks()\n  })\n\n  describe(\"loadPackage\", () => {\n    it(\"should load package from postgresql database\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      mockLoadPackageFromDatabase.mockResolvedValue(mockPackage)\n\n      const result = await plugin.loadPackage(\"postgresql://localhost/testdb\")\n\n      expect(mockLoadPackageFromDatabase).toHaveBeenCalledWith(\n        \"postgresql://localhost/testdb\",\n        { format: \"postgresql\" },\n      )\n      expect(result).toEqual(mockPackage)\n    })\n\n    it(\"should load package from mysql database\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      mockLoadPackageFromDatabase.mockResolvedValue(mockPackage)\n\n      const result = await plugin.loadPackage(\"mysql://localhost/testdb\")\n\n      expect(mockLoadPackageFromDatabase).toHaveBeenCalledWith(\n        \"mysql://localhost/testdb\",\n        { format: \"mysql\" },\n      )\n      expect(result).toEqual(mockPackage)\n    })\n\n    it(\"should load package from sqlite database\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      mockLoadPackageFromDatabase.mockResolvedValue(mockPackage)\n\n      const result = await plugin.loadPackage(\"sqlite://test.db\")\n\n      expect(mockLoadPackageFromDatabase).toHaveBeenCalledWith(\n        \"sqlite://test.db\",\n        {\n          format: \"sqlite\",\n        },\n      )\n      expect(result).toEqual(mockPackage)\n    })\n\n    it(\"should return undefined for non-database sources\", async () => {\n      const result = await plugin.loadPackage(\"test.csv\")\n\n      expect(mockLoadPackageFromDatabase).not.toHaveBeenCalled()\n      expect(result).toBeUndefined()\n    })\n\n    it(\"should return undefined for http urls\", async () => {\n      const result = await plugin.loadPackage(\"https://example.com/data\")\n\n      expect(mockLoadPackageFromDatabase).not.toHaveBeenCalled()\n      expect(result).toBeUndefined()\n    })\n  })\n\n  describe(\"savePackage\", () => {\n    it(\"should save package to postgresql database\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      mockSavePackageToDatabase.mockResolvedValue(undefined)\n\n      await plugin.savePackage(mockPackage, {\n        target: \"postgresql://localhost/testdb\",\n      })\n\n      expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {\n        target: \"postgresql://localhost/testdb\",\n        format: \"postgresql\",\n      })\n    })\n\n    it(\"should save package to mysql database\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      mockSavePackageToDatabase.mockResolvedValue(undefined)\n\n      await plugin.savePackage(mockPackage, {\n        target: \"mysql://localhost/testdb\",\n      })\n\n      expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {\n        target: \"mysql://localhost/testdb\",\n        format: \"mysql\",\n      })\n    })\n\n    it(\"should save package to sqlite database\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      mockSavePackageToDatabase.mockResolvedValue(undefined)\n\n      await plugin.savePackage(mockPackage, { target: \"sqlite://test.db\" })\n\n      expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {\n        target: \"sqlite://test.db\",\n        format: \"sqlite\",\n      })\n    })\n\n    it(\"should return undefined for non-database targets\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n\n      const result = await plugin.savePackage(mockPackage, {\n        target: \"test.csv\",\n      })\n\n      expect(mockSavePackageToDatabase).not.toHaveBeenCalled()\n      expect(result).toBeUndefined()\n    })\n\n    it(\"should pass through plugins option\", async () => {\n      const mockPackage: Package = {\n        name: \"test-package\",\n        resources: [{ name: \"test\", data: [] }],\n      }\n      const mockPlugins: any[] = []\n      mockSavePackageToDatabase.mockResolvedValue(undefined)\n\n      await plugin.savePackage(mockPackage, {\n        target: \"sqlite://test.db\",\n        plugins: mockPlugins,\n      })\n\n      expect(mockSavePackageToDatabase).toHaveBeenCalledWith(mockPackage, {\n        target: \"sqlite://test.db\",\n        format: \"sqlite\",\n        plugins: mockPlugins,\n      })\n    })\n  })\n\n  describe(\"loadTable\", () => {\n    it(\"should load table from postgresql resource\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"postgresql://localhost/testdb\",\n      }\n      const mockTable = pl.DataFrame().lazy()\n      mockLoadDatabaseTable.mockResolvedValue(mockTable)\n\n      const result = await plugin.loadTable(resource)\n\n      expect(mockLoadDatabaseTable).toHaveBeenCalledWith({\n        ...resource,\n        format: \"postgresql\",\n      })\n      expect(result).toEqual(mockTable)\n    })\n\n    it(\"should load table from mysql resource\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"mysql://localhost/testdb\",\n      }\n      const mockTable = pl.DataFrame().lazy()\n      mockLoadDatabaseTable.mockResolvedValue(mockTable)\n\n      const result = await plugin.loadTable(resource)\n\n      expect(mockLoadDatabaseTable).toHaveBeenCalledWith({\n        ...resource,\n        format: \"mysql\",\n      })\n      expect(result).toEqual(mockTable)\n    })\n\n    it(\"should load table from sqlite resource\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"sqlite://test.db\",\n      }\n      const mockTable = pl.DataFrame().lazy()\n      mockLoadDatabaseTable.mockResolvedValue(mockTable)\n\n      const result = await plugin.loadTable(resource)\n\n      expect(mockLoadDatabaseTable).toHaveBeenCalledWith({\n        ...resource,\n        format: \"sqlite\",\n      })\n      expect(result).toEqual(mockTable)\n    })\n\n    it(\"should return undefined for non-database resources\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"test.csv\",\n      }\n\n      const result = await plugin.loadTable(resource)\n\n      expect(mockLoadDatabaseTable).not.toHaveBeenCalled()\n      expect(result).toBeUndefined()\n    })\n\n    it(\"should handle explicit format specification\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"test.txt\",\n        format: \"sqlite\",\n      }\n      const mockTable = pl.DataFrame().lazy()\n      mockLoadDatabaseTable.mockResolvedValue(mockTable)\n\n      const result = await plugin.loadTable(resource)\n\n      expect(mockLoadDatabaseTable).toHaveBeenCalledWith({\n        ...resource,\n        format: \"sqlite\",\n      })\n      expect(result).toEqual(mockTable)\n    })\n  })\n\n  describe(\"saveTable\", () => {\n    it(\"should save table to postgresql database\", async () => {\n      const table = pl.DataFrame().lazy()\n      const options = { path: \"postgresql://localhost/testdb\" }\n      mockSaveDatabaseTable.mockResolvedValue(\"postgresql://localhost/testdb\")\n\n      const result = await plugin.saveTable(table, options)\n\n      expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {\n        ...options,\n        format: \"postgresql\",\n      })\n      expect(result).toBe(\"postgresql://localhost/testdb\")\n    })\n\n    it(\"should save table to mysql database\", async () => {\n      const table = pl.DataFrame().lazy()\n      const options = { path: \"mysql://localhost/testdb\" }\n      mockSaveDatabaseTable.mockResolvedValue(\"mysql://localhost/testdb\")\n\n      const result = await plugin.saveTable(table, options)\n\n      expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {\n        ...options,\n        format: \"mysql\",\n      })\n      expect(result).toBe(\"mysql://localhost/testdb\")\n    })\n\n    it(\"should save table to sqlite database\", async () => {\n      const table = pl.DataFrame().lazy()\n      const options = { path: \"sqlite://test.db\" }\n      mockSaveDatabaseTable.mockResolvedValue(\"sqlite://test.db\")\n\n      const result = await plugin.saveTable(table, options)\n\n      expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {\n        ...options,\n        format: \"sqlite\",\n      })\n      expect(result).toBe(\"sqlite://test.db\")\n    })\n\n    it(\"should return undefined for non-database paths\", async () => {\n      const table = pl.DataFrame().lazy()\n      const options = { path: \"output.csv\" }\n\n      const result = await plugin.saveTable(table, options)\n\n      expect(mockSaveDatabaseTable).not.toHaveBeenCalled()\n      expect(result).toBeUndefined()\n    })\n\n    it(\"should handle explicit format specification\", async () => {\n      const table = pl.DataFrame().lazy()\n      const options = { path: \"test.txt\", format: \"sqlite\" as const }\n      mockSaveDatabaseTable.mockResolvedValue(\"test.txt\")\n\n      const result = await plugin.saveTable(table, options)\n\n      expect(mockSaveDatabaseTable).toHaveBeenCalledWith(table, {\n        ...options,\n        format: \"sqlite\",\n      })\n      expect(result).toBe(\"test.txt\")\n    })\n  })\n\n  describe(\"inferSchema\", () => {\n    it(\"should infer schema for postgresql resource\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"postgresql://localhost/testdb\",\n      }\n      const mockSchema = { fields: [] }\n      mockInferDatabaseSchema.mockResolvedValue(mockSchema)\n\n      const result = await plugin.inferSchema(resource)\n\n      expect(mockInferDatabaseSchema).toHaveBeenCalledWith({\n        ...resource,\n        format: \"postgresql\",\n      })\n      expect(result).toEqual(mockSchema)\n    })\n\n    it(\"should infer schema for mysql resource\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"mysql://localhost/testdb\",\n      }\n      const mockSchema = { fields: [] }\n      mockInferDatabaseSchema.mockResolvedValue(mockSchema)\n\n      const result = await plugin.inferSchema(resource)\n\n      expect(mockInferDatabaseSchema).toHaveBeenCalledWith({\n        ...resource,\n        format: \"mysql\",\n      })\n      expect(result).toEqual(mockSchema)\n    })\n\n    it(\"should infer schema for sqlite resource\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"sqlite://test.db\",\n      }\n      const mockSchema = { fields: [] }\n      mockInferDatabaseSchema.mockResolvedValue(mockSchema)\n\n      const result = await plugin.inferSchema(resource)\n\n      expect(mockInferDatabaseSchema).toHaveBeenCalledWith({\n        ...resource,\n        format: \"sqlite\",\n      })\n      expect(result).toEqual(mockSchema)\n    })\n\n    it(\"should return undefined for non-database resources\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"test.csv\",\n      }\n\n      const result = await plugin.inferSchema(resource)\n\n      expect(mockInferDatabaseSchema).not.toHaveBeenCalled()\n      expect(result).toBeUndefined()\n    })\n\n    it(\"should handle explicit format specification\", async () => {\n      const resource: Partial<Resource> = {\n        path: \"test.txt\",\n        format: \"sqlite\",\n      }\n      const mockSchema = { fields: [] }\n      mockInferDatabaseSchema.mockResolvedValue(mockSchema)\n\n      const result = await plugin.inferSchema(resource)\n\n      expect(mockInferDatabaseSchema).toHaveBeenCalledWith({\n        ...resource,\n        format: \"sqlite\",\n      })\n      expect(result).toEqual(mockSchema)\n    })\n  })\n})\n"]}
@@ -0,0 +1 @@
1
+ export type DatabaseFormat = "sqlite" | "postgresql" | "mysql";
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRm9ybWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vcmVzb3VyY2UvRm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBEYXRhYmFzZUZvcm1hdCA9IFwic3FsaXRlXCIgfCBcInBvc3RncmVzcWxcIiB8IFwibXlzcWxcIlxuIl19
@@ -0,0 +1 @@
1
+ export type { DatabaseFormat } from "./Format.ts";
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9yZXNvdXJjZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgeyBEYXRhYmFzZUZvcm1hdCB9IGZyb20gXCIuL0Zvcm1hdC50c1wiXG4iXX0=
@@ -0,0 +1,4 @@
1
+ import type { TableMetadata } from "kysely";
2
+ export interface DatabaseSchema extends TableMetadata {
3
+ primaryKey?: string[];
4
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc2NoZW1hL1NjaGVtYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUYWJsZU1ldGFkYXRhIH0gZnJvbSBcImt5c2VseVwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgRGF0YWJhc2VTY2hlbWEgZXh0ZW5kcyBUYWJsZU1ldGFkYXRhIHtcbiAgcHJpbWFyeUtleT86IHN0cmluZ1tdXG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export { inferDatabaseSchema } from "./infer.ts";
2
+ export type { DatabaseSchema } from "./Schema.ts";
@@ -0,0 +1,2 @@
1
+ export { inferDatabaseSchema } from "./infer.js";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zY2hlbWEvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sWUFBWSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgaW5mZXJEYXRhYmFzZVNjaGVtYSB9IGZyb20gXCIuL2luZmVyLnRzXCJcbmV4cG9ydCB0eXBlIHsgRGF0YWJhc2VTY2hlbWEgfSBmcm9tIFwiLi9TY2hlbWEudHNcIlxuIl19
@@ -0,0 +1,4 @@
1
+ import type { Resource } from "@frictionless-ts/metadata";
2
+ export declare function inferDatabaseSchema(resource: Partial<Resource> & {
3
+ format: "postgresql" | "mysql" | "sqlite";
4
+ }): Promise<import("@frictionless-ts/metadata").Schema>;
@@ -0,0 +1,24 @@
1
+ import { resolveDialect } from "@frictionless-ts/metadata";
2
+ import { createAdapter } from "../adapters/create.js";
3
+ export async function inferDatabaseSchema(resource) {
4
+ const adapter = createAdapter(resource.format);
5
+ if (!adapter) {
6
+ throw new Error("Supported database format is not defined");
7
+ }
8
+ const dialect = await resolveDialect(resource.dialect);
9
+ if (!dialect?.table) {
10
+ throw new Error("Table name is not defined in dialect");
11
+ }
12
+ const path = typeof resource.path === "string" ? resource.path : undefined;
13
+ if (!path) {
14
+ throw new Error("Resource path is not defined");
15
+ }
16
+ const database = await adapter.connectDatabase(path);
17
+ const databaseSchemas = await database.introspection.getTables();
18
+ const databaseSchema = databaseSchemas.find(s => s.name === dialect.table);
19
+ if (!databaseSchema) {
20
+ throw new Error(`Table is not found in database: ${dialect.table}`);
21
+ }
22
+ return adapter.normalizeSchema(databaseSchema);
23
+ }
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zY2hlbWEvaW5mZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDJCQUEyQixDQUFBO0FBQzFELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUVyRCxNQUFNLENBQUMsS0FBSyxVQUFVLG1CQUFtQixDQUN2QyxRQUEyRTtJQUUzRSxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQzlDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNiLE1BQU0sSUFBSSxLQUFLLENBQUMsMENBQTBDLENBQUMsQ0FBQTtJQUM3RCxDQUFDO0lBRUQsTUFBTSxPQUFPLEdBQUcsTUFBTSxjQUFjLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ3RELElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDcEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxzQ0FBc0MsQ0FBQyxDQUFBO0lBQ3pELENBQUM7SUFFRCxNQUFNLElBQUksR0FBRyxPQUFPLFFBQVEsQ0FBQyxJQUFJLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUE7SUFDMUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ1YsTUFBTSxJQUFJLEtBQUssQ0FBQyw4QkFBOEIsQ0FBQyxDQUFBO0lBQ2pELENBQUM7SUFFRCxNQUFNLFFBQVEsR0FBRyxNQUFNLE9BQU8sQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDcEQsTUFBTSxlQUFlLEdBQUcsTUFBTSxRQUFRLENBQUMsYUFBYSxDQUFDLFNBQVMsRUFBRSxDQUFBO0lBRWhFLE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUMxRSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDcEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxtQ0FBbUMsT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDckUsQ0FBQztJQUVELE9BQU8sT0FBTyxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBQTtBQUNoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZXNvdXJjZSB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL21ldGFkYXRhXCJcbmltcG9ydCB7IHJlc29sdmVEaWFsZWN0IH0gZnJvbSBcIkBmcmljdGlvbmxlc3MtdHMvbWV0YWRhdGFcIlxuaW1wb3J0IHsgY3JlYXRlQWRhcHRlciB9IGZyb20gXCIuLi9hZGFwdGVycy9jcmVhdGUudHNcIlxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5mZXJEYXRhYmFzZVNjaGVtYShcbiAgcmVzb3VyY2U6IFBhcnRpYWw8UmVzb3VyY2U+ICYgeyBmb3JtYXQ6IFwicG9zdGdyZXNxbFwiIHwgXCJteXNxbFwiIHwgXCJzcWxpdGVcIiB9LFxuKSB7XG4gIGNvbnN0IGFkYXB0ZXIgPSBjcmVhdGVBZGFwdGVyKHJlc291cmNlLmZvcm1hdClcbiAgaWYgKCFhZGFwdGVyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiU3VwcG9ydGVkIGRhdGFiYXNlIGZvcm1hdCBpcyBub3QgZGVmaW5lZFwiKVxuICB9XG5cbiAgY29uc3QgZGlhbGVjdCA9IGF3YWl0IHJlc29sdmVEaWFsZWN0KHJlc291cmNlLmRpYWxlY3QpXG4gIGlmICghZGlhbGVjdD8udGFibGUpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJUYWJsZSBuYW1lIGlzIG5vdCBkZWZpbmVkIGluIGRpYWxlY3RcIilcbiAgfVxuXG4gIGNvbnN0IHBhdGggPSB0eXBlb2YgcmVzb3VyY2UucGF0aCA9PT0gXCJzdHJpbmdcIiA/IHJlc291cmNlLnBhdGggOiB1bmRlZmluZWRcbiAgaWYgKCFwYXRoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiUmVzb3VyY2UgcGF0aCBpcyBub3QgZGVmaW5lZFwiKVxuICB9XG5cbiAgY29uc3QgZGF0YWJhc2UgPSBhd2FpdCBhZGFwdGVyLmNvbm5lY3REYXRhYmFzZShwYXRoKVxuICBjb25zdCBkYXRhYmFzZVNjaGVtYXMgPSBhd2FpdCBkYXRhYmFzZS5pbnRyb3NwZWN0aW9uLmdldFRhYmxlcygpXG5cbiAgY29uc3QgZGF0YWJhc2VTY2hlbWEgPSBkYXRhYmFzZVNjaGVtYXMuZmluZChzID0+IHMubmFtZSA9PT0gZGlhbGVjdC50YWJsZSlcbiAgaWYgKCFkYXRhYmFzZVNjaGVtYSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgVGFibGUgaXMgbm90IGZvdW5kIGluIGRhdGFiYXNlOiAke2RpYWxlY3QudGFibGV9YClcbiAgfVxuXG4gIHJldHVybiBhZGFwdGVyLm5vcm1hbGl6ZVNjaGVtYShkYXRhYmFzZVNjaGVtYSlcbn1cbiJdfQ==
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,25 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { inferDatabaseSchema } from "./infer.js";
3
+ // TODO: Enable when SQLite support is fixed
4
+ describe.skip("inferDatabaseSchema", () => {
5
+ it("throws error when resource path is not defined", async () => {
6
+ await expect(inferDatabaseSchema({
7
+ format: "sqlite",
8
+ dialect: { table: "dpkit" },
9
+ })).rejects.toThrow("Resource path is not defined");
10
+ });
11
+ it("throws error when table name is not defined in dialect", async () => {
12
+ await expect(inferDatabaseSchema({
13
+ path: "path",
14
+ format: "sqlite",
15
+ })).rejects.toThrow("Table name is not defined in dialect");
16
+ });
17
+ it("throws error when format is not supported", async () => {
18
+ await expect(inferDatabaseSchema({
19
+ path: "path",
20
+ format: "unsupported",
21
+ dialect: { table: "dpkit" },
22
+ })).rejects.toThrow('Unsupported database format: "unsupported"');
23
+ });
24
+ });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mZXIuc3BlYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NjaGVtYS9pbmZlci5zcGVjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxNQUFNLFFBQVEsQ0FBQTtBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFFaEQsNENBQTRDO0FBQzVDLFFBQVEsQ0FBQyxJQUFJLENBQUMscUJBQXFCLEVBQUUsR0FBRyxFQUFFO0lBQ3hDLEVBQUUsQ0FBQyxnREFBZ0QsRUFBRSxLQUFLLElBQUksRUFBRTtRQUM5RCxNQUFNLE1BQU0sQ0FDVixtQkFBbUIsQ0FBQztZQUNsQixNQUFNLEVBQUUsUUFBUTtZQUNoQixPQUFPLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFO1NBQzVCLENBQUMsQ0FDSCxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsOEJBQThCLENBQUMsQ0FBQTtJQUNuRCxDQUFDLENBQUMsQ0FBQTtJQUVGLEVBQUUsQ0FBQyx3REFBd0QsRUFBRSxLQUFLLElBQUksRUFBRTtRQUN0RSxNQUFNLE1BQU0sQ0FDVixtQkFBbUIsQ0FBQztZQUNsQixJQUFJLEVBQUUsTUFBTTtZQUNaLE1BQU0sRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FDSCxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsc0NBQXNDLENBQUMsQ0FBQTtJQUMzRCxDQUFDLENBQUMsQ0FBQTtJQUVGLEVBQUUsQ0FBQywyQ0FBMkMsRUFBRSxLQUFLLElBQUksRUFBRTtRQUN6RCxNQUFNLE1BQU0sQ0FDVixtQkFBbUIsQ0FBQztZQUNsQixJQUFJLEVBQUUsTUFBTTtZQUNaLE1BQU0sRUFBRSxhQUFvQjtZQUM1QixPQUFPLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFO1NBQzVCLENBQUMsQ0FDSCxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsNENBQTRDLENBQUMsQ0FBQTtJQUNqRSxDQUFDLENBQUMsQ0FBQTtBQUNKLENBQUMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZGVzY3JpYmUsIGV4cGVjdCwgaXQgfSBmcm9tIFwidml0ZXN0XCJcbmltcG9ydCB7IGluZmVyRGF0YWJhc2VTY2hlbWEgfSBmcm9tIFwiLi9pbmZlci50c1wiXG5cbi8vIFRPRE86IEVuYWJsZSB3aGVuIFNRTGl0ZSBzdXBwb3J0IGlzIGZpeGVkXG5kZXNjcmliZS5za2lwKFwiaW5mZXJEYXRhYmFzZVNjaGVtYVwiLCAoKSA9PiB7XG4gIGl0KFwidGhyb3dzIGVycm9yIHdoZW4gcmVzb3VyY2UgcGF0aCBpcyBub3QgZGVmaW5lZFwiLCBhc3luYyAoKSA9PiB7XG4gICAgYXdhaXQgZXhwZWN0KFxuICAgICAgaW5mZXJEYXRhYmFzZVNjaGVtYSh7XG4gICAgICAgIGZvcm1hdDogXCJzcWxpdGVcIixcbiAgICAgICAgZGlhbGVjdDogeyB0YWJsZTogXCJkcGtpdFwiIH0sXG4gICAgICB9KSxcbiAgICApLnJlamVjdHMudG9UaHJvdyhcIlJlc291cmNlIHBhdGggaXMgbm90IGRlZmluZWRcIilcbiAgfSlcblxuICBpdChcInRocm93cyBlcnJvciB3aGVuIHRhYmxlIG5hbWUgaXMgbm90IGRlZmluZWQgaW4gZGlhbGVjdFwiLCBhc3luYyAoKSA9PiB7XG4gICAgYXdhaXQgZXhwZWN0KFxuICAgICAgaW5mZXJEYXRhYmFzZVNjaGVtYSh7XG4gICAgICAgIHBhdGg6IFwicGF0aFwiLFxuICAgICAgICBmb3JtYXQ6IFwic3FsaXRlXCIsXG4gICAgICB9KSxcbiAgICApLnJlamVjdHMudG9UaHJvdyhcIlRhYmxlIG5hbWUgaXMgbm90IGRlZmluZWQgaW4gZGlhbGVjdFwiKVxuICB9KVxuXG4gIGl0KFwidGhyb3dzIGVycm9yIHdoZW4gZm9ybWF0IGlzIG5vdCBzdXBwb3J0ZWRcIiwgYXN5bmMgKCkgPT4ge1xuICAgIGF3YWl0IGV4cGVjdChcbiAgICAgIGluZmVyRGF0YWJhc2VTY2hlbWEoe1xuICAgICAgICBwYXRoOiBcInBhdGhcIixcbiAgICAgICAgZm9ybWF0OiBcInVuc3VwcG9ydGVkXCIgYXMgYW55LFxuICAgICAgICBkaWFsZWN0OiB7IHRhYmxlOiBcImRwa2l0XCIgfSxcbiAgICAgIH0pLFxuICAgICkucmVqZWN0cy50b1Rocm93KCdVbnN1cHBvcnRlZCBkYXRhYmFzZSBmb3JtYXQ6IFwidW5zdXBwb3J0ZWRcIicpXG4gIH0pXG59KVxuIl19
@@ -0,0 +1,2 @@
1
+ export { loadDatabaseTable } from "./load.ts";
2
+ export { saveDatabaseTable } from "./save.ts";
@@ -0,0 +1,3 @@
1
+ export { loadDatabaseTable } from "./load.js";
2
+ export { saveDatabaseTable } from "./save.js";
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90YWJsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxXQUFXLENBQUE7QUFDN0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sV0FBVyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgbG9hZERhdGFiYXNlVGFibGUgfSBmcm9tIFwiLi9sb2FkLnRzXCJcbmV4cG9ydCB7IHNhdmVEYXRhYmFzZVRhYmxlIH0gZnJvbSBcIi4vc2F2ZS50c1wiXG4iXX0=
@@ -0,0 +1,6 @@
1
+ import type { Resource } from "@frictionless-ts/metadata";
2
+ import type { LoadTableOptions } from "@frictionless-ts/table";
3
+ import * as pl from "nodejs-polars";
4
+ export declare function loadDatabaseTable(resource: Partial<Resource> & {
5
+ format: "postgresql" | "mysql" | "sqlite";
6
+ }, options?: LoadTableOptions): Promise<pl.LazyDataFrame<any>>;
@@ -0,0 +1,29 @@
1
+ import { resolveDialect, resolveSchema } from "@frictionless-ts/metadata";
2
+ import { normalizeTable } from "@frictionless-ts/table";
3
+ import * as pl from "nodejs-polars";
4
+ import { createAdapter } from "../adapters/create.js";
5
+ import { inferDatabaseSchema } from "../schema/index.js";
6
+ // Currently, we use slow non-rust implementation as in the future
7
+ // polars-rust might be able to provide a faster native implementation
8
+ export async function loadDatabaseTable(resource, options) {
9
+ const dialect = await resolveDialect(resource.dialect);
10
+ if (!dialect?.table) {
11
+ throw new Error("Table name is not defined in dialect");
12
+ }
13
+ const path = typeof resource.path === "string" ? resource.path : undefined;
14
+ if (!path) {
15
+ throw new Error("Resource path is not defined");
16
+ }
17
+ const adapter = createAdapter(resource.format);
18
+ const database = await adapter.connectDatabase(path);
19
+ const records = await database.selectFrom(dialect.table).selectAll().execute();
20
+ let table = pl.DataFrame(records).lazy();
21
+ if (!options?.denormalized) {
22
+ let schema = await resolveSchema(resource.schema);
23
+ if (!schema)
24
+ schema = await inferDatabaseSchema(resource);
25
+ table = await normalizeTable(table, schema);
26
+ }
27
+ return table;
28
+ }
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RhYmxlL2xvYWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTtBQUV6RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFFdkQsT0FBTyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDbkMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBQ3JELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFBO0FBRXhELGtFQUFrRTtBQUNsRSxzRUFBc0U7QUFFdEUsTUFBTSxDQUFDLEtBQUssVUFBVSxpQkFBaUIsQ0FDckMsUUFBMkUsRUFDM0UsT0FBMEI7SUFFMUIsTUFBTSxPQUFPLEdBQUcsTUFBTSxjQUFjLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ3RELElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDcEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxzQ0FBc0MsQ0FBQyxDQUFBO0lBQ3pELENBQUM7SUFFRCxNQUFNLElBQUksR0FBRyxPQUFPLFFBQVEsQ0FBQyxJQUFJLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUE7SUFDMUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ1YsTUFBTSxJQUFJLEtBQUssQ0FBQyw4QkFBOEIsQ0FBQyxDQUFBO0lBQ2pELENBQUM7SUFFRCxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQzlDLE1BQU0sUUFBUSxHQUFHLE1BQU0sT0FBTyxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNwRCxNQUFNLE9BQU8sR0FBRyxNQUFNLFFBQVEsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFBO0lBRTlFLElBQUksS0FBSyxHQUFHLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUE7SUFFeEMsSUFBSSxDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsQ0FBQztRQUMzQixJQUFJLE1BQU0sR0FBRyxNQUFNLGFBQWEsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUE7UUFDakQsSUFBSSxDQUFDLE1BQU07WUFBRSxNQUFNLEdBQUcsTUFBTSxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsQ0FBQTtRQUN6RCxLQUFLLEdBQUcsTUFBTSxjQUFjLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFBO0lBQzdDLENBQUM7SUFFRCxPQUFPLEtBQUssQ0FBQTtBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByZXNvbHZlRGlhbGVjdCwgcmVzb2x2ZVNjaGVtYSB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL21ldGFkYXRhXCJcbmltcG9ydCB0eXBlIHsgUmVzb3VyY2UgfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9tZXRhZGF0YVwiXG5pbXBvcnQgeyBub3JtYWxpemVUYWJsZSB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL3RhYmxlXCJcbmltcG9ydCB0eXBlIHsgTG9hZFRhYmxlT3B0aW9ucyB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL3RhYmxlXCJcbmltcG9ydCAqIGFzIHBsIGZyb20gXCJub2RlanMtcG9sYXJzXCJcbmltcG9ydCB7IGNyZWF0ZUFkYXB0ZXIgfSBmcm9tIFwiLi4vYWRhcHRlcnMvY3JlYXRlLnRzXCJcbmltcG9ydCB7IGluZmVyRGF0YWJhc2VTY2hlbWEgfSBmcm9tIFwiLi4vc2NoZW1hL2luZGV4LnRzXCJcblxuLy8gQ3VycmVudGx5LCB3ZSB1c2Ugc2xvdyBub24tcnVzdCBpbXBsZW1lbnRhdGlvbiBhcyBpbiB0aGUgZnV0dXJlXG4vLyBwb2xhcnMtcnVzdCBtaWdodCBiZSBhYmxlIHRvIHByb3ZpZGUgYSBmYXN0ZXIgbmF0aXZlIGltcGxlbWVudGF0aW9uXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBsb2FkRGF0YWJhc2VUYWJsZShcbiAgcmVzb3VyY2U6IFBhcnRpYWw8UmVzb3VyY2U+ICYgeyBmb3JtYXQ6IFwicG9zdGdyZXNxbFwiIHwgXCJteXNxbFwiIHwgXCJzcWxpdGVcIiB9LFxuICBvcHRpb25zPzogTG9hZFRhYmxlT3B0aW9ucyxcbikge1xuICBjb25zdCBkaWFsZWN0ID0gYXdhaXQgcmVzb2x2ZURpYWxlY3QocmVzb3VyY2UuZGlhbGVjdClcbiAgaWYgKCFkaWFsZWN0Py50YWJsZSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlRhYmxlIG5hbWUgaXMgbm90IGRlZmluZWQgaW4gZGlhbGVjdFwiKVxuICB9XG5cbiAgY29uc3QgcGF0aCA9IHR5cGVvZiByZXNvdXJjZS5wYXRoID09PSBcInN0cmluZ1wiID8gcmVzb3VyY2UucGF0aCA6IHVuZGVmaW5lZFxuICBpZiAoIXBhdGgpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJSZXNvdXJjZSBwYXRoIGlzIG5vdCBkZWZpbmVkXCIpXG4gIH1cblxuICBjb25zdCBhZGFwdGVyID0gY3JlYXRlQWRhcHRlcihyZXNvdXJjZS5mb3JtYXQpXG4gIGNvbnN0IGRhdGFiYXNlID0gYXdhaXQgYWRhcHRlci5jb25uZWN0RGF0YWJhc2UocGF0aClcbiAgY29uc3QgcmVjb3JkcyA9IGF3YWl0IGRhdGFiYXNlLnNlbGVjdEZyb20oZGlhbGVjdC50YWJsZSkuc2VsZWN0QWxsKCkuZXhlY3V0ZSgpXG5cbiAgbGV0IHRhYmxlID0gcGwuRGF0YUZyYW1lKHJlY29yZHMpLmxhenkoKVxuXG4gIGlmICghb3B0aW9ucz8uZGVub3JtYWxpemVkKSB7XG4gICAgbGV0IHNjaGVtYSA9IGF3YWl0IHJlc29sdmVTY2hlbWEocmVzb3VyY2Uuc2NoZW1hKVxuICAgIGlmICghc2NoZW1hKSBzY2hlbWEgPSBhd2FpdCBpbmZlckRhdGFiYXNlU2NoZW1hKHJlc291cmNlKVxuICAgIHRhYmxlID0gYXdhaXQgbm9ybWFsaXplVGFibGUodGFibGUsIHNjaGVtYSlcbiAgfVxuXG4gIHJldHVybiB0YWJsZVxufVxuIl19
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,24 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { loadDatabaseTable } from "./load.js";
3
+ describe("loadDatabaseTable", () => {
4
+ it("throws error when resource path is not defined", async () => {
5
+ await expect(loadDatabaseTable({
6
+ format: "sqlite",
7
+ dialect: { table: "dpkit" },
8
+ })).rejects.toThrow("Resource path is not defined");
9
+ });
10
+ it("throws error when table name is not defined in dialect", async () => {
11
+ await expect(loadDatabaseTable({
12
+ path: "path",
13
+ format: "sqlite",
14
+ })).rejects.toThrow("Table name is not defined in dialect");
15
+ });
16
+ it("throws error when format is not supported", async () => {
17
+ await expect(loadDatabaseTable({
18
+ path: "path",
19
+ format: "unsupported",
20
+ dialect: { table: "dpkit" },
21
+ })).rejects.toThrow('Unsupported database format: "unsupported"');
22
+ });
23
+ });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC5zcGVjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdGFibGUvbG9hZC5zcGVjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxNQUFNLFFBQVEsQ0FBQTtBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxXQUFXLENBQUE7QUFFN0MsUUFBUSxDQUFDLG1CQUFtQixFQUFFLEdBQUcsRUFBRTtJQUNqQyxFQUFFLENBQUMsZ0RBQWdELEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDOUQsTUFBTSxNQUFNLENBQ1YsaUJBQWlCLENBQUM7WUFDaEIsTUFBTSxFQUFFLFFBQVE7WUFDaEIsT0FBTyxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRTtTQUM1QixDQUFDLENBQ0gsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLDhCQUE4QixDQUFDLENBQUE7SUFDbkQsQ0FBQyxDQUFDLENBQUE7SUFFRixFQUFFLENBQUMsd0RBQXdELEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDdEUsTUFBTSxNQUFNLENBQ1YsaUJBQWlCLENBQUM7WUFDaEIsSUFBSSxFQUFFLE1BQU07WUFDWixNQUFNLEVBQUUsUUFBUTtTQUNqQixDQUFDLENBQ0gsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLHNDQUFzQyxDQUFDLENBQUE7SUFDM0QsQ0FBQyxDQUFDLENBQUE7SUFFRixFQUFFLENBQUMsMkNBQTJDLEVBQUUsS0FBSyxJQUFJLEVBQUU7UUFDekQsTUFBTSxNQUFNLENBQ1YsaUJBQWlCLENBQUM7WUFDaEIsSUFBSSxFQUFFLE1BQU07WUFDWixNQUFNLEVBQUUsYUFBb0I7WUFDNUIsT0FBTyxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRTtTQUM1QixDQUFDLENBQ0gsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLDRDQUE0QyxDQUFDLENBQUE7SUFDakUsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlc2NyaWJlLCBleHBlY3QsIGl0IH0gZnJvbSBcInZpdGVzdFwiXG5pbXBvcnQgeyBsb2FkRGF0YWJhc2VUYWJsZSB9IGZyb20gXCIuL2xvYWQudHNcIlxuXG5kZXNjcmliZShcImxvYWREYXRhYmFzZVRhYmxlXCIsICgpID0+IHtcbiAgaXQoXCJ0aHJvd3MgZXJyb3Igd2hlbiByZXNvdXJjZSBwYXRoIGlzIG5vdCBkZWZpbmVkXCIsIGFzeW5jICgpID0+IHtcbiAgICBhd2FpdCBleHBlY3QoXG4gICAgICBsb2FkRGF0YWJhc2VUYWJsZSh7XG4gICAgICAgIGZvcm1hdDogXCJzcWxpdGVcIixcbiAgICAgICAgZGlhbGVjdDogeyB0YWJsZTogXCJkcGtpdFwiIH0sXG4gICAgICB9KSxcbiAgICApLnJlamVjdHMudG9UaHJvdyhcIlJlc291cmNlIHBhdGggaXMgbm90IGRlZmluZWRcIilcbiAgfSlcblxuICBpdChcInRocm93cyBlcnJvciB3aGVuIHRhYmxlIG5hbWUgaXMgbm90IGRlZmluZWQgaW4gZGlhbGVjdFwiLCBhc3luYyAoKSA9PiB7XG4gICAgYXdhaXQgZXhwZWN0KFxuICAgICAgbG9hZERhdGFiYXNlVGFibGUoe1xuICAgICAgICBwYXRoOiBcInBhdGhcIixcbiAgICAgICAgZm9ybWF0OiBcInNxbGl0ZVwiLFxuICAgICAgfSksXG4gICAgKS5yZWplY3RzLnRvVGhyb3coXCJUYWJsZSBuYW1lIGlzIG5vdCBkZWZpbmVkIGluIGRpYWxlY3RcIilcbiAgfSlcblxuICBpdChcInRocm93cyBlcnJvciB3aGVuIGZvcm1hdCBpcyBub3Qgc3VwcG9ydGVkXCIsIGFzeW5jICgpID0+IHtcbiAgICBhd2FpdCBleHBlY3QoXG4gICAgICBsb2FkRGF0YWJhc2VUYWJsZSh7XG4gICAgICAgIHBhdGg6IFwicGF0aFwiLFxuICAgICAgICBmb3JtYXQ6IFwidW5zdXBwb3J0ZWRcIiBhcyBhbnksXG4gICAgICAgIGRpYWxlY3Q6IHsgdGFibGU6IFwiZHBraXRcIiB9LFxuICAgICAgfSksXG4gICAgKS5yZWplY3RzLnRvVGhyb3coJ1Vuc3VwcG9ydGVkIGRhdGFiYXNlIGZvcm1hdDogXCJ1bnN1cHBvcnRlZFwiJylcbiAgfSlcbn0pXG4iXX0=
@@ -0,0 +1,4 @@
1
+ import type { SaveTableOptions, Table } from "@frictionless-ts/table";
2
+ export declare function saveDatabaseTable(table: Table, options: SaveTableOptions & {
3
+ format: "postgresql" | "mysql" | "sqlite";
4
+ }): Promise<string>;