@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.
Files changed (138) hide show
  1. package/dist/cleanup/cross-db-cleanup.d.ts +19 -0
  2. package/dist/cleanup/cross-db-cleanup.d.ts.map +1 -1
  3. package/dist/cleanup/cross-db-cleanup.js +40 -1
  4. package/dist/cleanup/cross-db-cleanup.js.map +1 -1
  5. package/dist/cleanup/index.d.ts +2 -1
  6. package/dist/cleanup/index.d.ts.map +1 -1
  7. package/dist/cleanup/index.js +2 -1
  8. package/dist/cleanup/index.js.map +1 -1
  9. package/dist/cleanup/rag-site-cleanup.d.ts +58 -0
  10. package/dist/cleanup/rag-site-cleanup.d.ts.map +1 -0
  11. package/dist/cleanup/rag-site-cleanup.js +68 -0
  12. package/dist/cleanup/rag-site-cleanup.js.map +1 -0
  13. package/dist/client/index.d.ts +1 -1
  14. package/dist/client/index.d.ts.map +1 -1
  15. package/dist/client/index.js +3 -6
  16. package/dist/client/index.js.map +1 -1
  17. package/dist/client/types.d.ts.map +1 -1
  18. package/dist/pool.d.ts +4 -0
  19. package/dist/pool.d.ts.map +1 -1
  20. package/dist/pool.js +46 -20
  21. package/dist/pool.js.map +1 -1
  22. package/dist/queries/conversations.d.ts +29 -0
  23. package/dist/queries/conversations.d.ts.map +1 -0
  24. package/dist/queries/conversations.js +80 -0
  25. package/dist/queries/conversations.js.map +1 -0
  26. package/dist/queries/orders.d.ts +91 -0
  27. package/dist/queries/orders.d.ts.map +1 -0
  28. package/dist/queries/orders.js +36 -0
  29. package/dist/queries/orders.js.map +1 -0
  30. package/dist/queries/pages.d.ts.map +1 -1
  31. package/dist/queries/pages.js +0 -5
  32. package/dist/queries/pages.js.map +1 -1
  33. package/dist/queries/posts.d.ts +31 -0
  34. package/dist/queries/posts.d.ts.map +1 -1
  35. package/dist/queries/posts.js +21 -0
  36. package/dist/queries/posts.js.map +1 -1
  37. package/dist/queries/products.d.ts +102 -0
  38. package/dist/queries/products.d.ts.map +1 -0
  39. package/dist/queries/products.js +55 -0
  40. package/dist/queries/products.js.map +1 -0
  41. package/dist/queries/ticket-comments.d.ts +25 -0
  42. package/dist/queries/ticket-comments.d.ts.map +1 -1
  43. package/dist/queries/ticket-comments.js +28 -1
  44. package/dist/queries/ticket-comments.js.map +1 -1
  45. package/dist/queries/tickets.d.ts +41 -0
  46. package/dist/queries/tickets.d.ts.map +1 -1
  47. package/dist/queries/tickets.js +24 -0
  48. package/dist/queries/tickets.js.map +1 -1
  49. package/dist/queries/users.d.ts +118 -0
  50. package/dist/queries/users.d.ts.map +1 -1
  51. package/dist/queries/users.js +51 -1
  52. package/dist/queries/users.js.map +1 -1
  53. package/dist/schema/accounts.d.ts.map +1 -1
  54. package/dist/schema/accounts.js +2 -0
  55. package/dist/schema/accounts.js.map +1 -1
  56. package/dist/schema/agents.d.ts +133 -0
  57. package/dist/schema/agents.d.ts.map +1 -1
  58. package/dist/schema/agents.js +28 -2
  59. package/dist/schema/agents.js.map +1 -1
  60. package/dist/schema/circuit-breaker.d.ts +139 -0
  61. package/dist/schema/circuit-breaker.d.ts.map +1 -0
  62. package/dist/schema/circuit-breaker.js +28 -0
  63. package/dist/schema/circuit-breaker.js.map +1 -0
  64. package/dist/schema/crdt-operations.d.ts.map +1 -1
  65. package/dist/schema/crdt-operations.js +5 -2
  66. package/dist/schema/crdt-operations.js.map +1 -1
  67. package/dist/schema/index.d.ts +7 -0
  68. package/dist/schema/index.d.ts.map +1 -1
  69. package/dist/schema/index.js +24 -4
  70. package/dist/schema/index.js.map +1 -1
  71. package/dist/schema/licenses.d.ts +34 -0
  72. package/dist/schema/licenses.d.ts.map +1 -1
  73. package/dist/schema/licenses.js +7 -1
  74. package/dist/schema/licenses.js.map +1 -1
  75. package/dist/schema/marketplace.d.ts.map +1 -1
  76. package/dist/schema/marketplace.js +6 -2
  77. package/dist/schema/marketplace.js.map +1 -1
  78. package/dist/schema/passkeys.d.ts.map +1 -1
  79. package/dist/schema/passkeys.js +1 -0
  80. package/dist/schema/passkeys.js.map +1 -1
  81. package/dist/schema/products.d.ts +536 -0
  82. package/dist/schema/products.d.ts.map +1 -0
  83. package/dist/schema/products.js +104 -0
  84. package/dist/schema/products.js.map +1 -0
  85. package/dist/schema/rest.d.ts +4 -1
  86. package/dist/schema/rest.d.ts.map +1 -1
  87. package/dist/schema/rest.js +6 -3
  88. package/dist/schema/rest.js.map +1 -1
  89. package/dist/schema/revealcoin.d.ts +267 -0
  90. package/dist/schema/revealcoin.d.ts.map +1 -0
  91. package/dist/schema/revealcoin.js +54 -0
  92. package/dist/schema/revealcoin.js.map +1 -0
  93. package/dist/schema/sites.d.ts.map +1 -1
  94. package/dist/schema/sites.js +2 -7
  95. package/dist/schema/sites.js.map +1 -1
  96. package/dist/schema/tenants.d.ts.map +1 -1
  97. package/dist/schema/tenants.js +0 -1
  98. package/dist/schema/tenants.js.map +1 -1
  99. package/dist/schema/tickets.d.ts.map +1 -1
  100. package/dist/schema/tickets.js +5 -2
  101. package/dist/schema/tickets.js.map +1 -1
  102. package/dist/schema/users.d.ts +17 -0
  103. package/dist/schema/users.d.ts.map +1 -1
  104. package/dist/schema/users.js +2 -2
  105. package/dist/schema/users.js.map +1 -1
  106. package/dist/schema/vector.d.ts +10 -4
  107. package/dist/schema/vector.d.ts.map +1 -1
  108. package/dist/schema/vector.js +14 -5
  109. package/dist/schema/vector.js.map +1 -1
  110. package/dist/types/database.d.ts +80 -2
  111. package/dist/types/database.d.ts.map +1 -1
  112. package/dist/types/database.js +17 -1
  113. package/dist/types/database.js.map +1 -1
  114. package/dist/types/generate-contracts.js +1 -1
  115. package/dist/validation/cross-db.d.ts +6 -6
  116. package/dist/validation/cross-db.d.ts.map +1 -1
  117. package/dist/validation/cross-db.js.map +1 -1
  118. package/package.json +38 -9
  119. package/dist/queries/optimized-queries.d.ts +0 -89
  120. package/dist/queries/optimized-queries.d.ts.map +0 -1
  121. package/dist/queries/optimized-queries.js +0 -371
  122. package/dist/queries/optimized-queries.js.map +0 -1
  123. package/dist/queries/todos.d.ts +0 -37
  124. package/dist/queries/todos.d.ts.map +0 -1
  125. package/dist/queries/todos.js +0 -37
  126. package/dist/queries/todos.js.map +0 -1
  127. package/dist/schema/query.d.ts +0 -11
  128. package/dist/schema/query.d.ts.map +0 -1
  129. package/dist/schema/query.js +0 -11
  130. package/dist/schema/query.js.map +0 -1
  131. package/dist/schema/todos.d.ts +0 -98
  132. package/dist/schema/todos.d.ts.map +0 -1
  133. package/dist/schema/todos.js +0 -12
  134. package/dist/schema/todos.js.map +0 -1
  135. package/dist/security-audit-storage.d.ts +0 -54
  136. package/dist/security-audit-storage.d.ts.map +0 -1
  137. package/dist/security-audit-storage.js +0 -100
  138. package/dist/security-audit-storage.js.map +0 -1
@@ -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"}
@@ -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
@@ -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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"}