@vankyle/storage-kysely 0.1.0

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 (74) hide show
  1. package/README.md +129 -0
  2. package/dist/index.d.ts +5 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +4 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/mappers/blob-reference-row.mapper.d.ts +7 -0
  7. package/dist/mappers/blob-reference-row.mapper.d.ts.map +1 -0
  8. package/dist/mappers/blob-reference-row.mapper.js +13 -0
  9. package/dist/mappers/blob-reference-row.mapper.js.map +1 -0
  10. package/dist/mappers/blob-row.mapper.d.ts +7 -0
  11. package/dist/mappers/blob-row.mapper.d.ts.map +1 -0
  12. package/dist/mappers/blob-row.mapper.js +27 -0
  13. package/dist/mappers/blob-row.mapper.js.map +1 -0
  14. package/dist/mappers/file-row.mapper.d.ts +7 -0
  15. package/dist/mappers/file-row.mapper.d.ts.map +1 -0
  16. package/dist/mappers/file-row.mapper.js +25 -0
  17. package/dist/mappers/file-row.mapper.js.map +1 -0
  18. package/dist/mappers/file-version-row.mapper.d.ts +7 -0
  19. package/dist/mappers/file-version-row.mapper.d.ts.map +1 -0
  20. package/dist/mappers/file-version-row.mapper.js +23 -0
  21. package/dist/mappers/file-version-row.mapper.js.map +1 -0
  22. package/dist/mappers/index.d.ts +7 -0
  23. package/dist/mappers/index.d.ts.map +1 -0
  24. package/dist/mappers/index.js +7 -0
  25. package/dist/mappers/index.js.map +1 -0
  26. package/dist/mappers/upload-session-row.mapper.d.ts +7 -0
  27. package/dist/mappers/upload-session-row.mapper.d.ts.map +1 -0
  28. package/dist/mappers/upload-session-row.mapper.js +33 -0
  29. package/dist/mappers/upload-session-row.mapper.js.map +1 -0
  30. package/dist/mappers/uploaded-part-row.mapper.d.ts +7 -0
  31. package/dist/mappers/uploaded-part-row.mapper.d.ts.map +1 -0
  32. package/dist/mappers/uploaded-part-row.mapper.js +22 -0
  33. package/dist/mappers/uploaded-part-row.mapper.js.map +1 -0
  34. package/dist/metadata/index.d.ts +5 -0
  35. package/dist/metadata/index.d.ts.map +1 -0
  36. package/dist/metadata/index.js +5 -0
  37. package/dist/metadata/index.js.map +1 -0
  38. package/dist/metadata/kysely-metadata-store.d.ts +13 -0
  39. package/dist/metadata/kysely-metadata-store.d.ts.map +1 -0
  40. package/dist/metadata/kysely-metadata-store.js +14 -0
  41. package/dist/metadata/kysely-metadata-store.js.map +1 -0
  42. package/dist/metadata/stores/index.d.ts +4 -0
  43. package/dist/metadata/stores/index.d.ts.map +1 -0
  44. package/dist/metadata/stores/index.js +4 -0
  45. package/dist/metadata/stores/index.js.map +1 -0
  46. package/dist/metadata/stores/kysely-blob-store.d.ts +17 -0
  47. package/dist/metadata/stores/kysely-blob-store.d.ts.map +1 -0
  48. package/dist/metadata/stores/kysely-blob-store.js +105 -0
  49. package/dist/metadata/stores/kysely-blob-store.js.map +1 -0
  50. package/dist/metadata/stores/kysely-file-store.d.ts +16 -0
  51. package/dist/metadata/stores/kysely-file-store.d.ts.map +1 -0
  52. package/dist/metadata/stores/kysely-file-store.js +112 -0
  53. package/dist/metadata/stores/kysely-file-store.js.map +1 -0
  54. package/dist/metadata/stores/kysely-upload-session-store.d.ts +15 -0
  55. package/dist/metadata/stores/kysely-upload-session-store.d.ts.map +1 -0
  56. package/dist/metadata/stores/kysely-upload-session-store.js +110 -0
  57. package/dist/metadata/stores/kysely-upload-session-store.js.map +1 -0
  58. package/dist/migrations/0001_init.d.ts +4 -0
  59. package/dist/migrations/0001_init.d.ts.map +1 -0
  60. package/dist/migrations/0001_init.js +143 -0
  61. package/dist/migrations/0001_init.js.map +1 -0
  62. package/dist/migrations/index.d.ts +2 -0
  63. package/dist/migrations/index.d.ts.map +1 -0
  64. package/dist/migrations/index.js +2 -0
  65. package/dist/migrations/index.js.map +1 -0
  66. package/dist/schema/database.d.ts +92 -0
  67. package/dist/schema/database.d.ts.map +1 -0
  68. package/dist/schema/database.js +2 -0
  69. package/dist/schema/database.js.map +1 -0
  70. package/dist/schema/index.d.ts +2 -0
  71. package/dist/schema/index.d.ts.map +1 -0
  72. package/dist/schema/index.js +2 -0
  73. package/dist/schema/index.js.map +1 -0
  74. package/package.json +41 -0
