@revealui/db 0.3.0 → 0.3.3
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/cleanup/cross-db-cleanup.d.ts +19 -0
- package/dist/cleanup/cross-db-cleanup.d.ts.map +1 -1
- package/dist/cleanup/cross-db-cleanup.js +40 -1
- package/dist/cleanup/cross-db-cleanup.js.map +1 -1
- package/dist/cleanup/index.d.ts +2 -1
- package/dist/cleanup/index.d.ts.map +1 -1
- package/dist/cleanup/index.js +2 -1
- package/dist/cleanup/index.js.map +1 -1
- package/dist/cleanup/rag-site-cleanup.d.ts +58 -0
- package/dist/cleanup/rag-site-cleanup.d.ts.map +1 -0
- package/dist/cleanup/rag-site-cleanup.js +68 -0
- package/dist/cleanup/rag-site-cleanup.js.map +1 -0
- package/dist/client/index.d.ts +1 -1
- package/dist/client/index.d.ts.map +1 -1
- package/dist/client/index.js +3 -6
- package/dist/client/index.js.map +1 -1
- package/dist/client/types.d.ts.map +1 -1
- package/dist/pool.d.ts +4 -0
- package/dist/pool.d.ts.map +1 -1
- package/dist/pool.js +46 -20
- package/dist/pool.js.map +1 -1
- package/dist/queries/conversations.d.ts +29 -0
- package/dist/queries/conversations.d.ts.map +1 -0
- package/dist/queries/conversations.js +80 -0
- package/dist/queries/conversations.js.map +1 -0
- package/dist/queries/orders.d.ts +91 -0
- package/dist/queries/orders.d.ts.map +1 -0
- package/dist/queries/orders.js +36 -0
- package/dist/queries/orders.js.map +1 -0
- package/dist/queries/pages.d.ts.map +1 -1
- package/dist/queries/pages.js +0 -5
- package/dist/queries/pages.js.map +1 -1
- package/dist/queries/posts.d.ts +31 -0
- package/dist/queries/posts.d.ts.map +1 -1
- package/dist/queries/posts.js +21 -0
- package/dist/queries/posts.js.map +1 -1
- package/dist/queries/products.d.ts +102 -0
- package/dist/queries/products.d.ts.map +1 -0
- package/dist/queries/products.js +55 -0
- package/dist/queries/products.js.map +1 -0
- package/dist/queries/ticket-comments.d.ts +25 -0
- package/dist/queries/ticket-comments.d.ts.map +1 -1
- package/dist/queries/ticket-comments.js +28 -1
- package/dist/queries/ticket-comments.js.map +1 -1
- package/dist/queries/tickets.d.ts +41 -0
- package/dist/queries/tickets.d.ts.map +1 -1
- package/dist/queries/tickets.js +24 -0
- package/dist/queries/tickets.js.map +1 -1
- package/dist/queries/users.d.ts +118 -0
- package/dist/queries/users.d.ts.map +1 -1
- package/dist/queries/users.js +51 -1
- package/dist/queries/users.js.map +1 -1
- package/dist/schema/accounts.d.ts.map +1 -1
- package/dist/schema/accounts.js +2 -0
- package/dist/schema/accounts.js.map +1 -1
- package/dist/schema/agents.d.ts +133 -0
- package/dist/schema/agents.d.ts.map +1 -1
- package/dist/schema/agents.js +28 -2
- package/dist/schema/agents.js.map +1 -1
- package/dist/schema/circuit-breaker.d.ts +139 -0
- package/dist/schema/circuit-breaker.d.ts.map +1 -0
- package/dist/schema/circuit-breaker.js +28 -0
- package/dist/schema/circuit-breaker.js.map +1 -0
- package/dist/schema/crdt-operations.d.ts.map +1 -1
- package/dist/schema/crdt-operations.js +5 -2
- package/dist/schema/crdt-operations.js.map +1 -1
- package/dist/schema/index.d.ts +7 -0
- package/dist/schema/index.d.ts.map +1 -1
- package/dist/schema/index.js +24 -4
- package/dist/schema/index.js.map +1 -1
- package/dist/schema/licenses.d.ts +34 -0
- package/dist/schema/licenses.d.ts.map +1 -1
- package/dist/schema/licenses.js +7 -1
- package/dist/schema/licenses.js.map +1 -1
- package/dist/schema/marketplace.d.ts.map +1 -1
- package/dist/schema/marketplace.js +6 -2
- package/dist/schema/marketplace.js.map +1 -1
- package/dist/schema/passkeys.d.ts.map +1 -1
- package/dist/schema/passkeys.js +1 -0
- package/dist/schema/passkeys.js.map +1 -1
- package/dist/schema/products.d.ts +536 -0
- package/dist/schema/products.d.ts.map +1 -0
- package/dist/schema/products.js +104 -0
- package/dist/schema/products.js.map +1 -0
- package/dist/schema/rest.d.ts +4 -1
- package/dist/schema/rest.d.ts.map +1 -1
- package/dist/schema/rest.js +6 -3
- package/dist/schema/rest.js.map +1 -1
- package/dist/schema/revealcoin.d.ts +267 -0
- package/dist/schema/revealcoin.d.ts.map +1 -0
- package/dist/schema/revealcoin.js +54 -0
- package/dist/schema/revealcoin.js.map +1 -0
- package/dist/schema/sites.d.ts.map +1 -1
- package/dist/schema/sites.js +2 -7
- package/dist/schema/sites.js.map +1 -1
- package/dist/schema/tenants.d.ts.map +1 -1
- package/dist/schema/tenants.js +0 -1
- package/dist/schema/tenants.js.map +1 -1
- package/dist/schema/tickets.d.ts.map +1 -1
- package/dist/schema/tickets.js +5 -2
- package/dist/schema/tickets.js.map +1 -1
- package/dist/schema/users.d.ts +17 -0
- package/dist/schema/users.d.ts.map +1 -1
- package/dist/schema/users.js +2 -2
- package/dist/schema/users.js.map +1 -1
- package/dist/schema/vector.d.ts +10 -4
- package/dist/schema/vector.d.ts.map +1 -1
- package/dist/schema/vector.js +14 -5
- package/dist/schema/vector.js.map +1 -1
- package/dist/types/database.d.ts +80 -2
- package/dist/types/database.d.ts.map +1 -1
- package/dist/types/database.js +17 -1
- package/dist/types/database.js.map +1 -1
- package/dist/types/generate-contracts.js +1 -1
- package/dist/validation/cross-db.d.ts +6 -6
- package/dist/validation/cross-db.d.ts.map +1 -1
- package/dist/validation/cross-db.js.map +1 -1
- package/package.json +38 -9
- package/dist/queries/optimized-queries.d.ts +0 -89
- package/dist/queries/optimized-queries.d.ts.map +0 -1
- package/dist/queries/optimized-queries.js +0 -371
- package/dist/queries/optimized-queries.js.map +0 -1
- package/dist/queries/todos.d.ts +0 -37
- package/dist/queries/todos.d.ts.map +0 -1
- package/dist/queries/todos.js +0 -37
- package/dist/queries/todos.js.map +0 -1
- package/dist/schema/query.d.ts +0 -11
- package/dist/schema/query.d.ts.map +0 -1
- package/dist/schema/query.js +0 -11
- package/dist/schema/query.js.map +0 -1
- package/dist/schema/todos.d.ts +0 -98
- package/dist/schema/todos.d.ts.map +0 -1
- package/dist/schema/todos.js +0 -12
- package/dist/schema/todos.js.map +0 -1
- package/dist/security-audit-storage.d.ts +0 -54
- package/dist/security-audit-storage.d.ts.map +0 -1
- package/dist/security-audit-storage.js +0 -100
- package/dist/security-audit-storage.js.map +0 -1
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Conversation database queries
|
|
3
|
+
*/
|
|
4
|
+
import { and, desc, eq } from 'drizzle-orm';
|
|
5
|
+
import { conversations, messages } from '../schema/agents.js';
|
|
6
|
+
export async function getConversations(db, userId, options = {}) {
|
|
7
|
+
const { limit = 50, offset = 0 } = options;
|
|
8
|
+
return db
|
|
9
|
+
.select()
|
|
10
|
+
.from(conversations)
|
|
11
|
+
.where(and(eq(conversations.userId, userId), eq(conversations.status, 'active')))
|
|
12
|
+
.orderBy(desc(conversations.updatedAt))
|
|
13
|
+
.limit(limit)
|
|
14
|
+
.offset(offset);
|
|
15
|
+
}
|
|
16
|
+
export async function getConversationById(db, id, userId) {
|
|
17
|
+
const result = await db
|
|
18
|
+
.select()
|
|
19
|
+
.from(conversations)
|
|
20
|
+
.where(and(eq(conversations.id, id), eq(conversations.userId, userId)))
|
|
21
|
+
.limit(1);
|
|
22
|
+
return result[0] ?? null;
|
|
23
|
+
}
|
|
24
|
+
export async function createConversation(db, data) {
|
|
25
|
+
const result = await db
|
|
26
|
+
.insert(conversations)
|
|
27
|
+
.values({
|
|
28
|
+
id: data.id,
|
|
29
|
+
userId: data.userId,
|
|
30
|
+
agentId: data.agentId,
|
|
31
|
+
title: data.title ?? 'New conversation',
|
|
32
|
+
status: 'active',
|
|
33
|
+
})
|
|
34
|
+
.returning();
|
|
35
|
+
return result[0] ?? null;
|
|
36
|
+
}
|
|
37
|
+
export async function updateConversationTitle(db, id, userId, title) {
|
|
38
|
+
const result = await db
|
|
39
|
+
.update(conversations)
|
|
40
|
+
.set({ title, updatedAt: new Date() })
|
|
41
|
+
.where(and(eq(conversations.id, id), eq(conversations.userId, userId)))
|
|
42
|
+
.returning();
|
|
43
|
+
return result[0] ?? null;
|
|
44
|
+
}
|
|
45
|
+
export async function deleteConversation(db, id, userId) {
|
|
46
|
+
// Messages cascade-delete via FK
|
|
47
|
+
const result = await db
|
|
48
|
+
.delete(conversations)
|
|
49
|
+
.where(and(eq(conversations.id, id), eq(conversations.userId, userId)))
|
|
50
|
+
.returning();
|
|
51
|
+
return result[0] ?? null;
|
|
52
|
+
}
|
|
53
|
+
export async function getMessages(db, conversationId, options = {}) {
|
|
54
|
+
const { limit = 200, offset = 0 } = options;
|
|
55
|
+
return db
|
|
56
|
+
.select()
|
|
57
|
+
.from(messages)
|
|
58
|
+
.where(eq(messages.conversationId, conversationId))
|
|
59
|
+
.orderBy(messages.timestamp)
|
|
60
|
+
.limit(limit)
|
|
61
|
+
.offset(offset);
|
|
62
|
+
}
|
|
63
|
+
export async function addMessage(db, data) {
|
|
64
|
+
const result = await db
|
|
65
|
+
.insert(messages)
|
|
66
|
+
.values({
|
|
67
|
+
id: data.id,
|
|
68
|
+
conversationId: data.conversationId,
|
|
69
|
+
role: data.role,
|
|
70
|
+
content: data.content,
|
|
71
|
+
})
|
|
72
|
+
.returning();
|
|
73
|
+
// Touch conversation updatedAt
|
|
74
|
+
await db
|
|
75
|
+
.update(conversations)
|
|
76
|
+
.set({ updatedAt: new Date() })
|
|
77
|
+
.where(eq(conversations.id, data.conversationId));
|
|
78
|
+
return result[0] ?? null;
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=conversations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conversations.js","sourceRoot":"","sources":["../../src/queries/conversations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Order database queries
|
|
3
|
+
*/
|
|
4
|
+
import type { DatabaseClient } from '../client/types.js';
|
|
5
|
+
import { orders } from '../schema/products.js';
|
|
6
|
+
export declare function getAllOrders(db: DatabaseClient, options?: {
|
|
7
|
+
customerId?: string;
|
|
8
|
+
status?: string;
|
|
9
|
+
limit?: number;
|
|
10
|
+
offset?: number;
|
|
11
|
+
}): Promise<{
|
|
12
|
+
id: string;
|
|
13
|
+
customerId: string;
|
|
14
|
+
status: string;
|
|
15
|
+
totalInCents: number;
|
|
16
|
+
currency: string;
|
|
17
|
+
stripePaymentIntentId: string | null;
|
|
18
|
+
stripeCheckoutSessionId: string | null;
|
|
19
|
+
items: {
|
|
20
|
+
productId: string;
|
|
21
|
+
title: string;
|
|
22
|
+
quantity: number;
|
|
23
|
+
priceInCents: number;
|
|
24
|
+
}[];
|
|
25
|
+
shippingAddress: unknown;
|
|
26
|
+
metadata: unknown;
|
|
27
|
+
createdAt: Date;
|
|
28
|
+
updatedAt: Date;
|
|
29
|
+
deletedAt: Date | null;
|
|
30
|
+
}[]>;
|
|
31
|
+
export declare function getOrderById(db: DatabaseClient, id: string): Promise<{
|
|
32
|
+
id: string;
|
|
33
|
+
customerId: string;
|
|
34
|
+
status: string;
|
|
35
|
+
totalInCents: number;
|
|
36
|
+
currency: string;
|
|
37
|
+
stripePaymentIntentId: string | null;
|
|
38
|
+
stripeCheckoutSessionId: string | null;
|
|
39
|
+
items: {
|
|
40
|
+
productId: string;
|
|
41
|
+
title: string;
|
|
42
|
+
quantity: number;
|
|
43
|
+
priceInCents: number;
|
|
44
|
+
}[];
|
|
45
|
+
shippingAddress: unknown;
|
|
46
|
+
metadata: unknown;
|
|
47
|
+
createdAt: Date;
|
|
48
|
+
updatedAt: Date;
|
|
49
|
+
deletedAt: Date | null;
|
|
50
|
+
} | null>;
|
|
51
|
+
export declare function createOrder(db: DatabaseClient, data: typeof orders.$inferInsert): Promise<{
|
|
52
|
+
id: string;
|
|
53
|
+
status: string;
|
|
54
|
+
createdAt: Date;
|
|
55
|
+
updatedAt: Date;
|
|
56
|
+
deletedAt: Date | null;
|
|
57
|
+
metadata: unknown;
|
|
58
|
+
customerId: string;
|
|
59
|
+
currency: string;
|
|
60
|
+
totalInCents: number;
|
|
61
|
+
stripePaymentIntentId: string | null;
|
|
62
|
+
stripeCheckoutSessionId: string | null;
|
|
63
|
+
items: {
|
|
64
|
+
productId: string;
|
|
65
|
+
title: string;
|
|
66
|
+
quantity: number;
|
|
67
|
+
priceInCents: number;
|
|
68
|
+
}[];
|
|
69
|
+
shippingAddress: unknown;
|
|
70
|
+
} | null>;
|
|
71
|
+
export declare function updateOrder(db: DatabaseClient, id: string, data: Partial<typeof orders.$inferInsert>): Promise<{
|
|
72
|
+
id: string;
|
|
73
|
+
customerId: string;
|
|
74
|
+
status: string;
|
|
75
|
+
totalInCents: number;
|
|
76
|
+
currency: string;
|
|
77
|
+
stripePaymentIntentId: string | null;
|
|
78
|
+
stripeCheckoutSessionId: string | null;
|
|
79
|
+
items: {
|
|
80
|
+
productId: string;
|
|
81
|
+
title: string;
|
|
82
|
+
quantity: number;
|
|
83
|
+
priceInCents: number;
|
|
84
|
+
}[];
|
|
85
|
+
shippingAddress: unknown;
|
|
86
|
+
metadata: unknown;
|
|
87
|
+
createdAt: Date;
|
|
88
|
+
updatedAt: Date;
|
|
89
|
+
deletedAt: Date | null;
|
|
90
|
+
} | null>;
|
|
91
|
+
//# sourceMappingURL=orders.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orders.d.ts","sourceRoot":"","sources":["../../src/queries/orders.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C,wBAAsB,YAAY,CAChC,EAAE,EAAE,cAAc,EAClB,OAAO,GAAE;IAAE,UAAU,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;;;KAcxF;AAED,wBAAsB,YAAY,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;;UAGhE;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,MAAM,CAAC,YAAY;;;;;;;;;;;;;;;;;;;UAGrF;AAED,wBAAsB,WAAW,CAC/B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,MAAM,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;;;UAQ1C"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Order database queries
|
|
3
|
+
*/
|
|
4
|
+
import { and, desc, eq } from 'drizzle-orm';
|
|
5
|
+
import { orders } from '../schema/products.js';
|
|
6
|
+
export async function getAllOrders(db, options = {}) {
|
|
7
|
+
const { customerId, status, limit = 20, offset = 0 } = options;
|
|
8
|
+
const conditions = [
|
|
9
|
+
...(customerId ? [eq(orders.customerId, customerId)] : []),
|
|
10
|
+
...(status ? [eq(orders.status, status)] : []),
|
|
11
|
+
];
|
|
12
|
+
return db
|
|
13
|
+
.select()
|
|
14
|
+
.from(orders)
|
|
15
|
+
.where(conditions.length > 0 ? and(...conditions) : undefined)
|
|
16
|
+
.orderBy(desc(orders.createdAt))
|
|
17
|
+
.limit(limit)
|
|
18
|
+
.offset(offset);
|
|
19
|
+
}
|
|
20
|
+
export async function getOrderById(db, id) {
|
|
21
|
+
const result = await db.select().from(orders).where(eq(orders.id, id)).limit(1);
|
|
22
|
+
return result[0] ?? null;
|
|
23
|
+
}
|
|
24
|
+
export async function createOrder(db, data) {
|
|
25
|
+
const result = await db.insert(orders).values(data).returning();
|
|
26
|
+
return result[0] ?? null;
|
|
27
|
+
}
|
|
28
|
+
export async function updateOrder(db, id, data) {
|
|
29
|
+
const result = await db
|
|
30
|
+
.update(orders)
|
|
31
|
+
.set({ ...data, updatedAt: new Date() })
|
|
32
|
+
.where(eq(orders.id, id))
|
|
33
|
+
.returning();
|
|
34
|
+
return result[0] ?? null;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=orders.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orders.js","sourceRoot":"","sources":["../../src/queries/orders.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAE5C,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,EAAkB,EAClB,UAAqF,EAAE;IAEvF,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,GAAG,EAAE,EAAE,MAAM,GAAG,CAAC,EAAE,GAAG,OAAO,CAAC;IAC/D,MAAM,UAAU,GAAG;QACjB,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1D,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;KAC/C,CAAC;IACF,OAAO,EAAE;SACN,MAAM,EAAE;SACR,IAAI,CAAC,MAAM,CAAC;SACZ,KAAK,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;SAC7D,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;SAC/B,KAAK,CAAC,KAAK,CAAC;SACZ,MAAM,CAAC,MAAM,CAAC,CAAC;AACpB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,EAAkB,EAAE,EAAU;IAC/D,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChF,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,EAAkB,EAAE,IAAgC;IACpF,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;IAChE,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,EAAkB,EAClB,EAAU,EACV,IAAyC;IAEzC,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,CAAC,MAAM,CAAC;SACd,GAAG,CAAC,EAAE,GAAG,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC;SACvC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;SACxB,SAAS,EAAE,CAAC;IACf,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.d.ts","sourceRoot":"","sources":["../../src/queries/pages.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"pages.d.ts","sourceRoot":"","sources":["../../src/queries/pages.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAE3C,wBAAsB,cAAc,CAClC,EAAE,EAAE,cAAc,EAClB,MAAM,EAAE,MAAM,EACd,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;;;;;KAalC;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;UAO/D;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;UAOnF;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;UAGnF;AAED,wBAAsB,UAAU,CAC9B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,KAAK,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;UAQzC;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAO9D"}
|
package/dist/queries/pages.js
CHANGED
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { and, asc, eq, isNull } from 'drizzle-orm';
|
|
5
5
|
import { pages } from '../schema/pages.js';
|
|
6
|
-
import { decrementPageCount, incrementPageCount } from './sites.js';
|
|
7
6
|
export async function getPagesBySite(db, siteId, options = {}) {
|
|
8
7
|
const { status } = options;
|
|
9
8
|
const conditions = [
|
|
@@ -35,9 +34,6 @@ export async function getPageByPath(db, siteId, path) {
|
|
|
35
34
|
}
|
|
36
35
|
export async function createPage(db, data) {
|
|
37
36
|
const result = await db.insert(pages).values(data).returning();
|
|
38
|
-
if (result[0]) {
|
|
39
|
-
await incrementPageCount(db, data.siteId);
|
|
40
|
-
}
|
|
41
37
|
return result[0] ?? null;
|
|
42
38
|
}
|
|
43
39
|
export async function updatePage(db, id, data) {
|
|
@@ -56,6 +52,5 @@ export async function deletePage(db, id) {
|
|
|
56
52
|
.update(pages)
|
|
57
53
|
.set({ deletedAt: new Date(), updatedAt: new Date() })
|
|
58
54
|
.where(and(eq(pages.id, id), isNull(pages.deletedAt)));
|
|
59
|
-
await decrementPageCount(db, page.siteId);
|
|
60
55
|
}
|
|
61
56
|
//# sourceMappingURL=pages.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.js","sourceRoot":"","sources":["../../src/queries/pages.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAEnD,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"pages.js","sourceRoot":"","sources":["../../src/queries/pages.ts"],"names":[],"mappings":"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"}
|
package/dist/queries/posts.d.ts
CHANGED
|
@@ -27,6 +27,37 @@ export declare function getAllPosts(db: DatabaseClient, options?: {
|
|
|
27
27
|
publishedAt: Date | null;
|
|
28
28
|
deletedAt: Date | null;
|
|
29
29
|
}[]>;
|
|
30
|
+
/** List posts with author data joined (prevents N+1 when listing posts) */
|
|
31
|
+
export declare function getPostsWithAuthor(db: DatabaseClient, options?: {
|
|
32
|
+
status?: string;
|
|
33
|
+
limit?: number;
|
|
34
|
+
offset?: number;
|
|
35
|
+
}): Promise<{
|
|
36
|
+
post: {
|
|
37
|
+
id: string;
|
|
38
|
+
schemaVersion: string;
|
|
39
|
+
version: number;
|
|
40
|
+
title: string;
|
|
41
|
+
slug: string;
|
|
42
|
+
excerpt: string | null;
|
|
43
|
+
content: unknown;
|
|
44
|
+
featuredImageId: string | null;
|
|
45
|
+
authorId: string | null;
|
|
46
|
+
status: string;
|
|
47
|
+
published: boolean | null;
|
|
48
|
+
meta: unknown;
|
|
49
|
+
categories: string[] | null;
|
|
50
|
+
createdAt: Date;
|
|
51
|
+
updatedAt: Date;
|
|
52
|
+
publishedAt: Date | null;
|
|
53
|
+
deletedAt: Date | null;
|
|
54
|
+
};
|
|
55
|
+
author: {
|
|
56
|
+
id: string;
|
|
57
|
+
name: string;
|
|
58
|
+
email: string | null;
|
|
59
|
+
} | null;
|
|
60
|
+
}[]>;
|
|
30
61
|
export declare function getPostById(db: DatabaseClient, id: string): Promise<{
|
|
31
62
|
id: string;
|
|
32
63
|
schemaVersion: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"posts.d.ts","sourceRoot":"","sources":["../../src/queries/posts.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"posts.d.ts","sourceRoot":"","sources":["../../src/queries/posts.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAGzC,wBAAsB,WAAW,CAC/B,EAAE,EAAE,cAAc,EAClB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;;KAetF;AAED,2EAA2E;AAC3E,wBAAsB,kBAAkB,CACtC,EAAE,EAAE,cAAc,EAClB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;;;;;;;;;KAmBnE;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;UAO/D;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM;;;;;;;;;;;;;;;;;;UAOnE;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;;UAGnF;AAED,wBAAsB,UAAU,CAC9B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,KAAK,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;;UAQzC;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAK9D"}
|
package/dist/queries/posts.js
CHANGED
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { and, desc, eq, isNull } from 'drizzle-orm';
|
|
5
5
|
import { posts } from '../schema/cms.js';
|
|
6
|
+
import { users } from '../schema/users.js';
|
|
6
7
|
export async function getAllPosts(db, options = {}) {
|
|
7
8
|
const { status, authorId, limit = 20, offset = 0 } = options;
|
|
8
9
|
const conditions = [
|
|
@@ -18,6 +19,26 @@ export async function getAllPosts(db, options = {}) {
|
|
|
18
19
|
.limit(limit)
|
|
19
20
|
.offset(offset);
|
|
20
21
|
}
|
|
22
|
+
/** List posts with author data joined (prevents N+1 when listing posts) */
|
|
23
|
+
export async function getPostsWithAuthor(db, options = {}) {
|
|
24
|
+
const { status, limit = 20, offset = 0 } = options;
|
|
25
|
+
const conditions = [isNull(posts.deletedAt), ...(status ? [eq(posts.status, status)] : [])];
|
|
26
|
+
return db
|
|
27
|
+
.select({
|
|
28
|
+
post: posts,
|
|
29
|
+
author: {
|
|
30
|
+
id: users.id,
|
|
31
|
+
name: users.name,
|
|
32
|
+
email: users.email,
|
|
33
|
+
},
|
|
34
|
+
})
|
|
35
|
+
.from(posts)
|
|
36
|
+
.leftJoin(users, eq(posts.authorId, users.id))
|
|
37
|
+
.where(and(...conditions))
|
|
38
|
+
.orderBy(desc(posts.createdAt))
|
|
39
|
+
.limit(limit)
|
|
40
|
+
.offset(offset);
|
|
41
|
+
}
|
|
21
42
|
export async function getPostById(db, id) {
|
|
22
43
|
const result = await db
|
|
23
44
|
.select()
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../src/queries/posts.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../src/queries/posts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Product database queries
|
|
3
|
+
*/
|
|
4
|
+
import type { DatabaseClient } from '../client/types.js';
|
|
5
|
+
import { products } from '../schema/products.js';
|
|
6
|
+
export declare function getAllProducts(db: DatabaseClient, options?: {
|
|
7
|
+
status?: string;
|
|
8
|
+
ownerId?: string;
|
|
9
|
+
limit?: number;
|
|
10
|
+
offset?: number;
|
|
11
|
+
}): Promise<{
|
|
12
|
+
id: string;
|
|
13
|
+
title: string;
|
|
14
|
+
slug: string;
|
|
15
|
+
description: string | null;
|
|
16
|
+
priceInCents: number | null;
|
|
17
|
+
currency: string;
|
|
18
|
+
stripeProductId: string | null;
|
|
19
|
+
stripePriceId: string | null;
|
|
20
|
+
active: boolean;
|
|
21
|
+
status: string;
|
|
22
|
+
images: string[] | null;
|
|
23
|
+
metadata: unknown;
|
|
24
|
+
ownerId: string | null;
|
|
25
|
+
createdAt: Date;
|
|
26
|
+
updatedAt: Date;
|
|
27
|
+
deletedAt: Date | null;
|
|
28
|
+
}[]>;
|
|
29
|
+
export declare function getProductById(db: DatabaseClient, id: string): Promise<{
|
|
30
|
+
id: string;
|
|
31
|
+
title: string;
|
|
32
|
+
slug: string;
|
|
33
|
+
description: string | null;
|
|
34
|
+
priceInCents: number | null;
|
|
35
|
+
currency: string;
|
|
36
|
+
stripeProductId: string | null;
|
|
37
|
+
stripePriceId: string | null;
|
|
38
|
+
active: boolean;
|
|
39
|
+
status: string;
|
|
40
|
+
images: string[] | null;
|
|
41
|
+
metadata: unknown;
|
|
42
|
+
ownerId: string | null;
|
|
43
|
+
createdAt: Date;
|
|
44
|
+
updatedAt: Date;
|
|
45
|
+
deletedAt: Date | null;
|
|
46
|
+
} | null>;
|
|
47
|
+
export declare function getProductBySlug(db: DatabaseClient, slug: string): Promise<{
|
|
48
|
+
id: string;
|
|
49
|
+
title: string;
|
|
50
|
+
slug: string;
|
|
51
|
+
description: string | null;
|
|
52
|
+
priceInCents: number | null;
|
|
53
|
+
currency: string;
|
|
54
|
+
stripeProductId: string | null;
|
|
55
|
+
stripePriceId: string | null;
|
|
56
|
+
active: boolean;
|
|
57
|
+
status: string;
|
|
58
|
+
images: string[] | null;
|
|
59
|
+
metadata: unknown;
|
|
60
|
+
ownerId: string | null;
|
|
61
|
+
createdAt: Date;
|
|
62
|
+
updatedAt: Date;
|
|
63
|
+
deletedAt: Date | null;
|
|
64
|
+
} | null>;
|
|
65
|
+
export declare function createProduct(db: DatabaseClient, data: typeof products.$inferInsert): Promise<{
|
|
66
|
+
id: string;
|
|
67
|
+
status: string;
|
|
68
|
+
active: boolean;
|
|
69
|
+
createdAt: Date;
|
|
70
|
+
updatedAt: Date;
|
|
71
|
+
deletedAt: Date | null;
|
|
72
|
+
metadata: unknown;
|
|
73
|
+
slug: string;
|
|
74
|
+
stripeProductId: string | null;
|
|
75
|
+
stripePriceId: string | null;
|
|
76
|
+
ownerId: string | null;
|
|
77
|
+
description: string | null;
|
|
78
|
+
title: string;
|
|
79
|
+
priceInCents: number | null;
|
|
80
|
+
currency: string;
|
|
81
|
+
images: string[] | null;
|
|
82
|
+
} | null>;
|
|
83
|
+
export declare function updateProduct(db: DatabaseClient, id: string, data: Partial<typeof products.$inferInsert>): Promise<{
|
|
84
|
+
id: string;
|
|
85
|
+
title: string;
|
|
86
|
+
slug: string;
|
|
87
|
+
description: string | null;
|
|
88
|
+
priceInCents: number | null;
|
|
89
|
+
currency: string;
|
|
90
|
+
stripeProductId: string | null;
|
|
91
|
+
stripePriceId: string | null;
|
|
92
|
+
active: boolean;
|
|
93
|
+
status: string;
|
|
94
|
+
images: string[] | null;
|
|
95
|
+
metadata: unknown;
|
|
96
|
+
ownerId: string | null;
|
|
97
|
+
createdAt: Date;
|
|
98
|
+
updatedAt: Date;
|
|
99
|
+
deletedAt: Date | null;
|
|
100
|
+
} | null>;
|
|
101
|
+
export declare function deleteProduct(db: DatabaseClient, id: string): Promise<void>;
|
|
102
|
+
//# sourceMappingURL=products.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"products.d.ts","sourceRoot":"","sources":["../../src/queries/products.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEjD,wBAAsB,cAAc,CAClC,EAAE,EAAE,cAAc,EAClB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;KAerF;AAED,wBAAsB,cAAc,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;UAOlE;AAED,wBAAsB,gBAAgB,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM;;;;;;;;;;;;;;;;;UAOtE;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,QAAQ,CAAC,YAAY;;;;;;;;;;;;;;;;;UAGzF;AAED,wBAAsB,aAAa,CACjC,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,QAAQ,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;UAQ5C;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAKjE"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Product database queries
|
|
3
|
+
*/
|
|
4
|
+
import { and, desc, eq, isNull } from 'drizzle-orm';
|
|
5
|
+
import { products } from '../schema/products.js';
|
|
6
|
+
export async function getAllProducts(db, options = {}) {
|
|
7
|
+
const { status, ownerId, limit = 20, offset = 0 } = options;
|
|
8
|
+
const conditions = [
|
|
9
|
+
isNull(products.deletedAt),
|
|
10
|
+
...(status ? [eq(products.status, status)] : []),
|
|
11
|
+
...(ownerId ? [eq(products.ownerId, ownerId)] : []),
|
|
12
|
+
];
|
|
13
|
+
return db
|
|
14
|
+
.select()
|
|
15
|
+
.from(products)
|
|
16
|
+
.where(and(...conditions))
|
|
17
|
+
.orderBy(desc(products.createdAt))
|
|
18
|
+
.limit(limit)
|
|
19
|
+
.offset(offset);
|
|
20
|
+
}
|
|
21
|
+
export async function getProductById(db, id) {
|
|
22
|
+
const result = await db
|
|
23
|
+
.select()
|
|
24
|
+
.from(products)
|
|
25
|
+
.where(and(eq(products.id, id), isNull(products.deletedAt)))
|
|
26
|
+
.limit(1);
|
|
27
|
+
return result[0] ?? null;
|
|
28
|
+
}
|
|
29
|
+
export async function getProductBySlug(db, slug) {
|
|
30
|
+
const result = await db
|
|
31
|
+
.select()
|
|
32
|
+
.from(products)
|
|
33
|
+
.where(and(eq(products.slug, slug), isNull(products.deletedAt)))
|
|
34
|
+
.limit(1);
|
|
35
|
+
return result[0] ?? null;
|
|
36
|
+
}
|
|
37
|
+
export async function createProduct(db, data) {
|
|
38
|
+
const result = await db.insert(products).values(data).returning();
|
|
39
|
+
return result[0] ?? null;
|
|
40
|
+
}
|
|
41
|
+
export async function updateProduct(db, id, data) {
|
|
42
|
+
const result = await db
|
|
43
|
+
.update(products)
|
|
44
|
+
.set({ ...data, updatedAt: new Date() })
|
|
45
|
+
.where(and(eq(products.id, id), isNull(products.deletedAt)))
|
|
46
|
+
.returning();
|
|
47
|
+
return result[0] ?? null;
|
|
48
|
+
}
|
|
49
|
+
export async function deleteProduct(db, id) {
|
|
50
|
+
await db
|
|
51
|
+
.update(products)
|
|
52
|
+
.set({ deletedAt: new Date(), updatedAt: new Date() })
|
|
53
|
+
.where(and(eq(products.id, id), isNull(products.deletedAt)));
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=products.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"products.js","sourceRoot":"","sources":["../../src/queries/products.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,6 +18,31 @@ export declare function getCommentsByTicket(db: DatabaseClient, ticketId: string
|
|
|
18
18
|
createdAt: Date;
|
|
19
19
|
updatedAt: Date;
|
|
20
20
|
}[]>;
|
|
21
|
+
/** Get comments with author data joined (prevents N+1 when displaying threads) */
|
|
22
|
+
export declare function getCommentsWithAuthors(db: DatabaseClient, ticketId: string): Promise<{
|
|
23
|
+
comment: {
|
|
24
|
+
id: string;
|
|
25
|
+
ticketId: string;
|
|
26
|
+
authorId: string | null;
|
|
27
|
+
body: unknown;
|
|
28
|
+
createdAt: Date;
|
|
29
|
+
updatedAt: Date;
|
|
30
|
+
};
|
|
31
|
+
author: {
|
|
32
|
+
id: string;
|
|
33
|
+
name: string;
|
|
34
|
+
email: string | null;
|
|
35
|
+
} | null;
|
|
36
|
+
}[]>;
|
|
37
|
+
/** Batch-load comments for multiple tickets (prevents N+1 on board views) */
|
|
38
|
+
export declare function getCommentsByTicketIds(db: DatabaseClient, ticketIds: string[]): Promise<{
|
|
39
|
+
id: string;
|
|
40
|
+
ticketId: string;
|
|
41
|
+
authorId: string | null;
|
|
42
|
+
body: unknown;
|
|
43
|
+
createdAt: Date;
|
|
44
|
+
updatedAt: Date;
|
|
45
|
+
}[]>;
|
|
21
46
|
export declare function createComment(db: DatabaseClient, data: {
|
|
22
47
|
id: string;
|
|
23
48
|
ticketId: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ticket-comments.d.ts","sourceRoot":"","sources":["../../src/queries/ticket-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"ticket-comments.d.ts","sourceRoot":"","sources":["../../src/queries/ticket-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAIzD,wBAAsB,cAAc,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;UAGlE;AAED,wBAAsB,mBAAmB,CAAC,EAAE,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM;;;;;;;KAM7E;AAED,kFAAkF;AAClF,wBAAsB,sBAAsB,CAAC,EAAE,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM;;;;;;;;;;;;;;KAchF;AAED,6EAA6E;AAC7E,wBAAsB,sBAAsB,CAAC,EAAE,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,EAAE;;;;;;;KAOnF;AAED,wBAAsB,aAAa,CACjC,EAAE,EAAE,cAAc,EAClB,IAAI,EAAE;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,OAAO,CAAA;CAAE;;;;;;;eAczE;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;IAAE,IAAI,EAAE,OAAO,CAAA;CAAE;;;;;;;UAQ1F;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAoBjE"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Ticket comment database queries
|
|
3
3
|
*/
|
|
4
|
-
import { eq, sql } from 'drizzle-orm';
|
|
4
|
+
import { eq, inArray, sql } from 'drizzle-orm';
|
|
5
5
|
import { ticketComments, tickets } from '../schema/tickets.js';
|
|
6
|
+
import { users } from '../schema/users.js';
|
|
6
7
|
export async function getCommentById(db, id) {
|
|
7
8
|
const result = await db.select().from(ticketComments).where(eq(ticketComments.id, id)).limit(1);
|
|
8
9
|
return result[0] ?? null;
|
|
@@ -14,6 +15,32 @@ export async function getCommentsByTicket(db, ticketId) {
|
|
|
14
15
|
.where(eq(ticketComments.ticketId, ticketId))
|
|
15
16
|
.orderBy(ticketComments.createdAt);
|
|
16
17
|
}
|
|
18
|
+
/** Get comments with author data joined (prevents N+1 when displaying threads) */
|
|
19
|
+
export async function getCommentsWithAuthors(db, ticketId) {
|
|
20
|
+
return db
|
|
21
|
+
.select({
|
|
22
|
+
comment: ticketComments,
|
|
23
|
+
author: {
|
|
24
|
+
id: users.id,
|
|
25
|
+
name: users.name,
|
|
26
|
+
email: users.email,
|
|
27
|
+
},
|
|
28
|
+
})
|
|
29
|
+
.from(ticketComments)
|
|
30
|
+
.leftJoin(users, eq(ticketComments.authorId, users.id))
|
|
31
|
+
.where(eq(ticketComments.ticketId, ticketId))
|
|
32
|
+
.orderBy(ticketComments.createdAt);
|
|
33
|
+
}
|
|
34
|
+
/** Batch-load comments for multiple tickets (prevents N+1 on board views) */
|
|
35
|
+
export async function getCommentsByTicketIds(db, ticketIds) {
|
|
36
|
+
if (ticketIds.length === 0)
|
|
37
|
+
return [];
|
|
38
|
+
return db
|
|
39
|
+
.select()
|
|
40
|
+
.from(ticketComments)
|
|
41
|
+
.where(inArray(ticketComments.ticketId, ticketIds))
|
|
42
|
+
.orderBy(ticketComments.createdAt);
|
|
43
|
+
}
|
|
17
44
|
export async function createComment(db, data) {
|
|
18
45
|
const result = await db.insert(ticketComments).values(data).returning();
|
|
19
46
|
// Increment comment count on the ticket
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ticket-comments.js","sourceRoot":"","sources":["../../src/queries/ticket-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"ticket-comments.js","sourceRoot":"","sources":["../../src/queries/ticket-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAE/C,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAE3C,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,EAAkB,EAAE,EAAU;IACjE,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChG,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,EAAkB,EAAE,QAAgB;IAC5E,OAAO,EAAE;SACN,MAAM,EAAE;SACR,IAAI,CAAC,cAAc,CAAC;SACpB,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;SAC5C,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AACvC,CAAC;AAED,kFAAkF;AAClF,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,EAAkB,EAAE,QAAgB;IAC/E,OAAO,EAAE;SACN,MAAM,CAAC;QACN,OAAO,EAAE,cAAc;QACvB,MAAM,EAAE;YACN,EAAE,EAAE,KAAK,CAAC,EAAE;YACZ,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,KAAK,EAAE,KAAK,CAAC,KAAK;SACnB;KACF,CAAC;SACD,IAAI,CAAC,cAAc,CAAC;SACpB,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,cAAc,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC;SACtD,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;SAC5C,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AACvC,CAAC;AAED,6EAA6E;AAC7E,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,EAAkB,EAAE,SAAmB;IAClF,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IACtC,OAAO,EAAE;SACN,MAAM,EAAE;SACR,IAAI,CAAC,cAAc,CAAC;SACpB,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;SAClD,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AACvC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,EAAkB,EAClB,IAAwE;IAExE,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;IAExE,wCAAwC;IACxC,MAAM,EAAE;SACL,MAAM,CAAC,OAAO,CAAC;SACf,GAAG,CAAC;QACH,YAAY,EAAE,GAAG,CAAA,GAAG,OAAO,CAAC,YAAY,MAAM;QAC9C,SAAS,EAAE,IAAI,IAAI,EAAE;KACtB,CAAC;SACD,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IAExC,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;AACnB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAAkB,EAAE,EAAU,EAAE,IAAuB;IACzF,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,CAAC,cAAc,CAAC;SACtB,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC;SAC/C,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;SAChC,SAAS,EAAE,CAAC;IAEf,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAAkB,EAAE,EAAU;IAChE,oCAAoC;IACpC,MAAM,OAAO,GAAG,MAAM,EAAE;SACrB,MAAM,CAAC,EAAE,QAAQ,EAAE,cAAc,CAAC,QAAQ,EAAE,CAAC;SAC7C,IAAI,CAAC,cAAc,CAAC;SACpB,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;SAChC,KAAK,CAAC,CAAC,CAAC,CAAC;IAEZ,MAAM,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IAEjE,0BAA0B;IAC1B,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;QACf,MAAM,EAAE;aACL,MAAM,CAAC,OAAO,CAAC;aACf,GAAG,CAAC;YACH,YAAY,EAAE,GAAG,CAAA,YAAY,OAAO,CAAC,YAAY,UAAU;YAC3D,SAAS,EAAE,IAAI,IAAI,EAAE;SACtB,CAAC;aACD,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChD,CAAC;AACH,CAAC"}
|