@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
package/dist/schema/todos.d.ts
DELETED
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Todos Schema - Simple demo table for API integration
|
|
3
|
-
*/
|
|
4
|
-
export declare const todos: import("drizzle-orm/pg-core").PgTableWithColumns<{
|
|
5
|
-
name: "todos";
|
|
6
|
-
schema: undefined;
|
|
7
|
-
columns: {
|
|
8
|
-
id: import("drizzle-orm/pg-core").PgColumn<{
|
|
9
|
-
name: "id";
|
|
10
|
-
tableName: "todos";
|
|
11
|
-
dataType: "string";
|
|
12
|
-
columnType: "PgUUID";
|
|
13
|
-
data: string;
|
|
14
|
-
driverParam: string;
|
|
15
|
-
notNull: true;
|
|
16
|
-
hasDefault: true;
|
|
17
|
-
isPrimaryKey: true;
|
|
18
|
-
isAutoincrement: false;
|
|
19
|
-
hasRuntimeDefault: false;
|
|
20
|
-
enumValues: undefined;
|
|
21
|
-
baseColumn: never;
|
|
22
|
-
identity: undefined;
|
|
23
|
-
generated: undefined;
|
|
24
|
-
}, {}, {}>;
|
|
25
|
-
text: import("drizzle-orm/pg-core").PgColumn<{
|
|
26
|
-
name: "text";
|
|
27
|
-
tableName: "todos";
|
|
28
|
-
dataType: "string";
|
|
29
|
-
columnType: "PgText";
|
|
30
|
-
data: string;
|
|
31
|
-
driverParam: string;
|
|
32
|
-
notNull: true;
|
|
33
|
-
hasDefault: false;
|
|
34
|
-
isPrimaryKey: false;
|
|
35
|
-
isAutoincrement: false;
|
|
36
|
-
hasRuntimeDefault: false;
|
|
37
|
-
enumValues: [string, ...string[]];
|
|
38
|
-
baseColumn: never;
|
|
39
|
-
identity: undefined;
|
|
40
|
-
generated: undefined;
|
|
41
|
-
}, {}, {}>;
|
|
42
|
-
completed: import("drizzle-orm/pg-core").PgColumn<{
|
|
43
|
-
name: "completed";
|
|
44
|
-
tableName: "todos";
|
|
45
|
-
dataType: "boolean";
|
|
46
|
-
columnType: "PgBoolean";
|
|
47
|
-
data: boolean;
|
|
48
|
-
driverParam: boolean;
|
|
49
|
-
notNull: true;
|
|
50
|
-
hasDefault: true;
|
|
51
|
-
isPrimaryKey: false;
|
|
52
|
-
isAutoincrement: false;
|
|
53
|
-
hasRuntimeDefault: false;
|
|
54
|
-
enumValues: undefined;
|
|
55
|
-
baseColumn: never;
|
|
56
|
-
identity: undefined;
|
|
57
|
-
generated: undefined;
|
|
58
|
-
}, {}, {}>;
|
|
59
|
-
createdAt: import("drizzle-orm/pg-core").PgColumn<{
|
|
60
|
-
name: "created_at";
|
|
61
|
-
tableName: "todos";
|
|
62
|
-
dataType: "date";
|
|
63
|
-
columnType: "PgTimestamp";
|
|
64
|
-
data: Date;
|
|
65
|
-
driverParam: string;
|
|
66
|
-
notNull: true;
|
|
67
|
-
hasDefault: true;
|
|
68
|
-
isPrimaryKey: false;
|
|
69
|
-
isAutoincrement: false;
|
|
70
|
-
hasRuntimeDefault: false;
|
|
71
|
-
enumValues: undefined;
|
|
72
|
-
baseColumn: never;
|
|
73
|
-
identity: undefined;
|
|
74
|
-
generated: undefined;
|
|
75
|
-
}, {}, {}>;
|
|
76
|
-
updatedAt: import("drizzle-orm/pg-core").PgColumn<{
|
|
77
|
-
name: "updated_at";
|
|
78
|
-
tableName: "todos";
|
|
79
|
-
dataType: "date";
|
|
80
|
-
columnType: "PgTimestamp";
|
|
81
|
-
data: Date;
|
|
82
|
-
driverParam: string;
|
|
83
|
-
notNull: true;
|
|
84
|
-
hasDefault: true;
|
|
85
|
-
isPrimaryKey: false;
|
|
86
|
-
isAutoincrement: false;
|
|
87
|
-
hasRuntimeDefault: false;
|
|
88
|
-
enumValues: undefined;
|
|
89
|
-
baseColumn: never;
|
|
90
|
-
identity: undefined;
|
|
91
|
-
generated: undefined;
|
|
92
|
-
}, {}, {}>;
|
|
93
|
-
};
|
|
94
|
-
dialect: "pg";
|
|
95
|
-
}>;
|
|
96
|
-
export type Todo = typeof todos.$inferSelect;
|
|
97
|
-
export type NewTodo = typeof todos.$inferInsert;
|
|
98
|
-
//# sourceMappingURL=todos.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"todos.d.ts","sourceRoot":"","sources":["../../src/schema/todos.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,eAAO,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAMhB,CAAA;AAEF,MAAM,MAAM,IAAI,GAAG,OAAO,KAAK,CAAC,YAAY,CAAA;AAC5C,MAAM,MAAM,OAAO,GAAG,OAAO,KAAK,CAAC,YAAY,CAAA"}
|
package/dist/schema/todos.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Todos Schema - Simple demo table for API integration
|
|
3
|
-
*/
|
|
4
|
-
import { boolean, pgTable, text, timestamp, uuid } from 'drizzle-orm/pg-core';
|
|
5
|
-
export const todos = pgTable('todos', {
|
|
6
|
-
id: uuid('id').primaryKey().defaultRandom(),
|
|
7
|
-
text: text('text').notNull(),
|
|
8
|
-
completed: boolean('completed').notNull().default(false),
|
|
9
|
-
createdAt: timestamp('created_at', { withTimezone: true }).notNull().defaultNow(),
|
|
10
|
-
updatedAt: timestamp('updated_at', { withTimezone: true }).notNull().defaultNow(),
|
|
11
|
-
});
|
|
12
|
-
//# sourceMappingURL=todos.js.map
|
package/dist/schema/todos.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"todos.js","sourceRoot":"","sources":["../../src/schema/todos.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAA;AAE7E,MAAM,CAAC,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,EAAE;IACpC,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC,aAAa,EAAE;IAC3C,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE;IAC5B,SAAS,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACxD,SAAS,EAAE,SAAS,CAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,UAAU,EAAE;IACjF,SAAS,EAAE,SAAS,CAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,UAAU,EAAE;CAClF,CAAC,CAAA"}
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* DrizzleSecurityAuditStorage — DB-backed implementation of @revealui/core's AuditStorage.
|
|
3
|
-
*
|
|
4
|
-
* Adapts the core security audit interface to the shared `audit_log` table.
|
|
5
|
-
* Maps AuditEvent.actor.id → agentId, and stores the full event in payload.
|
|
6
|
-
*/
|
|
7
|
-
import type { NeonHttpDatabase } from 'drizzle-orm/neon-http';
|
|
8
|
-
import type { NodePgDatabase } from 'drizzle-orm/node-postgres';
|
|
9
|
-
interface AuditEvent {
|
|
10
|
-
id: string;
|
|
11
|
-
timestamp: string;
|
|
12
|
-
type: string;
|
|
13
|
-
severity: string;
|
|
14
|
-
actor: {
|
|
15
|
-
id: string;
|
|
16
|
-
type: 'user' | 'system' | 'api';
|
|
17
|
-
ip?: string;
|
|
18
|
-
userAgent?: string;
|
|
19
|
-
};
|
|
20
|
-
resource?: {
|
|
21
|
-
type: string;
|
|
22
|
-
id: string;
|
|
23
|
-
name?: string;
|
|
24
|
-
};
|
|
25
|
-
action: string;
|
|
26
|
-
result: 'success' | 'failure' | 'partial';
|
|
27
|
-
changes?: {
|
|
28
|
-
before?: Record<string, unknown>;
|
|
29
|
-
after?: Record<string, unknown>;
|
|
30
|
-
};
|
|
31
|
-
metadata?: Record<string, unknown>;
|
|
32
|
-
}
|
|
33
|
-
interface AuditQuery {
|
|
34
|
-
types?: string[];
|
|
35
|
-
actorId?: string;
|
|
36
|
-
resourceType?: string;
|
|
37
|
-
resourceId?: string;
|
|
38
|
-
startDate?: Date;
|
|
39
|
-
endDate?: Date;
|
|
40
|
-
severity?: string[];
|
|
41
|
-
result?: string[];
|
|
42
|
-
limit?: number;
|
|
43
|
-
offset?: number;
|
|
44
|
-
}
|
|
45
|
-
type DrizzleDb = NeonHttpDatabase | NodePgDatabase;
|
|
46
|
-
export declare class DrizzleSecurityAuditStorage {
|
|
47
|
-
private db;
|
|
48
|
-
constructor(db: DrizzleDb);
|
|
49
|
-
write(event: AuditEvent): Promise<void>;
|
|
50
|
-
query(query: AuditQuery): Promise<AuditEvent[]>;
|
|
51
|
-
count(query: AuditQuery): Promise<number>;
|
|
52
|
-
}
|
|
53
|
-
export {};
|
|
54
|
-
//# sourceMappingURL=security-audit-storage.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"security-audit-storage.d.ts","sourceRoot":"","sources":["../src/security-audit-storage.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAG/D,UAAU,UAAU;IAClB,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,EAAE,MAAM,CAAA;IAChB,KAAK,EAAE;QACL,EAAE,EAAE,MAAM,CAAA;QACV,IAAI,EAAE,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAA;QAC/B,EAAE,CAAC,EAAE,MAAM,CAAA;QACX,SAAS,CAAC,EAAE,MAAM,CAAA;KACnB,CAAA;IACD,QAAQ,CAAC,EAAE;QACT,IAAI,EAAE,MAAM,CAAA;QACZ,EAAE,EAAE,MAAM,CAAA;QACV,IAAI,CAAC,EAAE,MAAM,CAAA;KACd,CAAA;IACD,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,SAAS,CAAA;IACzC,OAAO,CAAC,EAAE;QACR,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;QAChC,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAChC,CAAA;IACD,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CACnC;AAED,UAAU,UAAU;IAClB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,IAAI,CAAA;IAChB,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;IACnB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,KAAK,SAAS,GAAG,gBAAgB,GAAG,cAAc,CAAA;AAElD,qBAAa,2BAA2B;IAC1B,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,SAAS;IAE3B,KAAK,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAqBvC,KAAK,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAiD/C,KAAK,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC;CAyBhD"}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* DrizzleSecurityAuditStorage — DB-backed implementation of @revealui/core's AuditStorage.
|
|
3
|
-
*
|
|
4
|
-
* Adapts the core security audit interface to the shared `audit_log` table.
|
|
5
|
-
* Maps AuditEvent.actor.id → agentId, and stores the full event in payload.
|
|
6
|
-
*/
|
|
7
|
-
import { and, count, desc, eq, gte, inArray, lte } from 'drizzle-orm';
|
|
8
|
-
import { auditLog } from './schema/audit-log.js';
|
|
9
|
-
export class DrizzleSecurityAuditStorage {
|
|
10
|
-
db;
|
|
11
|
-
constructor(db) {
|
|
12
|
-
this.db = db;
|
|
13
|
-
}
|
|
14
|
-
async write(event) {
|
|
15
|
-
await this.db.insert(auditLog).values({
|
|
16
|
-
id: event.id,
|
|
17
|
-
timestamp: new Date(event.timestamp),
|
|
18
|
-
eventType: event.type,
|
|
19
|
-
severity: event.severity,
|
|
20
|
-
agentId: event.actor.id,
|
|
21
|
-
taskId: event.resource?.id ?? null,
|
|
22
|
-
sessionId: null,
|
|
23
|
-
payload: {
|
|
24
|
-
actor: event.actor,
|
|
25
|
-
resource: event.resource,
|
|
26
|
-
action: event.action,
|
|
27
|
-
result: event.result,
|
|
28
|
-
changes: event.changes,
|
|
29
|
-
metadata: event.metadata,
|
|
30
|
-
},
|
|
31
|
-
policyViolations: [],
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
async query(query) {
|
|
35
|
-
const conditions = [];
|
|
36
|
-
if (query.types?.length) {
|
|
37
|
-
conditions.push(inArray(auditLog.eventType, query.types));
|
|
38
|
-
}
|
|
39
|
-
if (query.actorId) {
|
|
40
|
-
conditions.push(eq(auditLog.agentId, query.actorId));
|
|
41
|
-
}
|
|
42
|
-
if (query.startDate) {
|
|
43
|
-
conditions.push(gte(auditLog.timestamp, query.startDate));
|
|
44
|
-
}
|
|
45
|
-
if (query.endDate) {
|
|
46
|
-
conditions.push(lte(auditLog.timestamp, query.endDate));
|
|
47
|
-
}
|
|
48
|
-
if (query.severity?.length) {
|
|
49
|
-
conditions.push(inArray(auditLog.severity, query.severity));
|
|
50
|
-
}
|
|
51
|
-
const where = conditions.length > 0 ? and(...conditions) : undefined;
|
|
52
|
-
const rows = await this.db
|
|
53
|
-
.select()
|
|
54
|
-
.from(auditLog)
|
|
55
|
-
.where(where)
|
|
56
|
-
.orderBy(desc(auditLog.timestamp))
|
|
57
|
-
.limit(query.limit ?? 100)
|
|
58
|
-
.offset(query.offset ?? 0);
|
|
59
|
-
return rows.map((row) => {
|
|
60
|
-
const payload = (row.payload ?? {});
|
|
61
|
-
return {
|
|
62
|
-
id: row.id,
|
|
63
|
-
timestamp: row.timestamp.toISOString(),
|
|
64
|
-
type: row.eventType,
|
|
65
|
-
severity: row.severity,
|
|
66
|
-
actor: payload.actor ?? {
|
|
67
|
-
id: row.agentId,
|
|
68
|
-
type: 'system',
|
|
69
|
-
},
|
|
70
|
-
resource: payload.resource,
|
|
71
|
-
action: payload.action ?? row.eventType,
|
|
72
|
-
result: payload.result ?? 'success',
|
|
73
|
-
changes: payload.changes,
|
|
74
|
-
metadata: payload.metadata,
|
|
75
|
-
};
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
async count(query) {
|
|
79
|
-
const conditions = [];
|
|
80
|
-
if (query.types?.length) {
|
|
81
|
-
conditions.push(inArray(auditLog.eventType, query.types));
|
|
82
|
-
}
|
|
83
|
-
if (query.actorId) {
|
|
84
|
-
conditions.push(eq(auditLog.agentId, query.actorId));
|
|
85
|
-
}
|
|
86
|
-
if (query.startDate) {
|
|
87
|
-
conditions.push(gte(auditLog.timestamp, query.startDate));
|
|
88
|
-
}
|
|
89
|
-
if (query.endDate) {
|
|
90
|
-
conditions.push(lte(auditLog.timestamp, query.endDate));
|
|
91
|
-
}
|
|
92
|
-
const where = conditions.length > 0 ? and(...conditions) : undefined;
|
|
93
|
-
const [result] = await this.db
|
|
94
|
-
.select({ total: count() })
|
|
95
|
-
.from(auditLog)
|
|
96
|
-
.where(where);
|
|
97
|
-
return result?.total ?? 0;
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
//# sourceMappingURL=security-audit-storage.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"security-audit-storage.js","sourceRoot":"","sources":["../src/security-audit-storage.ts"],"names":[],"mappings":"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"}
|