bloko 0.0.47 → 0.0.49
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/sql/schema.sql +49 -0
- package/dist/driver/crud/blocks.d.ts +5 -1
- package/dist/driver/crud/blocks.d.ts.map +1 -1
- package/dist/driver/crud/blocks.js +78 -1
- package/dist/driver/crud/blocks.js.map +1 -1
- package/dist/driver/crud/collections.d.ts +5 -1
- package/dist/driver/crud/collections.d.ts.map +1 -1
- package/dist/driver/crud/collections.js +62 -1
- package/dist/driver/crud/collections.js.map +1 -1
- package/dist/driver/crud/contents.d.ts +4 -1
- package/dist/driver/crud/contents.d.ts.map +1 -1
- package/dist/driver/crud/contents.js +49 -1
- package/dist/driver/crud/contents.js.map +1 -1
- package/dist/driver/crud/image-variants.d.ts +5 -1
- package/dist/driver/crud/image-variants.d.ts.map +1 -1
- package/dist/driver/crud/image-variants.js +89 -1
- package/dist/driver/crud/image-variants.js.map +1 -1
- package/dist/driver/crud/images.d.ts +5 -1
- package/dist/driver/crud/images.d.ts.map +1 -1
- package/dist/driver/crud/images.js +94 -1
- package/dist/driver/crud/images.js.map +1 -1
- package/dist/driver/crud/index.d.ts +43 -0
- package/dist/driver/crud/index.d.ts.map +1 -1
- package/dist/driver/crud/languages.d.ts +5 -1
- package/dist/driver/crud/languages.d.ts.map +1 -1
- package/dist/driver/crud/languages.js +58 -1
- package/dist/driver/crud/languages.js.map +1 -1
- package/dist/driver/crud/node-relation-types.d.ts +5 -1
- package/dist/driver/crud/node-relation-types.d.ts.map +1 -1
- package/dist/driver/crud/node-relation-types.js +70 -1
- package/dist/driver/crud/node-relation-types.js.map +1 -1
- package/dist/driver/crud/node-relations.d.ts +5 -1
- package/dist/driver/crud/node-relations.d.ts.map +1 -1
- package/dist/driver/crud/node-relations.js +62 -1
- package/dist/driver/crud/node-relations.js.map +1 -1
- package/dist/driver/crud/node-types.d.ts +5 -1
- package/dist/driver/crud/node-types.d.ts.map +1 -1
- package/dist/driver/crud/node-types.js +66 -1
- package/dist/driver/crud/node-types.js.map +1 -1
- package/dist/driver/crud/nodes.d.ts +5 -1
- package/dist/driver/crud/nodes.d.ts.map +1 -1
- package/dist/driver/crud/nodes.js +106 -1
- package/dist/driver/crud/nodes.js.map +1 -1
- package/dist/driver/crud/query-builder.d.ts +17 -1
- package/dist/driver/crud/query-builder.d.ts.map +1 -1
- package/dist/driver/crud/query-builder.js +96 -0
- package/dist/driver/crud/query-builder.js.map +1 -1
- package/dist/driver/crud/templates.d.ts +5 -1
- package/dist/driver/crud/templates.d.ts.map +1 -1
- package/dist/driver/crud/templates.js +70 -1
- package/dist/driver/crud/templates.js.map +1 -1
- package/dist/driver/types.d.ts +16 -0
- package/dist/driver/types.d.ts.map +1 -1
- package/package.json +6 -3
package/dist/cli/sql/schema.sql
CHANGED
|
@@ -465,3 +465,52 @@ CREATE TRIGGER trigger_node_relation_validate
|
|
|
465
465
|
BEFORE INSERT OR UPDATE ON node_relations
|
|
466
466
|
FOR EACH ROW
|
|
467
467
|
EXECUTE FUNCTION validate_node_relation();
|
|
468
|
+
|
|
469
|
+
-- Slugify all slug values (ensures URL-safe slugs even when manually set)
|
|
470
|
+
CREATE OR REPLACE FUNCTION slugify_node_slug()
|
|
471
|
+
RETURNS TRIGGER AS $$
|
|
472
|
+
DECLARE
|
|
473
|
+
lang TEXT;
|
|
474
|
+
slug_value TEXT;
|
|
475
|
+
base_slug TEXT;
|
|
476
|
+
final_slug TEXT;
|
|
477
|
+
counter INTEGER;
|
|
478
|
+
BEGIN
|
|
479
|
+
IF NEW.slug IS NOT NULL THEN
|
|
480
|
+
FOR lang IN SELECT jsonb_object_keys(NEW.slug)
|
|
481
|
+
LOOP
|
|
482
|
+
slug_value := NEW.slug->>lang;
|
|
483
|
+
IF slug_value IS NOT NULL AND slug_value != '' THEN
|
|
484
|
+
-- Remove accents, convert to lowercase, replace non-alphanumeric with hyphens
|
|
485
|
+
base_slug := lower(regexp_replace(unaccent(slug_value), '[^a-zA-Z0-9]+', '-', 'g'));
|
|
486
|
+
base_slug := trim(both '-' from base_slug);
|
|
487
|
+
-- Collapse multiple hyphens
|
|
488
|
+
base_slug := regexp_replace(base_slug, '-+', '-', 'g');
|
|
489
|
+
|
|
490
|
+
-- Check for uniqueness within same parent
|
|
491
|
+
final_slug := base_slug;
|
|
492
|
+
counter := 0;
|
|
493
|
+
|
|
494
|
+
WHILE EXISTS (
|
|
495
|
+
SELECT 1 FROM nodes
|
|
496
|
+
WHERE id != NEW.id
|
|
497
|
+
AND COALESCE(_parent, '00000000-0000-0000-0000-000000000000') =
|
|
498
|
+
COALESCE(NEW._parent, '00000000-0000-0000-0000-000000000000')
|
|
499
|
+
AND slug->>lang = final_slug
|
|
500
|
+
) LOOP
|
|
501
|
+
counter := counter + 1;
|
|
502
|
+
final_slug := base_slug || '-' || counter;
|
|
503
|
+
END LOOP;
|
|
504
|
+
|
|
505
|
+
NEW.slug := NEW.slug || jsonb_build_object(lang, final_slug);
|
|
506
|
+
END IF;
|
|
507
|
+
END LOOP;
|
|
508
|
+
END IF;
|
|
509
|
+
RETURN NEW;
|
|
510
|
+
END;
|
|
511
|
+
$$ LANGUAGE plpgsql;
|
|
512
|
+
|
|
513
|
+
CREATE TRIGGER trigger_node_slug_slugify
|
|
514
|
+
BEFORE INSERT OR UPDATE OF slug ON nodes
|
|
515
|
+
FOR EACH ROW
|
|
516
|
+
EXECUTE FUNCTION slugify_node_slug();
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Block, BlockInsert, BlockUpdate, QueryOptions, CountOptions } from '../types.js';
|
|
2
|
+
import type { Block, BlockInsert, BlockUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function blocks(db: DB): {
|
|
4
4
|
findMany(options?: QueryOptions<Block>): Promise<Block[]>;
|
|
5
5
|
findFirst(options: QueryOptions<Block>): Promise<Block | null>;
|
|
@@ -11,6 +11,10 @@ export declare function blocks(db: DB): {
|
|
|
11
11
|
create(data: BlockInsert): Promise<Block>;
|
|
12
12
|
update(id: string, data: BlockUpdate): Promise<Block | null>;
|
|
13
13
|
delete(id: string): Promise<boolean>;
|
|
14
|
+
upsert(data: BlockInsert, conflictKeys?: (keyof Block)[]): Promise<Block>;
|
|
15
|
+
deleteMany(where: WhereClause<Block>): Promise<number>;
|
|
16
|
+
createMany(data: BlockInsert[]): Promise<Block[]>;
|
|
17
|
+
updateMany(where: WhereClause<Block>, data: BlockUpdate): Promise<number>;
|
|
14
18
|
findAll(): Promise<Block[]>;
|
|
15
19
|
};
|
|
16
20
|
//# sourceMappingURL=blocks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blocks.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"blocks.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG5G,wBAAgB,MAAM,CAAC,EAAE,EAAE,EAAE;uBAEA,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;uBAMtC,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;iBAKjD,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;+BAKhB,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;2BAI7B,MAAM,QAAQ,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;2BAI5C,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;oBAIhC,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAMxC,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC;eAQ9B,MAAM,QAAQ,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;eA4CjD,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;iBAKvB,WAAW,iBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,GAA2B,OAAO,CAAC,KAAK,CAAC;sBAiB9E,WAAW,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAOrC,WAAW,EAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;sBAmB/B,WAAW,CAAC,KAAK,CAAC,QAAQ,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC;eA0B9D,OAAO,CAAC,KAAK,EAAE,CAAC;EAIpC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { buildSelectQuery, buildCountQuery } from './query-builder.js';
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
2
2
|
export function blocks(db) {
|
|
3
3
|
return {
|
|
4
4
|
async findMany(options) {
|
|
@@ -74,6 +74,83 @@ export function blocks(db) {
|
|
|
74
74
|
const result = await db.query('DELETE FROM blocks WHERE id = $1', [id]);
|
|
75
75
|
return (result.rowCount ?? 0) > 0;
|
|
76
76
|
},
|
|
77
|
+
async upsert(data, conflictKeys = ['_template', 'code']) {
|
|
78
|
+
const columns = ['_template', '_parent', 'code', 'title', 'content_type', 'sort', 'notes'];
|
|
79
|
+
const values = [data._template, data._parent, data.code, data.title, data.content_type, data.sort, data.notes];
|
|
80
|
+
const placeholders = columns.map((_, i) => `$${i + 1}`);
|
|
81
|
+
const updateColumns = columns.filter(col => !conflictKeys.includes(col));
|
|
82
|
+
const updateClauses = updateColumns.map(col => `${col} = EXCLUDED.${col}`);
|
|
83
|
+
let sql = `INSERT INTO blocks (${columns.join(', ')}) VALUES (${placeholders.join(', ')})`;
|
|
84
|
+
sql += ` ON CONFLICT (${conflictKeys.join(', ')})`;
|
|
85
|
+
sql += updateClauses.length > 0 ? ` DO UPDATE SET ${updateClauses.join(', ')}` : ' DO NOTHING';
|
|
86
|
+
sql += ' RETURNING *';
|
|
87
|
+
const result = await db.query(sql, values);
|
|
88
|
+
return result.rows[0];
|
|
89
|
+
},
|
|
90
|
+
async deleteMany(where) {
|
|
91
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
92
|
+
const sql = whereClause ? `DELETE FROM blocks WHERE ${whereClause}` : 'DELETE FROM blocks';
|
|
93
|
+
const result = await db.query(sql, params);
|
|
94
|
+
return result.rowCount ?? 0;
|
|
95
|
+
},
|
|
96
|
+
async createMany(data) {
|
|
97
|
+
if (data.length === 0)
|
|
98
|
+
return [];
|
|
99
|
+
const columns = ['_template', '_parent', 'code', 'title', 'content_type', 'sort', 'notes'];
|
|
100
|
+
const values = [];
|
|
101
|
+
const valueRows = [];
|
|
102
|
+
let idx = 1;
|
|
103
|
+
for (const record of data) {
|
|
104
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
105
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
106
|
+
values.push(record._template, record._parent, record.code, record.title, record.content_type, record.sort, record.notes);
|
|
107
|
+
}
|
|
108
|
+
const sql = `INSERT INTO blocks (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
109
|
+
const result = await db.query(sql, values);
|
|
110
|
+
return result.rows;
|
|
111
|
+
},
|
|
112
|
+
async updateMany(where, data) {
|
|
113
|
+
const setClauses = [];
|
|
114
|
+
const values = [];
|
|
115
|
+
let idx = 1;
|
|
116
|
+
if (data._template !== undefined) {
|
|
117
|
+
setClauses.push(`_template = $${idx++}`);
|
|
118
|
+
values.push(data._template);
|
|
119
|
+
}
|
|
120
|
+
if (data._parent !== undefined) {
|
|
121
|
+
setClauses.push(`_parent = $${idx++}`);
|
|
122
|
+
values.push(data._parent);
|
|
123
|
+
}
|
|
124
|
+
if (data.code !== undefined) {
|
|
125
|
+
setClauses.push(`code = $${idx++}`);
|
|
126
|
+
values.push(data.code);
|
|
127
|
+
}
|
|
128
|
+
if (data.title !== undefined) {
|
|
129
|
+
setClauses.push(`title = $${idx++}`);
|
|
130
|
+
values.push(data.title);
|
|
131
|
+
}
|
|
132
|
+
if (data.content_type !== undefined) {
|
|
133
|
+
setClauses.push(`content_type = $${idx++}`);
|
|
134
|
+
values.push(data.content_type);
|
|
135
|
+
}
|
|
136
|
+
if (data.sort !== undefined) {
|
|
137
|
+
setClauses.push(`sort = $${idx++}`);
|
|
138
|
+
values.push(data.sort);
|
|
139
|
+
}
|
|
140
|
+
if (data.notes !== undefined) {
|
|
141
|
+
setClauses.push(`notes = $${idx++}`);
|
|
142
|
+
values.push(data.notes);
|
|
143
|
+
}
|
|
144
|
+
if (setClauses.length === 0)
|
|
145
|
+
return 0;
|
|
146
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
147
|
+
values.push(...whereParams);
|
|
148
|
+
let sql = `UPDATE blocks SET ${setClauses.join(', ')}`;
|
|
149
|
+
if (whereClause)
|
|
150
|
+
sql += ` WHERE ${whereClause}`;
|
|
151
|
+
const result = await db.query(sql, values);
|
|
152
|
+
return result.rowCount ?? 0;
|
|
153
|
+
},
|
|
77
154
|
// Backward compatibility alias
|
|
78
155
|
async findAll() {
|
|
79
156
|
return this.findMany();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blocks.js","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"blocks.js","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Collection, CollectionInsert, CollectionUpdate, QueryOptions, CountOptions } from '../types.js';
|
|
2
|
+
import type { Collection, CollectionInsert, CollectionUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function collections(db: DB): {
|
|
4
4
|
findMany(options?: QueryOptions<Collection>): Promise<Collection[]>;
|
|
5
5
|
findFirst(options: QueryOptions<Collection>): Promise<Collection | null>;
|
|
@@ -9,6 +9,10 @@ export declare function collections(db: DB): {
|
|
|
9
9
|
create(data: CollectionInsert): Promise<Collection>;
|
|
10
10
|
update(id: string, data: CollectionUpdate): Promise<Collection | null>;
|
|
11
11
|
delete(id: string): Promise<boolean>;
|
|
12
|
+
upsert(data: CollectionInsert, conflictKeys?: (keyof Collection)[]): Promise<Collection>;
|
|
13
|
+
deleteMany(where: WhereClause<Collection>): Promise<number>;
|
|
14
|
+
createMany(data: CollectionInsert[]): Promise<Collection[]>;
|
|
15
|
+
updateMany(where: WhereClause<Collection>, data: CollectionUpdate): Promise<number>;
|
|
12
16
|
findAll(): Promise<Collection[]>;
|
|
13
17
|
};
|
|
14
18
|
//# sourceMappingURL=collections.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collections.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"collections.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG3H,wBAAgB,WAAW,CAAC,EAAE,EAAE,EAAE;uBAEL,YAAY,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;uBAMhD,YAAY,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;iBAK3D,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;qBAK/B,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;oBAKpC,YAAY,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAM7C,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC;eAiBxC,MAAM,QAAQ,gBAAgB,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;eA4B3D,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;iBAKvB,gBAAgB,iBAAgB,CAAC,MAAM,UAAU,CAAC,EAAE,GAAc,OAAO,CAAC,UAAU,CAAC;sBAiBhF,WAAW,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAO1C,gBAAgB,EAAE,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;sBAmBzC,WAAW,CAAC,UAAU,CAAC,QAAQ,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC;eA+BxE,OAAO,CAAC,UAAU,EAAE,CAAC;EAIzC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { buildSelectQuery, buildCountQuery } from './query-builder.js';
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
2
2
|
export function collections(db) {
|
|
3
3
|
return {
|
|
4
4
|
async findMany(options) {
|
|
@@ -59,6 +59,67 @@ export function collections(db) {
|
|
|
59
59
|
const result = await db.query('DELETE FROM collections WHERE id = $1', [id]);
|
|
60
60
|
return (result.rowCount ?? 0) > 0;
|
|
61
61
|
},
|
|
62
|
+
async upsert(data, conflictKeys = ['code']) {
|
|
63
|
+
const columns = ['code', 'sort', 'notes'];
|
|
64
|
+
const values = [data.code, data.sort, data.notes];
|
|
65
|
+
const placeholders = columns.map((_, i) => `$${i + 1}`);
|
|
66
|
+
const updateColumns = columns.filter(col => !conflictKeys.includes(col));
|
|
67
|
+
const updateClauses = updateColumns.map(col => `${col} = EXCLUDED.${col}`);
|
|
68
|
+
let sql = `INSERT INTO collections (${columns.join(', ')}) VALUES (${placeholders.join(', ')})`;
|
|
69
|
+
sql += ` ON CONFLICT (${conflictKeys.join(', ')})`;
|
|
70
|
+
sql += updateClauses.length > 0 ? ` DO UPDATE SET ${updateClauses.join(', ')}` : ' DO NOTHING';
|
|
71
|
+
sql += ' RETURNING *';
|
|
72
|
+
const result = await db.query(sql, values);
|
|
73
|
+
return result.rows[0];
|
|
74
|
+
},
|
|
75
|
+
async deleteMany(where) {
|
|
76
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
77
|
+
const sql = whereClause ? `DELETE FROM collections WHERE ${whereClause}` : 'DELETE FROM collections';
|
|
78
|
+
const result = await db.query(sql, params);
|
|
79
|
+
return result.rowCount ?? 0;
|
|
80
|
+
},
|
|
81
|
+
async createMany(data) {
|
|
82
|
+
if (data.length === 0)
|
|
83
|
+
return [];
|
|
84
|
+
const columns = ['code', 'sort', 'notes'];
|
|
85
|
+
const values = [];
|
|
86
|
+
const valueRows = [];
|
|
87
|
+
let idx = 1;
|
|
88
|
+
for (const record of data) {
|
|
89
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
90
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
91
|
+
values.push(record.code, record.sort, record.notes);
|
|
92
|
+
}
|
|
93
|
+
const sql = `INSERT INTO collections (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
94
|
+
const result = await db.query(sql, values);
|
|
95
|
+
return result.rows;
|
|
96
|
+
},
|
|
97
|
+
async updateMany(where, data) {
|
|
98
|
+
const setClauses = [];
|
|
99
|
+
const values = [];
|
|
100
|
+
let idx = 1;
|
|
101
|
+
if (data.code !== undefined) {
|
|
102
|
+
setClauses.push(`code = $${idx++}`);
|
|
103
|
+
values.push(data.code);
|
|
104
|
+
}
|
|
105
|
+
if (data.sort !== undefined) {
|
|
106
|
+
setClauses.push(`sort = $${idx++}`);
|
|
107
|
+
values.push(data.sort);
|
|
108
|
+
}
|
|
109
|
+
if (data.notes !== undefined) {
|
|
110
|
+
setClauses.push(`notes = $${idx++}`);
|
|
111
|
+
values.push(data.notes);
|
|
112
|
+
}
|
|
113
|
+
if (setClauses.length === 0)
|
|
114
|
+
return 0;
|
|
115
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
116
|
+
values.push(...whereParams);
|
|
117
|
+
let sql = `UPDATE collections SET ${setClauses.join(', ')}`;
|
|
118
|
+
if (whereClause)
|
|
119
|
+
sql += ` WHERE ${whereClause}`;
|
|
120
|
+
const result = await db.query(sql, values);
|
|
121
|
+
return result.rowCount ?? 0;
|
|
122
|
+
},
|
|
62
123
|
// Backward compatibility alias
|
|
63
124
|
async findAll() {
|
|
64
125
|
return this.findMany();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collections.js","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"collections.js","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Content, ContentInsert, ContentUpdate, QueryOptions, CountOptions } from '../types.js';
|
|
2
|
+
import type { Content, ContentInsert, ContentUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function contents(db: DB): {
|
|
4
4
|
findMany(options?: QueryOptions<Content>): Promise<Content[]>;
|
|
5
5
|
findFirst(options: QueryOptions<Content>): Promise<Content | null>;
|
|
@@ -13,6 +13,9 @@ export declare function contents(db: DB): {
|
|
|
13
13
|
update(id: string, data: ContentUpdate): Promise<Content | null>;
|
|
14
14
|
delete(id: string): Promise<boolean>;
|
|
15
15
|
deleteByNode(nodeId: string): Promise<number>;
|
|
16
|
+
deleteMany(where: WhereClause<Content>): Promise<number>;
|
|
17
|
+
createMany(data: ContentInsert[]): Promise<Content[]>;
|
|
18
|
+
updateMany(where: WhereClause<Content>, data: ContentUpdate): Promise<number>;
|
|
16
19
|
findAll(): Promise<Content[]>;
|
|
17
20
|
};
|
|
18
21
|
//# sourceMappingURL=contents.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contents.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"contents.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAGlH,wBAAgB,QAAQ,CAAC,EAAE,EAAE,EAAE;uBAEF,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;uBAM1C,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;iBAKrD,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;uBAK1B,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;yBAIzB,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;+BAIrB,MAAM,WAAW,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;oBAI5D,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAM1C,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC;iBAQhC,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC;eAUlC,MAAM,QAAQ,aAAa,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;eA4BrD,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;yBAKf,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;sBAK3B,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAOvC,aAAa,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;sBAmBnC,WAAW,CAAC,OAAO,CAAC,QAAQ,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC;eA+BlE,OAAO,CAAC,OAAO,EAAE,CAAC;EAItC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { buildSelectQuery, buildCountQuery } from './query-builder.js';
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
2
2
|
export function contents(db) {
|
|
3
3
|
return {
|
|
4
4
|
async findMany(options) {
|
|
@@ -68,6 +68,54 @@ export function contents(db) {
|
|
|
68
68
|
const result = await db.query('DELETE FROM contents WHERE _node = $1', [nodeId]);
|
|
69
69
|
return result.rowCount ?? 0;
|
|
70
70
|
},
|
|
71
|
+
async deleteMany(where) {
|
|
72
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
73
|
+
const sql = whereClause ? `DELETE FROM contents WHERE ${whereClause}` : 'DELETE FROM contents';
|
|
74
|
+
const result = await db.query(sql, params);
|
|
75
|
+
return result.rowCount ?? 0;
|
|
76
|
+
},
|
|
77
|
+
async createMany(data) {
|
|
78
|
+
if (data.length === 0)
|
|
79
|
+
return [];
|
|
80
|
+
const columns = ['_node', '_block', 'value'];
|
|
81
|
+
const values = [];
|
|
82
|
+
const valueRows = [];
|
|
83
|
+
let idx = 1;
|
|
84
|
+
for (const record of data) {
|
|
85
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
86
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
87
|
+
values.push(record._node, record._block, JSON.stringify(record.value));
|
|
88
|
+
}
|
|
89
|
+
const sql = `INSERT INTO contents (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
90
|
+
const result = await db.query(sql, values);
|
|
91
|
+
return result.rows;
|
|
92
|
+
},
|
|
93
|
+
async updateMany(where, data) {
|
|
94
|
+
const setClauses = [];
|
|
95
|
+
const values = [];
|
|
96
|
+
let idx = 1;
|
|
97
|
+
if (data._node !== undefined) {
|
|
98
|
+
setClauses.push(`_node = $${idx++}`);
|
|
99
|
+
values.push(data._node);
|
|
100
|
+
}
|
|
101
|
+
if (data._block !== undefined) {
|
|
102
|
+
setClauses.push(`_block = $${idx++}`);
|
|
103
|
+
values.push(data._block);
|
|
104
|
+
}
|
|
105
|
+
if (data.value !== undefined) {
|
|
106
|
+
setClauses.push(`value = $${idx++}`);
|
|
107
|
+
values.push(JSON.stringify(data.value));
|
|
108
|
+
}
|
|
109
|
+
if (setClauses.length === 0)
|
|
110
|
+
return 0;
|
|
111
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
112
|
+
values.push(...whereParams);
|
|
113
|
+
let sql = `UPDATE contents SET ${setClauses.join(', ')}`;
|
|
114
|
+
if (whereClause)
|
|
115
|
+
sql += ` WHERE ${whereClause}`;
|
|
116
|
+
const result = await db.query(sql, values);
|
|
117
|
+
return result.rowCount ?? 0;
|
|
118
|
+
},
|
|
71
119
|
// Backward compatibility alias
|
|
72
120
|
async findAll() {
|
|
73
121
|
return this.findMany();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contents.js","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"contents.js","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEzF,MAAM,UAAU,QAAQ,CAAC,EAAM;IAC7B,OAAO;QACL,KAAK,CAAC,QAAQ,CAAC,OAA+B;YAC5C,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,gBAAgB,CAAC,UAAU,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;YAClE,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;QACrB,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,OAA8B;YAC5C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;YAC5D,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAC3B,CAAC;QAED,KAAK,CAAC,QAAQ,CAAC,EAAU;YACvB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,sCAAsC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5E,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,MAAc;YAC7B,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAS,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,KAAK,CAAC,WAAW,CAAC,OAAe;YAC/B,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAS,EAAE,CAAC,CAAC;QAC9D,CAAC;QAED,KAAK,CAAC,kBAAkB,CAAC,MAAc,EAAE,OAAe;YACtD,OAAO,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAS,EAAE,CAAC,CAAC;QAC9E,CAAC;QAED,KAAK,CAAC,KAAK,CAAC,OAA+B;YACzC,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,eAAe,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;YAC7D,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAC5C,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,IAAmB;YAC9B,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B,6EAA6E,EAC7E,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACtD,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,IAAmB;YAC9B,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B;;qBAEa,EACb,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACtD,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAU,EAAE,IAAmB;YAC1C,MAAM,MAAM,GAAa,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAc,EAAE,CAAC;YAC7B,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC7B,MAAM,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,EAAE,CAAC,CAAC;gBACjC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,MAAM,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAClC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;YACD,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC7B,MAAM,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,EAAE,CAAC,CAAC;gBACjC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;YAC1C,CAAC;YAED,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAElD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B,uBAAuB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,GAAG,cAAc,EACzE,MAAM,CACP,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAU;YACrB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,oCAAoC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAC1E,OAAO,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;QAED,KAAK,CAAC,YAAY,CAAC,MAAc;YAC/B,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,uCAAuC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;YACjF,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,KAA2B;YAC1C,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAChE,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,8BAA8B,WAAW,EAAE,CAAC,CAAC,CAAC,sBAAsB,CAAC;YAC/F,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,IAAqB;YACpC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,EAAE,CAAC;YAEjC,MAAM,OAAO,GAAG,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;YAC7C,MAAM,MAAM,GAAc,EAAE,CAAC;YAC7B,MAAM,SAAS,GAAa,EAAE,CAAC;YAC/B,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,KAAK,MAAM,MAAM,IAAI,IAAI,EAAE,CAAC;gBAC1B,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,EAAE,EAAE,CAAC,CAAC;gBACpD,SAAS,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC/C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACzE,CAAC;YAED,MAAM,GAAG,GAAG,yBAAyB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;YACtG,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;QACrB,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,KAA2B,EAAE,IAAmB;YAC/D,MAAM,UAAU,GAAa,EAAE,CAAC;YAChC,MAAM,MAAM,GAAc,EAAE,CAAC;YAC7B,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC7B,UAAU,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,EAAE,CAAC,CAAC;gBACrC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,UAAU,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBACtC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;YACD,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC7B,UAAU,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,EAAE,CAAC,CAAC;gBACrC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;YAC1C,CAAC;YAED,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,CAAC,CAAC;YAEtC,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,gBAAgB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YAC/E,MAAM,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;YAE5B,IAAI,GAAG,GAAG,uBAAuB,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YACzD,IAAI,WAAW;gBAAE,GAAG,IAAI,UAAU,WAAW,EAAE,CAAC;YAEhD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,+BAA+B;QAC/B,KAAK,CAAC,OAAO;YACX,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzB,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { ImageVariant, ImageVariantInsert, ImageVariantUpdate, QueryOptions, CountOptions } from '../types.js';
|
|
2
|
+
import type { ImageVariant, ImageVariantInsert, ImageVariantUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function imageVariants(db: DB): {
|
|
4
4
|
findMany(options?: QueryOptions<ImageVariant>): Promise<ImageVariant[]>;
|
|
5
5
|
findFirst(options: QueryOptions<ImageVariant>): Promise<ImageVariant | null>;
|
|
@@ -16,6 +16,10 @@ export declare function imageVariants(db: DB): {
|
|
|
16
16
|
update(id: string, data: ImageVariantUpdate): Promise<ImageVariant | null>;
|
|
17
17
|
delete(id: string): Promise<boolean>;
|
|
18
18
|
deleteByImage(imageId: string): Promise<number>;
|
|
19
|
+
upsert(data: ImageVariantInsert, conflictKeys?: (keyof ImageVariant)[]): Promise<ImageVariant>;
|
|
20
|
+
deleteMany(where: WhereClause<ImageVariant>): Promise<number>;
|
|
21
|
+
createMany(data: ImageVariantInsert[]): Promise<ImageVariant[]>;
|
|
22
|
+
updateMany(where: WhereClause<ImageVariant>, data: ImageVariantUpdate): Promise<number>;
|
|
19
23
|
findAll(): Promise<ImageVariant[]>;
|
|
20
24
|
};
|
|
21
25
|
//# sourceMappingURL=image-variants.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"image-variants.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/image-variants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"image-variants.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/image-variants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAGjI,wBAAgB,aAAa,CAAC,EAAE,EAAE,EAAE;uBAEP,YAAY,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;uBAMpD,YAAY,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;iBAK/D,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;yBAK7B,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;uBAIlC,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAI9D;;;OAGG;0BAEQ,MAAM,YACL,MAAM,GAAG,IAAI,aACZ,MAAM,GAAG,IAAI,UAChB,MAAM,WACL,MAAM,GACd,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;oBAaT,YAAY,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAM/C,kBAAkB,GAAG,OAAO,CAAC,YAAY,CAAC;eAsB5C,MAAM,QAAQ,kBAAkB,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;eAoD/D,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;2BAKb,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;iBAKlC,kBAAkB,iBAAgB,CAAC,MAAM,YAAY,CAAC,EAAE,GAAgB,OAAO,CAAC,YAAY,CAAC;sBAoBxF,WAAW,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAO5C,kBAAkB,EAAE,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;sBAsB7C,WAAW,CAAC,YAAY,CAAC,QAAQ,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC;eA4B5E,OAAO,CAAC,YAAY,EAAE,CAAC;EAI3C"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { buildSelectQuery, buildCountQuery } from './query-builder.js';
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
2
2
|
export function imageVariants(db) {
|
|
3
3
|
return {
|
|
4
4
|
async findMany(options) {
|
|
@@ -110,6 +110,94 @@ export function imageVariants(db) {
|
|
|
110
110
|
const result = await db.query('DELETE FROM image_variants WHERE _image = $1', [imageId]);
|
|
111
111
|
return result.rowCount ?? 0;
|
|
112
112
|
},
|
|
113
|
+
async upsert(data, conflictKeys = ['s3_key']) {
|
|
114
|
+
const columns = ['_image', 'req_width', 'req_height', 'format', 'quality', 'actual_width', 'actual_height', 's3_key', 'file_size'];
|
|
115
|
+
const values = [
|
|
116
|
+
data._image, data.req_width, data.req_height, data.format, data.quality,
|
|
117
|
+
data.actual_width, data.actual_height, data.s3_key, data.file_size
|
|
118
|
+
];
|
|
119
|
+
const placeholders = columns.map((_, i) => `$${i + 1}`);
|
|
120
|
+
const updateColumns = columns.filter(col => !conflictKeys.includes(col));
|
|
121
|
+
const updateClauses = updateColumns.map(col => `${col} = EXCLUDED.${col}`);
|
|
122
|
+
let sql = `INSERT INTO image_variants (${columns.join(', ')}) VALUES (${placeholders.join(', ')})`;
|
|
123
|
+
sql += ` ON CONFLICT (${conflictKeys.join(', ')})`;
|
|
124
|
+
sql += updateClauses.length > 0 ? ` DO UPDATE SET ${updateClauses.join(', ')}` : ' DO NOTHING';
|
|
125
|
+
sql += ' RETURNING *';
|
|
126
|
+
const result = await db.query(sql, values);
|
|
127
|
+
return result.rows[0];
|
|
128
|
+
},
|
|
129
|
+
async deleteMany(where) {
|
|
130
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
131
|
+
const sql = whereClause ? `DELETE FROM image_variants WHERE ${whereClause}` : 'DELETE FROM image_variants';
|
|
132
|
+
const result = await db.query(sql, params);
|
|
133
|
+
return result.rowCount ?? 0;
|
|
134
|
+
},
|
|
135
|
+
async createMany(data) {
|
|
136
|
+
if (data.length === 0)
|
|
137
|
+
return [];
|
|
138
|
+
const columns = ['_image', 'req_width', 'req_height', 'format', 'quality', 'actual_width', 'actual_height', 's3_key', 'file_size'];
|
|
139
|
+
const values = [];
|
|
140
|
+
const valueRows = [];
|
|
141
|
+
let idx = 1;
|
|
142
|
+
for (const record of data) {
|
|
143
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
144
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
145
|
+
values.push(record._image, record.req_width, record.req_height, record.format, record.quality, record.actual_width, record.actual_height, record.s3_key, record.file_size);
|
|
146
|
+
}
|
|
147
|
+
const sql = `INSERT INTO image_variants (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
148
|
+
const result = await db.query(sql, values);
|
|
149
|
+
return result.rows;
|
|
150
|
+
},
|
|
151
|
+
async updateMany(where, data) {
|
|
152
|
+
const setClauses = [];
|
|
153
|
+
const values = [];
|
|
154
|
+
let idx = 1;
|
|
155
|
+
if (data._image !== undefined) {
|
|
156
|
+
setClauses.push(`_image = $${idx++}`);
|
|
157
|
+
values.push(data._image);
|
|
158
|
+
}
|
|
159
|
+
if (data.req_width !== undefined) {
|
|
160
|
+
setClauses.push(`req_width = $${idx++}`);
|
|
161
|
+
values.push(data.req_width);
|
|
162
|
+
}
|
|
163
|
+
if (data.req_height !== undefined) {
|
|
164
|
+
setClauses.push(`req_height = $${idx++}`);
|
|
165
|
+
values.push(data.req_height);
|
|
166
|
+
}
|
|
167
|
+
if (data.format !== undefined) {
|
|
168
|
+
setClauses.push(`format = $${idx++}`);
|
|
169
|
+
values.push(data.format);
|
|
170
|
+
}
|
|
171
|
+
if (data.quality !== undefined) {
|
|
172
|
+
setClauses.push(`quality = $${idx++}`);
|
|
173
|
+
values.push(data.quality);
|
|
174
|
+
}
|
|
175
|
+
if (data.actual_width !== undefined) {
|
|
176
|
+
setClauses.push(`actual_width = $${idx++}`);
|
|
177
|
+
values.push(data.actual_width);
|
|
178
|
+
}
|
|
179
|
+
if (data.actual_height !== undefined) {
|
|
180
|
+
setClauses.push(`actual_height = $${idx++}`);
|
|
181
|
+
values.push(data.actual_height);
|
|
182
|
+
}
|
|
183
|
+
if (data.s3_key !== undefined) {
|
|
184
|
+
setClauses.push(`s3_key = $${idx++}`);
|
|
185
|
+
values.push(data.s3_key);
|
|
186
|
+
}
|
|
187
|
+
if (data.file_size !== undefined) {
|
|
188
|
+
setClauses.push(`file_size = $${idx++}`);
|
|
189
|
+
values.push(data.file_size);
|
|
190
|
+
}
|
|
191
|
+
if (setClauses.length === 0)
|
|
192
|
+
return 0;
|
|
193
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
194
|
+
values.push(...whereParams);
|
|
195
|
+
let sql = `UPDATE image_variants SET ${setClauses.join(', ')}`;
|
|
196
|
+
if (whereClause)
|
|
197
|
+
sql += ` WHERE ${whereClause}`;
|
|
198
|
+
const result = await db.query(sql, values);
|
|
199
|
+
return result.rowCount ?? 0;
|
|
200
|
+
},
|
|
113
201
|
// Backward compatibility alias
|
|
114
202
|
async findAll() {
|
|
115
203
|
return this.findMany();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"image-variants.js","sourceRoot":"","sources":["../../../src/driver/crud/image-variants.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"image-variants.js","sourceRoot":"","sources":["../../../src/driver/crud/image-variants.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEzF,MAAM,UAAU,aAAa,CAAC,EAAM;IAClC,OAAO;QACL,KAAK,CAAC,QAAQ,CAAC,OAAoC;YACjD,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,gBAAgB,CAAC,gBAAgB,EAAE,OAAO,EAAE,6BAA6B,CAAC,CAAC;YACnG,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;QACrB,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,OAAmC;YACjD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;YAC5D,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAC3B,CAAC;QAED,KAAK,CAAC,QAAQ,CAAC,EAAU;YACvB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,4CAA4C,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;QAED,KAAK,CAAC,WAAW,CAAC,OAAe;YAC/B,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAS,EAAE,CAAC,CAAC;QAC9D,CAAC;QAED,KAAK,CAAC,WAAW,CAAC,KAAa;YAC7B,OAAO,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,EAAS,EAAE,CAAC,CAAC;QAC7D,CAAC;QAED;;;WAGG;QACH,KAAK,CAAC,YAAY,CAChB,OAAe,EACf,QAAuB,EACvB,SAAwB,EACxB,MAAc,EACd,OAAe;YAEf,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B;;;;;4BAKoB,EACpB,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,CAChD,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;QAED,KAAK,CAAC,KAAK,CAAC,OAAoC;YAC9C,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,eAAe,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC;YACnE,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAC5C,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,IAAwB;YACnC,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B;;;;gEAIwD,EACxD;gBACE,IAAI,CAAC,MAAM;gBACX,IAAI,CAAC,SAAS;gBACd,IAAI,CAAC,UAAU;gBACf,IAAI,CAAC,MAAM;gBACX,IAAI,CAAC,OAAO;gBACZ,IAAI,CAAC,YAAY;gBACjB,IAAI,CAAC,aAAa;gBAClB,IAAI,CAAC,MAAM;gBACX,IAAI,CAAC,SAAS;aACf,CACF,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAU,EAAE,IAAwB;YAC/C,MAAM,MAAM,GAAa,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAc,EAAE,CAAC;YAC7B,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,MAAM,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAClC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;YACD,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;gBACjC,MAAM,CAAC,IAAI,CAAC,gBAAgB,GAAG,EAAE,EAAE,CAAC,CAAC;gBACrC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC9B,CAAC;YACD,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;gBAClC,MAAM,CAAC,IAAI,CAAC,iBAAiB,GAAG,EAAE,EAAE,CAAC,CAAC;gBACtC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC/B,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,MAAM,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAClC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;YACD,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;gBAC/B,MAAM,CAAC,IAAI,CAAC,cAAc,GAAG,EAAE,EAAE,CAAC,CAAC;gBACnC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC5B,CAAC;YACD,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE,CAAC;gBACpC,MAAM,CAAC,IAAI,CAAC,mBAAmB,GAAG,EAAE,EAAE,CAAC,CAAC;gBACxC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,CAAC;YACD,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;gBACrC,MAAM,CAAC,IAAI,CAAC,oBAAoB,GAAG,EAAE,EAAE,CAAC,CAAC;gBACzC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAClC,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,MAAM,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAClC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;YACD,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;gBACjC,MAAM,CAAC,IAAI,CAAC,gBAAgB,GAAG,EAAE,EAAE,CAAC,CAAC;gBACrC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC9B,CAAC;YAED,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAElD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAC3B,6BAA6B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,GAAG,cAAc,EAC/E,MAAM,CACP,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAU;YACrB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,0CAA0C,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAChF,OAAO,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;QAED,KAAK,CAAC,aAAa,CAAC,OAAe;YACjC,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,8CAA8C,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;YACzF,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,IAAwB,EAAE,eAAuC,CAAC,QAAQ,CAAC;YACtF,MAAM,OAAO,GAAG,CAAC,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,eAAe,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;YACnI,MAAM,MAAM,GAAG;gBACb,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO;gBACvE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS;aACnE,CAAC;YACF,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAExD,MAAM,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAyB,CAAC,CAAC,CAAC;YAC/F,MAAM,aAAa,GAAG,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,eAAe,GAAG,EAAE,CAAC,CAAC;YAE3E,IAAI,GAAG,GAAG,+BAA+B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YACnG,GAAG,IAAI,iBAAiB,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YACnD,GAAG,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,kBAAkB,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;YAC/F,GAAG,IAAI,cAAc,CAAC;YAEtB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,KAAgC;YAC/C,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAChE,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,oCAAoC,WAAW,EAAE,CAAC,CAAC,CAAC,4BAA4B,CAAC;YAC3G,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,IAA0B;YACzC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,EAAE,CAAC;YAEjC,MAAM,OAAO,GAAG,CAAC,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,eAAe,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;YACnI,MAAM,MAAM,GAAc,EAAE,CAAC;YAC7B,MAAM,SAAS,GAAa,EAAE,CAAC;YAC/B,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,KAAK,MAAM,MAAM,IAAI,IAAI,EAAE,CAAC;gBAC1B,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,EAAE,EAAE,CAAC,CAAC;gBACpD,SAAS,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC/C,MAAM,CAAC,IAAI,CACT,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,OAAO,EACjF,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAC3E,CAAC;YACJ,CAAC;YAED,MAAM,GAAG,GAAG,+BAA+B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;YAC5G,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;QACrB,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,KAAgC,EAAE,IAAwB;YACzE,MAAM,UAAU,GAAa,EAAE,CAAC;YAChC,MAAM,MAAM,GAAc,EAAE,CAAC;YAC7B,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAAC,CAAC;YACnG,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAAC,CAAC;YAC5G,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAAC,CAAC;YAC/G,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAAC,CAAC;YACnG,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,cAAc,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAAC,CAAC;YACtG,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,mBAAmB,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAAC,CAAC;YACrH,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,oBAAoB,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAAC,CAAC;YACxH,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAAC,CAAC;YACnG,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;gBAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,GAAG,EAAE,EAAE,CAAC,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAAC,CAAC;YAE5G,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,CAAC,CAAC;YAEtC,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,gBAAgB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YAC/E,MAAM,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;YAE5B,IAAI,GAAG,GAAG,6BAA6B,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAC/D,IAAI,WAAW;gBAAE,GAAG,IAAI,UAAU,WAAW,EAAE,CAAC;YAEhD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC9B,CAAC;QAED,+BAA+B;QAC/B,KAAK,CAAC,OAAO;YACX,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzB,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Image, ImageInsert, ImageUpdate, QueryOptions, CountOptions } from '../types.js';
|
|
2
|
+
import type { Image, ImageInsert, ImageUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function images(db: DB): {
|
|
4
4
|
findMany(options?: QueryOptions<Image>): Promise<Image[]>;
|
|
5
5
|
findFirst(options: QueryOptions<Image>): Promise<Image | null>;
|
|
@@ -11,6 +11,10 @@ export declare function images(db: DB): {
|
|
|
11
11
|
create(data: ImageInsert): Promise<Image>;
|
|
12
12
|
update(id: string, data: ImageUpdate): Promise<Image | null>;
|
|
13
13
|
delete(id: string): Promise<boolean>;
|
|
14
|
+
upsert(data: ImageInsert, conflictKeys?: (keyof Image)[]): Promise<Image>;
|
|
15
|
+
deleteMany(where: WhereClause<Image>): Promise<number>;
|
|
16
|
+
createMany(data: ImageInsert[]): Promise<Image[]>;
|
|
17
|
+
updateMany(where: WhereClause<Image>, data: ImageUpdate): Promise<number>;
|
|
14
18
|
findAll(): Promise<Image[]>;
|
|
15
19
|
};
|
|
16
20
|
//# sourceMappingURL=images.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"images.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/images.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"images.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/images.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG5G,wBAAgB,MAAM,CAAC,EAAE,EAAE,EAAE;uBAEA,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;uBAMtC,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;iBAKjD,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;uBAKxB,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;uBAI9B,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;mBAI7B,OAAO,CAAC,KAAK,EAAE,CAAC;oBAIf,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAMxC,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC;eAa9B,MAAM,QAAQ,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;eAwDjD,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;iBAKvB,WAAW,iBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,GAAgB,OAAO,CAAC,KAAK,CAAC;sBAqBnE,WAAW,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAOrC,WAAW,EAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;sBAuB/B,WAAW,CAAC,KAAK,CAAC,QAAQ,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC;eA6B9D,OAAO,CAAC,KAAK,EAAE,CAAC;EAIpC"}
|