@@ -0,0 +1,105 @@
1
+ import { BlobStatus } from "@vankyle-hub/storage-core";
2
+ import { blobRowToModel } from "../../mappers/blob-row.mapper.js";
3
+ import { blobReferenceRowToModel } from "../../mappers/blob-reference-row.mapper.js";
4
+ export class KyselyBlobStore {
5
+ db;
6
+ constructor(db) {
7
+ this.db = db;
8
+ }
9
+ async createBlob(input) {
10
+ const now = new Date();
11
+ const row = await this.db
12
+ .insertInto("blobs")
13
+ .values({
14
+ id: input.id,
15
+ provider: input.provider,
16
+ bucket: input.bucket,
17
+ object_key: input.objectKey,
18
+ size: input.size,
19
+ mime_type: input.mimeType ?? null,
20
+ sha256: input.sha256 ?? null,
21
+ etag: input.etag ?? null,
22
+ storage_class: input.storageClass ?? null,
23
+ status: BlobStatus.Active,
24
+ created_at: now,
25
+ updated_at: now,
26
+ deleted_at: null,
27
+ metadata: input.metadata ? JSON.stringify(input.metadata) : null,
28
+ })
29
+ .returningAll()
30
+ .executeTakeFirstOrThrow();
31
+ return blobRowToModel(row);
32
+ }
33
+ async getBlob(id) {
34
+ const row = await this.db
35
+ .selectFrom("blobs")
36
+ .selectAll()
37
+ .where("id", "=", id)
38
+ .executeTakeFirst();
39
+ return row ? blobRowToModel(row) : undefined;
40
+ }
41
+ async updateBlob(id, input) {
42
+ const updates = {
43
+ updated_at: new Date(),
44
+ };
45
+ if (input.status !== undefined)
46
+ updates.status = input.status;
47
+ if (input.deletedAt !== undefined)
48
+ updates.deleted_at = input.deletedAt;
49
+ const row = await this.db
50
+ .updateTable("blobs")
51
+ .set(updates)
52
+ .where("id", "=", id)
53
+ .returningAll()
54
+ .executeTakeFirstOrThrow();
55
+ return blobRowToModel(row);
56
+ }
57
+ async findBlobBySha256(sha256) {
58
+ const row = await this.db
59
+ .selectFrom("blobs")
60
+ .selectAll()
61
+ .where("sha256", "=", sha256)
62
+ .where("status", "=", BlobStatus.Active)
63
+ .executeTakeFirst();
64
+ return row ? blobRowToModel(row) : undefined;
65
+ }
66
+ async findBlobByLocator(provider, bucket, objectKey) {
67
+ const row = await this.db
68
+ .selectFrom("blobs")
69
+ .selectAll()
70
+ .where("provider", "=", provider)
71
+ .where("bucket", "=", bucket)
72
+ .where("object_key", "=", objectKey)
73
+ .executeTakeFirst();
74
+ return row ? blobRowToModel(row) : undefined;
75
+ }
76
+ async createReference(input) {
77
+ const row = await this.db
78
+ .insertInto("blob_references")
79
+ .values({
80
+ id: input.id,
81
+ blob_id: input.blobId,
82
+ ref_type: input.refType,
83
+ ref_id: input.refId,
84
+ created_at: new Date(),
85
+ })
86
+ .returningAll()
87
+ .executeTakeFirstOrThrow();
88
+ return blobReferenceRowToModel(row);
89
+ }
90
+ async listReferences(blobId) {
91
+ const rows = await this.db
92
+ .selectFrom("blob_references")
93
+ .selectAll()
94
+ .where("blob_id", "=", blobId)
95
+ .execute();
96
+ return rows.map(blobReferenceRowToModel);
97
+ }
98
+ async deleteReference(id) {
99
+ await this.db
100
+ .deleteFrom("blob_references")
101
+ .where("id", "=", id)
102
+ .execute();
103
+ }
104
+ }
105
+ //# sourceMappingURL=kysely-blob-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kysely-blob-store.js","sourceRoot":"","sources":["../../../src/metadata/stores/kysely-blob-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import type { Kysely } from "kysely";
2
+ import type { IFileStore, CreateFileInput, UpdateFileInput, CreateFileVersionInput } from "@vankyle-hub/storage-core";
3
+ import type { File, FileVersion } from "@vankyle-hub/storage-core";
4
+ import type { StorageDatabase } from "../../schema/database.js";
5
+ export declare class KyselyFileStore implements IFileStore {
6
+ private readonly db;
7
+ constructor(db: Kysely<StorageDatabase>);
8
+ createFile(input: CreateFileInput): Promise<File>;
9
+ getFile(id: string): Promise<File | undefined>;
10
+ updateFile(id: string, input: UpdateFileInput): Promise<File>;
11
+ createVersion(input: CreateFileVersionInput): Promise<FileVersion>;
12
+ getVersion(id: string): Promise<FileVersion | undefined>;
13
+ listVersions(fileId: string): Promise<FileVersion[]>;
14
+ getLatestVersion(fileId: string): Promise<FileVersion | undefined>;
15
+ }
16
+ //# sourceMappingURL=kysely-file-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kysely-file-store.d.ts","sourceRoot":"","sources":["../../../src/metadata/stores/kysely-file-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EACV,UAAU,EACV,eAAe,EACf,eAAe,EACf,sBAAsB,EACvB,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAEnE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAIhE,qBAAa,eAAgB,YAAW,UAAU;IACpC,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,MAAM,CAAC,eAAe,CAAC;IAElD,UAAU,CAAC,KAAK,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBjD,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,SAAS,CAAC;IAU9C,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAyB7D,aAAa,CAAC,KAAK,EAAE,sBAAsB,GAAG,OAAO,CAAC,WAAW,CAAC;IAqBlE,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAUxD,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;IAWpD,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;CAWzE"}
@@ -0,0 +1,112 @@
1
+ import { FileStatus } from "@vankyle-hub/storage-core";
2
+ import { fileRowToModel } from "../../mappers/file-row.mapper.js";
3
+ import { fileVersionRowToModel } from "../../mappers/file-version-row.mapper.js";
4
+ export class KyselyFileStore {
5
+ db;
6
+ constructor(db) {
7
+ this.db = db;
8
+ }
9
+ async createFile(input) {
10
+ const now = new Date();
11
+ const row = await this.db
12
+ .insertInto("files")
13
+ .values({
14
+ id: input.id,
15
+ owner_id: input.ownerId ?? null,
16
+ display_name: input.displayName,
17
+ mime_type: input.mimeType ?? null,
18
+ current_version_id: null,
19
+ size: input.size ?? null,
20
+ parent_id: input.parentId ?? null,
21
+ status: FileStatus.Active,
22
+ created_at: now,
23
+ updated_at: now,
24
+ deleted_at: null,
25
+ metadata: input.metadata ? JSON.stringify(input.metadata) : null,
26
+ })
27
+ .returningAll()
28
+ .executeTakeFirstOrThrow();
29
+ return fileRowToModel(row);
30
+ }
31
+ async getFile(id) {
32
+ const row = await this.db
33
+ .selectFrom("files")
34
+ .selectAll()
35
+ .where("id", "=", id)
36
+ .executeTakeFirst();
37
+ return row ? fileRowToModel(row) : undefined;
38
+ }
39
+ async updateFile(id, input) {
40
+ const updates = {
41
+ updated_at: new Date(),
42
+ };
43
+ if (input.displayName !== undefined)
44
+ updates.display_name = input.displayName;
45
+ if (input.currentVersionId !== undefined)
46
+ updates.current_version_id = input.currentVersionId;
47
+ if (input.size !== undefined)
48
+ updates.size = input.size;
49
+ if (input.mimeType !== undefined)
50
+ updates.mime_type = input.mimeType;
51
+ if (input.status !== undefined)
52
+ updates.status = input.status;
53
+ if (input.deletedAt !== undefined)
54
+ updates.deleted_at = input.deletedAt;
55
+ if (input.metadata !== undefined)
56
+ updates.metadata = JSON.stringify(input.metadata);
57
+ const row = await this.db
58
+ .updateTable("files")
59
+ .set(updates)
60
+ .where("id", "=", id)
61
+ .returningAll()
62
+ .executeTakeFirstOrThrow();
63
+ return fileRowToModel(row);
64
+ }
65
+ async createVersion(input) {
66
+ const row = await this.db
67
+ .insertInto("file_versions")
68
+ .values({
69
+ id: input.id,
70
+ file_id: input.fileId,
71
+ blob_id: input.blobId,
72
+ version: input.version,
73
+ size: input.size,
74
+ mime_type: input.mimeType ?? null,
75
+ sha256: input.sha256 ?? null,
76
+ created_at: new Date(),
77
+ created_by: input.createdBy ?? null,
78
+ metadata: input.metadata ? JSON.stringify(input.metadata) : null,
79
+ })
80
+ .returningAll()
81
+ .executeTakeFirstOrThrow();
82
+ return fileVersionRowToModel(row);
83
+ }
84
+ async getVersion(id) {
85
+ const row = await this.db
86
+ .selectFrom("file_versions")
87
+ .selectAll()
88
+ .where("id", "=", id)
89
+ .executeTakeFirst();
90
+ return row ? fileVersionRowToModel(row) : undefined;
91
+ }
92
+ async listVersions(fileId) {
93
+ const rows = await this.db
94
+ .selectFrom("file_versions")
95
+ .selectAll()
96
+ .where("file_id", "=", fileId)
97
+ .orderBy("version", "asc")
98
+ .execute();
99
+ return rows.map(fileVersionRowToModel);
100
+ }
101
+ async getLatestVersion(fileId) {
102
+ const row = await this.db
103
+ .selectFrom("file_versions")
104
+ .selectAll()
105
+ .where("file_id", "=", fileId)
106
+ .orderBy("version", "desc")
107
+ .limit(1)
108
+ .executeTakeFirst();
109
+ return row ? fileVersionRowToModel(row) : undefined;
110
+ }
111
+ }
112
+ //# sourceMappingURL=kysely-file-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kysely-file-store.js","sourceRoot":"","sources":["../../../src/metadata/stores/kysely-file-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { Kysely } from "kysely";
2
+ import type { IUploadSessionStore, CreateUploadSessionInput, UpdateUploadSessionInput, CreateUploadedPartInput } from "@vankyle-hub/storage-core";
3
+ import type { UploadSession, UploadedPart } from "@vankyle-hub/storage-core";
4
+ import type { StorageDatabase } from "../../schema/database.js";
5
+ export declare class KyselyUploadSessionStore implements IUploadSessionStore {
6
+ private readonly db;
7
+ constructor(db: Kysely<StorageDatabase>);
8
+ createSession(input: CreateUploadSessionInput): Promise<UploadSession>;
9
+ getSession(id: string): Promise<UploadSession | undefined>;
10
+ updateSession(id: string, input: UpdateUploadSessionInput): Promise<UploadSession>;
11
+ addPart(input: CreateUploadedPartInput): Promise<UploadedPart>;
12
+ getPart(sessionId: string, partNumber: number): Promise<UploadedPart | undefined>;
13
+ listParts(sessionId: string): Promise<UploadedPart[]>;
14
+ }
15
+ //# sourceMappingURL=kysely-upload-session-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kysely-upload-session-store.d.ts","sourceRoot":"","sources":["../../../src/metadata/stores/kysely-upload-session-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EACV,mBAAmB,EACnB,wBAAwB,EACxB,wBAAwB,EACxB,uBAAuB,EACxB,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE7E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAIhE,qBAAa,wBAAyB,YAAW,mBAAmB;IACtD,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,MAAM,CAAC,eAAe,CAAC;IAElD,aAAa,CAAC,KAAK,EAAE,wBAAwB,GAAG,OAAO,CAAC,aAAa,CAAC;IAkCtE,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC;IAU1D,aAAa,CACjB,EAAE,EAAE,MAAM,EACV,KAAK,EAAE,wBAAwB,GAC9B,OAAO,CAAC,aAAa,CAAC;IAuBnB,OAAO,CAAC,KAAK,EAAE,uBAAuB,GAAG,OAAO,CAAC,YAAY,CAAC;IAsB9D,OAAO,CACX,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;IAW9B,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;CAU5D"}
@@ -0,0 +1,110 @@
1
+ import { UploadSessionStatus } from "@vankyle-hub/storage-core";
2
+ import { uploadSessionRowToModel } from "../../mappers/upload-session-row.mapper.js";
3
+ import { uploadedPartRowToModel } from "../../mappers/uploaded-part-row.mapper.js";
4
+ export class KyselyUploadSessionStore {
5
+ db;
6
+ constructor(db) {
7
+ this.db = db;
8
+ }
9
+ async createSession(input) {
10
+ const now = new Date();
11
+ const row = await this.db
12
+ .insertInto("upload_sessions")
13
+ .values({
14
+ id: input.id,
15
+ provider: input.provider,
16
+ bucket: input.bucket,
17
+ object_key: input.objectKey,
18
+ mode: input.mode,
19
+ status: UploadSessionStatus.Pending,
20
+ file_name: input.fileName ?? null,
21
+ mime_type: input.mimeType ?? null,
22
+ expected_size: input.expectedSize ?? null,
23
+ expected_sha256: input.expectedSha256 ?? null,
24
+ provider_upload_id: input.providerUploadId ?? null,
25
+ provider_session_data: input.providerSessionData
26
+ ? JSON.stringify(input.providerSessionData)
27
+ : null,
28
+ created_by: input.createdBy ?? null,
29
+ owner_id: input.ownerId ?? null,
30
+ metadata: input.metadata ? JSON.stringify(input.metadata) : null,
31
+ created_at: now,
32
+ updated_at: now,
33
+ expires_at: input.expiresAt ?? null,
34
+ completed_at: null,
35
+ aborted_at: null,
36
+ })
37
+ .returningAll()
38
+ .executeTakeFirstOrThrow();
39
+ return uploadSessionRowToModel(row);
40
+ }
41
+ async getSession(id) {
42
+ const row = await this.db
43
+ .selectFrom("upload_sessions")
44
+ .selectAll()
45
+ .where("id", "=", id)
46
+ .executeTakeFirst();
47
+ return row ? uploadSessionRowToModel(row) : undefined;
48
+ }
49
+ async updateSession(id, input) {
50
+ const updates = {
51
+ updated_at: new Date(),
52
+ };
53
+ if (input.status !== undefined)
54
+ updates.status = input.status;
55
+ if (input.providerUploadId !== undefined)
56
+ updates.provider_upload_id = input.providerUploadId;
57
+ if (input.providerSessionData !== undefined)
58
+ updates.provider_session_data = JSON.stringify(input.providerSessionData);
59
+ if (input.completedAt !== undefined)
60
+ updates.completed_at = input.completedAt;
61
+ if (input.abortedAt !== undefined)
62
+ updates.aborted_at = input.abortedAt;
63
+ const row = await this.db
64
+ .updateTable("upload_sessions")
65
+ .set(updates)
66
+ .where("id", "=", id)
67
+ .returningAll()
68
+ .executeTakeFirstOrThrow();
69
+ return uploadSessionRowToModel(row);
70
+ }
71
+ async addPart(input) {
72
+ const row = await this.db
73
+ .insertInto("uploaded_parts")
74
+ .values({
75
+ id: input.id,
76
+ session_id: input.sessionId,
77
+ part_number: input.partNumber,
78
+ size: input.size,
79
+ etag: input.etag ?? null,
80
+ checksum_sha256: input.checksumSha256 ?? null,
81
+ provider_part_id: input.providerPartId ?? null,
82
+ provider_part_data: input.providerPartData
83
+ ? JSON.stringify(input.providerPartData)
84
+ : null,
85
+ uploaded_at: new Date(),
86
+ })
87
+ .returningAll()
88
+ .executeTakeFirstOrThrow();
89
+ return uploadedPartRowToModel(row);
90
+ }
91
+ async getPart(sessionId, partNumber) {
92
+ const row = await this.db
93
+ .selectFrom("uploaded_parts")
94
+ .selectAll()
95
+ .where("session_id", "=", sessionId)
96
+ .where("part_number", "=", partNumber)
97
+ .executeTakeFirst();
98
+ return row ? uploadedPartRowToModel(row) : undefined;
99
+ }
100
+ async listParts(sessionId) {
101
+ const rows = await this.db
102
+ .selectFrom("uploaded_parts")
103
+ .selectAll()
104
+ .where("session_id", "=", sessionId)
105
+ .orderBy("part_number", "asc")
106
+ .execute();
107
+ return rows.map(uploadedPartRowToModel);
108
+ }
109
+ }
110
+ //# sourceMappingURL=kysely-upload-session-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kysely-upload-session-store.js","sourceRoot":"","sources":["../../../src/metadata/stores/kysely-upload-session-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<unknown>): Promise<void>;
3
+ export declare function down(db: Kysely<unknown>): Promise<void>;
4
+ //# sourceMappingURL=0001_init.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"0001_init.d.ts","sourceRoot":"","sources":["../../src/migrations/0001_init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAiJ3D;AAED,wBAAsB,IAAI,CAAC,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAO7D"}
@@ -0,0 +1,143 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("upload_sessions")
5
+ .addColumn("id", "varchar(36)", (col) => col.primaryKey())
6
+ .addColumn("provider", "varchar(32)", (col) => col.notNull())
7
+ .addColumn("bucket", "varchar(255)", (col) => col.notNull())
8
+ .addColumn("object_key", "varchar(1024)", (col) => col.notNull())
9
+ .addColumn("mode", "varchar(16)", (col) => col.notNull())
10
+ .addColumn("status", "varchar(16)", (col) => col.notNull())
11
+ .addColumn("file_name", "varchar(512)")
12
+ .addColumn("mime_type", "varchar(255)")
13
+ .addColumn("expected_size", "bigint")
14
+ .addColumn("expected_sha256", "varchar(64)")
15
+ .addColumn("provider_upload_id", "varchar(512)")
16
+ .addColumn("provider_session_data", "text")
17
+ .addColumn("created_by", "varchar(255)")
18
+ .addColumn("owner_id", "varchar(255)")
19
+ .addColumn("metadata", "text")
20
+ .addColumn("created_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
21
+ .addColumn("updated_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
22
+ .addColumn("expires_at", "timestamp")
23
+ .addColumn("completed_at", "timestamp")
24
+ .addColumn("aborted_at", "timestamp")
25
+ .execute();
26
+ await db.schema
27
+ .createIndex("idx_upload_sessions_status")
28
+ .on("upload_sessions")
29
+ .column("status")
30
+ .execute();
31
+ await db.schema
32
+ .createTable("uploaded_parts")
33
+ .addColumn("id", "varchar(36)", (col) => col.primaryKey())
34
+ .addColumn("session_id", "varchar(36)", (col) => col.notNull())
35
+ .addColumn("part_number", "integer", (col) => col.notNull())
36
+ .addColumn("size", "bigint", (col) => col.notNull())
37
+ .addColumn("etag", "varchar(255)")
38
+ .addColumn("checksum_sha256", "varchar(64)")
39
+ .addColumn("provider_part_id", "varchar(512)")
40
+ .addColumn("provider_part_data", "text")
41
+ .addColumn("uploaded_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
42
+ .execute();
43
+ await db.schema
44
+ .createIndex("idx_uploaded_parts_session")
45
+ .on("uploaded_parts")
46
+ .columns(["session_id", "part_number"])
47
+ .unique()
48
+ .execute();
49
+ await db.schema
50
+ .createTable("blobs")
51
+ .addColumn("id", "varchar(36)", (col) => col.primaryKey())
52
+ .addColumn("provider", "varchar(32)", (col) => col.notNull())
53
+ .addColumn("bucket", "varchar(255)", (col) => col.notNull())
54
+ .addColumn("object_key", "varchar(1024)", (col) => col.notNull())
55
+ .addColumn("size", "bigint", (col) => col.notNull())
56
+ .addColumn("mime_type", "varchar(255)")
57
+ .addColumn("sha256", "varchar(64)")
58
+ .addColumn("etag", "varchar(255)")
59
+ .addColumn("storage_class", "varchar(32)")
60
+ .addColumn("status", "varchar(16)", (col) => col.notNull())
61
+ .addColumn("created_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
62
+ .addColumn("updated_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
63
+ .addColumn("deleted_at", "timestamp")
64
+ .addColumn("metadata", "text")
65
+ .execute();
66
+ await db.schema
67
+ .createIndex("idx_blobs_sha256")
68
+ .on("blobs")
69
+ .column("sha256")
70
+ .execute();
71
+ await db.schema
72
+ .createIndex("idx_blobs_locator")
73
+ .on("blobs")
74
+ .columns(["provider", "bucket", "object_key"])
75
+ .unique()
76
+ .execute();
77
+ await db.schema
78
+ .createTable("blob_references")
79
+ .addColumn("id", "varchar(36)", (col) => col.primaryKey())
80
+ .addColumn("blob_id", "varchar(36)", (col) => col.notNull())
81
+ .addColumn("ref_type", "varchar(64)", (col) => col.notNull())
82
+ .addColumn("ref_id", "varchar(36)", (col) => col.notNull())
83
+ .addColumn("created_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
84
+ .execute();
85
+ await db.schema
86
+ .createIndex("idx_blob_references_blob")
87
+ .on("blob_references")
88
+ .column("blob_id")
89
+ .execute();
90
+ await db.schema
91
+ .createTable("files")
92
+ .addColumn("id", "varchar(36)", (col) => col.primaryKey())
93
+ .addColumn("owner_id", "varchar(255)")
94
+ .addColumn("display_name", "varchar(512)", (col) => col.notNull())
95
+ .addColumn("mime_type", "varchar(255)")
96
+ .addColumn("current_version_id", "varchar(36)")
97
+ .addColumn("size", "bigint")
98
+ .addColumn("parent_id", "varchar(36)")
99
+ .addColumn("status", "varchar(16)", (col) => col.notNull())
100
+ .addColumn("created_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
101
+ .addColumn("updated_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
102
+ .addColumn("deleted_at", "timestamp")
103
+ .addColumn("metadata", "text")
104
+ .execute();
105
+ await db.schema
106
+ .createIndex("idx_files_owner")
107
+ .on("files")
108
+ .column("owner_id")
109
+ .execute();
110
+ await db.schema
111
+ .createIndex("idx_files_parent")
112
+ .on("files")
113
+ .column("parent_id")
114
+ .execute();
115
+ await db.schema
116
+ .createTable("file_versions")
117
+ .addColumn("id", "varchar(36)", (col) => col.primaryKey())
118
+ .addColumn("file_id", "varchar(36)", (col) => col.notNull())
119
+ .addColumn("blob_id", "varchar(36)", (col) => col.notNull())
120
+ .addColumn("version", "integer", (col) => col.notNull())
121
+ .addColumn("size", "bigint", (col) => col.notNull())
122
+ .addColumn("mime_type", "varchar(255)")
123
+ .addColumn("sha256", "varchar(64)")
124
+ .addColumn("created_at", "timestamp", (col) => col.notNull().defaultTo(sql `CURRENT_TIMESTAMP`))
125
+ .addColumn("created_by", "varchar(255)")
126
+ .addColumn("metadata", "text")
127
+ .execute();
128
+ await db.schema
129
+ .createIndex("idx_file_versions_file")
130
+ .on("file_versions")
131
+ .columns(["file_id", "version"])
132
+ .unique()
133
+ .execute();
134
+ }
135
+ export async function down(db) {
136
+ await db.schema.dropTable("file_versions").ifExists().execute();
137
+ await db.schema.dropTable("files").ifExists().execute();
138
+ await db.schema.dropTable("blob_references").ifExists().execute();
139
+ await db.schema.dropTable("blobs").ifExists().execute();
140
+ await db.schema.dropTable("uploaded_parts").ifExists().execute();
141
+ await db.schema.dropTable("upload_sessions").ifExists().execute();
142
+ }
143
+ //# sourceMappingURL=0001_init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"0001_init.js","sourceRoot":"","sources":["../../src/migrations/0001_init.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { up, down } from "./0001_init.js";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/migrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { up, down } from "./0001_init.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC"}