@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.
- package/README.md +129 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/mappers/blob-reference-row.mapper.d.ts +7 -0
- package/dist/mappers/blob-reference-row.mapper.d.ts.map +1 -0
- package/dist/mappers/blob-reference-row.mapper.js +13 -0
- package/dist/mappers/blob-reference-row.mapper.js.map +1 -0
- package/dist/mappers/blob-row.mapper.d.ts +7 -0
- package/dist/mappers/blob-row.mapper.d.ts.map +1 -0
- package/dist/mappers/blob-row.mapper.js +27 -0
- package/dist/mappers/blob-row.mapper.js.map +1 -0
- package/dist/mappers/file-row.mapper.d.ts +7 -0
- package/dist/mappers/file-row.mapper.d.ts.map +1 -0
- package/dist/mappers/file-row.mapper.js +25 -0
- package/dist/mappers/file-row.mapper.js.map +1 -0
- package/dist/mappers/file-version-row.mapper.d.ts +7 -0
- package/dist/mappers/file-version-row.mapper.d.ts.map +1 -0
- package/dist/mappers/file-version-row.mapper.js +23 -0
- package/dist/mappers/file-version-row.mapper.js.map +1 -0
- package/dist/mappers/index.d.ts +7 -0
- package/dist/mappers/index.d.ts.map +1 -0
- package/dist/mappers/index.js +7 -0
- package/dist/mappers/index.js.map +1 -0
- package/dist/mappers/upload-session-row.mapper.d.ts +7 -0
- package/dist/mappers/upload-session-row.mapper.d.ts.map +1 -0
- package/dist/mappers/upload-session-row.mapper.js +33 -0
- package/dist/mappers/upload-session-row.mapper.js.map +1 -0
- package/dist/mappers/uploaded-part-row.mapper.d.ts +7 -0
- package/dist/mappers/uploaded-part-row.mapper.d.ts.map +1 -0
- package/dist/mappers/uploaded-part-row.mapper.js +22 -0
- package/dist/mappers/uploaded-part-row.mapper.js.map +1 -0
- package/dist/metadata/index.d.ts +5 -0
- package/dist/metadata/index.d.ts.map +1 -0
- package/dist/metadata/index.js +5 -0
- package/dist/metadata/index.js.map +1 -0
- package/dist/metadata/kysely-metadata-store.d.ts +13 -0
- package/dist/metadata/kysely-metadata-store.d.ts.map +1 -0
- package/dist/metadata/kysely-metadata-store.js +14 -0
- package/dist/metadata/kysely-metadata-store.js.map +1 -0
- package/dist/metadata/stores/index.d.ts +4 -0
- package/dist/metadata/stores/index.d.ts.map +1 -0
- package/dist/metadata/stores/index.js +4 -0
- package/dist/metadata/stores/index.js.map +1 -0
- package/dist/metadata/stores/kysely-blob-store.d.ts +17 -0
- package/dist/metadata/stores/kysely-blob-store.d.ts.map +1 -0
- package/dist/metadata/stores/kysely-blob-store.js +105 -0
- package/dist/metadata/stores/kysely-blob-store.js.map +1 -0
- package/dist/metadata/stores/kysely-file-store.d.ts +16 -0
- package/dist/metadata/stores/kysely-file-store.d.ts.map +1 -0
- package/dist/metadata/stores/kysely-file-store.js +112 -0
- package/dist/metadata/stores/kysely-file-store.js.map +1 -0
- package/dist/metadata/stores/kysely-upload-session-store.d.ts +15 -0
- package/dist/metadata/stores/kysely-upload-session-store.d.ts.map +1 -0
- package/dist/metadata/stores/kysely-upload-session-store.js +110 -0
- package/dist/metadata/stores/kysely-upload-session-store.js.map +1 -0
- package/dist/migrations/0001_init.d.ts +4 -0
- package/dist/migrations/0001_init.d.ts.map +1 -0
- package/dist/migrations/0001_init.js +143 -0
- package/dist/migrations/0001_init.js.map +1 -0
- package/dist/migrations/index.d.ts +2 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +2 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/schema/database.d.ts +92 -0
- package/dist/schema/database.d.ts.map +1 -0
- package/dist/schema/database.js +2 -0
- package/dist/schema/database.js.map +1 -0
- package/dist/schema/index.d.ts +2 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +2 -0
- package/dist/schema/index.js.map +1 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC"}
|