@vorionsys/contracts 0.1.0 → 0.1.2
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/CHANGELOG.md +44 -0
- package/LICENSE +190 -0
- package/README.md +435 -0
- package/dist/aci/index.d.ts +6 -62
- package/dist/aci/index.d.ts.map +1 -1
- package/dist/aci/index.js +22 -152
- package/dist/aci/index.js.map +1 -1
- package/dist/canonical/agent.d.ts +2 -2
- package/dist/canonical/agent.d.ts.map +1 -1
- package/dist/canonical/agent.js +146 -130
- package/dist/canonical/agent.js.map +1 -1
- package/dist/canonical/governance.d.ts +1 -1
- package/dist/canonical/governance.js +134 -120
- package/dist/canonical/governance.js.map +1 -1
- package/dist/canonical/index.d.ts +1 -0
- package/dist/canonical/index.d.ts.map +1 -1
- package/dist/canonical/index.js +26 -8
- package/dist/canonical/index.js.map +1 -1
- package/dist/canonical/intent.d.ts +8 -15
- package/dist/canonical/intent.d.ts.map +1 -1
- package/dist/canonical/intent.js +91 -82
- package/dist/canonical/intent.js.map +1 -1
- package/dist/canonical/middleware.d.ts +513 -0
- package/dist/canonical/middleware.d.ts.map +1 -0
- package/dist/canonical/middleware.js +218 -0
- package/dist/canonical/middleware.js.map +1 -0
- package/dist/canonical/risk-level.d.ts +1 -1
- package/dist/canonical/risk-level.js +66 -46
- package/dist/canonical/risk-level.js.map +1 -1
- package/dist/canonical/trust-band.d.ts +1 -1
- package/dist/canonical/trust-band.js +39 -28
- package/dist/canonical/trust-band.js.map +1 -1
- package/dist/canonical/trust-score.d.ts +1 -1
- package/dist/canonical/trust-score.js +46 -29
- package/dist/canonical/trust-score.js.map +1 -1
- package/dist/canonical/trust-signal.d.ts +13 -13
- package/dist/canonical/trust-signal.js +91 -78
- package/dist/canonical/trust-signal.js.map +1 -1
- package/dist/canonical/validation.js +148 -102
- package/dist/canonical/validation.js.map +1 -1
- package/dist/{aci → car}/attestation.d.ts +73 -73
- package/dist/{aci → car}/attestation.d.ts.map +1 -1
- package/dist/{aci → car}/attestation.js +69 -59
- package/dist/car/attestation.js.map +1 -0
- package/dist/car/car-string.d.ts +846 -0
- package/dist/car/car-string.d.ts.map +1 -0
- package/dist/car/car-string.js +734 -0
- package/dist/car/car-string.js.map +1 -0
- package/dist/{aci → car}/domains.d.ts +3 -3
- package/dist/{aci → car}/domains.d.ts.map +1 -1
- package/dist/{aci → car}/domains.js +57 -39
- package/dist/car/domains.js.map +1 -0
- package/dist/{aci → car}/effective-permission.d.ts +8 -8
- package/dist/{aci → car}/effective-permission.d.ts.map +1 -1
- package/dist/{aci → car}/effective-permission.js +59 -46
- package/dist/car/effective-permission.js.map +1 -0
- package/dist/{aci → car}/identity.d.ts +235 -129
- package/dist/car/identity.d.ts.map +1 -0
- package/dist/{aci → car}/identity.js +125 -105
- package/dist/car/identity.js.map +1 -0
- package/dist/car/index.d.ts +104 -0
- package/dist/car/index.d.ts.map +1 -0
- package/dist/car/index.js +401 -0
- package/dist/car/index.js.map +1 -0
- package/dist/car/jwt-claims.d.ts +1364 -0
- package/dist/car/jwt-claims.d.ts.map +1 -0
- package/dist/car/jwt-claims.js +388 -0
- package/dist/car/jwt-claims.js.map +1 -0
- package/dist/{aci → car}/levels.d.ts +5 -5
- package/dist/{aci → car}/levels.d.ts.map +1 -1
- package/dist/{aci → car}/levels.js +81 -62
- package/dist/car/levels.js.map +1 -0
- package/dist/{aci → car}/mapping.d.ts +5 -5
- package/dist/{aci → car}/mapping.d.ts.map +1 -1
- package/dist/{aci → car}/mapping.js +96 -76
- package/dist/car/mapping.js.map +1 -0
- package/dist/{aci → car}/skills.d.ts +4 -4
- package/dist/{aci → car}/skills.d.ts.map +1 -1
- package/dist/{aci → car}/skills.js +72 -50
- package/dist/car/skills.js.map +1 -0
- package/dist/{aci → car}/tiers.d.ts +3 -3
- package/dist/{aci → car}/tiers.d.ts.map +1 -1
- package/dist/{aci → car}/tiers.js +140 -113
- package/dist/car/tiers.js.map +1 -0
- package/dist/common/index.d.ts +1 -0
- package/dist/common/index.d.ts.map +1 -1
- package/dist/common/index.js +18 -1
- package/dist/common/index.js.map +1 -1
- package/dist/common/primitives.d.ts +9 -7
- package/dist/common/primitives.d.ts.map +1 -1
- package/dist/common/primitives.js +30 -25
- package/dist/common/primitives.js.map +1 -1
- package/dist/common/types.d.ts +328 -0
- package/dist/common/types.d.ts.map +1 -0
- package/dist/common/types.js +61 -0
- package/dist/common/types.js.map +1 -0
- package/dist/db/agents.d.ts +1914 -0
- package/dist/db/agents.d.ts.map +1 -0
- package/dist/db/agents.js +283 -0
- package/dist/db/agents.js.map +1 -0
- package/dist/db/api-keys.d.ts +506 -0
- package/dist/db/api-keys.d.ts.map +1 -0
- package/dist/db/api-keys.js +101 -0
- package/dist/db/api-keys.js.map +1 -0
- package/dist/db/escalations.d.ts +554 -0
- package/dist/db/escalations.d.ts.map +1 -0
- package/dist/db/escalations.js +100 -0
- package/dist/db/escalations.js.map +1 -0
- package/dist/db/index.d.ts +20 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +47 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/intents.d.ts +535 -0
- package/dist/db/intents.d.ts.map +1 -0
- package/dist/db/intents.js +93 -0
- package/dist/db/intents.js.map +1 -0
- package/dist/db/merkle.d.ts +475 -0
- package/dist/db/merkle.d.ts.map +1 -0
- package/dist/db/merkle.js +103 -0
- package/dist/db/merkle.js.map +1 -0
- package/dist/db/operations.d.ts +256 -0
- package/dist/db/operations.d.ts.map +1 -0
- package/dist/db/operations.js +68 -0
- package/dist/db/operations.js.map +1 -0
- package/dist/db/policy-versions.d.ts +149 -0
- package/dist/db/policy-versions.d.ts.map +1 -0
- package/dist/db/policy-versions.js +44 -0
- package/dist/db/policy-versions.js.map +1 -0
- package/dist/db/proofs.d.ts +412 -0
- package/dist/db/proofs.d.ts.map +1 -0
- package/dist/db/proofs.js +66 -0
- package/dist/db/proofs.js.map +1 -0
- package/dist/db/rbac.d.ts +882 -0
- package/dist/db/rbac.d.ts.map +1 -0
- package/dist/db/rbac.js +189 -0
- package/dist/db/rbac.js.map +1 -0
- package/dist/db/service-accounts.d.ts +783 -0
- package/dist/db/service-accounts.d.ts.map +1 -0
- package/dist/db/service-accounts.js +179 -0
- package/dist/db/service-accounts.js.map +1 -0
- package/dist/db/trust.d.ts +603 -0
- package/dist/db/trust.d.ts.map +1 -0
- package/dist/db/trust.js +111 -0
- package/dist/db/trust.js.map +1 -0
- package/dist/db/webhooks.d.ts +382 -0
- package/dist/db/webhooks.d.ts.map +1 -0
- package/dist/db/webhooks.js +94 -0
- package/dist/db/webhooks.js.map +1 -0
- package/dist/flags.d.ts +214 -0
- package/dist/flags.d.ts.map +1 -0
- package/dist/flags.js +443 -0
- package/dist/flags.js.map +1 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +47 -4
- package/dist/index.js.map +1 -1
- package/dist/v2/canary-probe.js +10 -7
- package/dist/v2/canary-probe.js.map +1 -1
- package/dist/v2/component.js +2 -1
- package/dist/v2/component.js.map +1 -1
- package/dist/v2/decision.js +5 -2
- package/dist/v2/decision.js.map +1 -1
- package/dist/v2/enums.js +28 -25
- package/dist/v2/enums.js.map +1 -1
- package/dist/v2/evidence.js +75 -72
- package/dist/v2/evidence.js.map +1 -1
- package/dist/v2/execution.js +2 -1
- package/dist/v2/execution.js.map +1 -1
- package/dist/v2/index.js +29 -13
- package/dist/v2/index.js.map +1 -1
- package/dist/v2/intent.js +2 -1
- package/dist/v2/intent.js.map +1 -1
- package/dist/v2/policy-bundle.js +5 -2
- package/dist/v2/policy-bundle.js.map +1 -1
- package/dist/v2/pre-action-gate.js +10 -7
- package/dist/v2/pre-action-gate.js.map +1 -1
- package/dist/v2/proof-event.d.ts +3 -1
- package/dist/v2/proof-event.d.ts.map +1 -1
- package/dist/v2/proof-event.js +2 -1
- package/dist/v2/proof-event.js.map +1 -1
- package/dist/v2/retention.js +104 -101
- package/dist/v2/retention.js.map +1 -1
- package/dist/v2/trust-delta.js +5 -2
- package/dist/v2/trust-delta.js.map +1 -1
- package/dist/v2/trust-profile.js +12 -9
- package/dist/v2/trust-profile.js.map +1 -1
- package/dist/validators/decision.d.ts +2 -2
- package/dist/validators/decision.js +49 -46
- package/dist/validators/decision.js.map +1 -1
- package/dist/validators/enums.js +14 -11
- package/dist/validators/enums.js.map +1 -1
- package/dist/validators/index.js +30 -9
- package/dist/validators/index.js.map +1 -1
- package/dist/validators/intent.js +40 -37
- package/dist/validators/intent.js.map +1 -1
- package/dist/validators/proof-event.d.ts +3 -0
- package/dist/validators/proof-event.d.ts.map +1 -1
- package/dist/validators/proof-event.js +103 -99
- package/dist/validators/proof-event.js.map +1 -1
- package/dist/validators/trust-profile.js +40 -37
- package/dist/validators/trust-profile.js.map +1 -1
- package/package.json +81 -15
- package/dist/aci/aci-string.d.ts +0 -539
- package/dist/aci/aci-string.d.ts.map +0 -1
- package/dist/aci/aci-string.js +0 -563
- package/dist/aci/aci-string.js.map +0 -1
- package/dist/aci/attestation.js.map +0 -1
- package/dist/aci/domains.js.map +0 -1
- package/dist/aci/effective-permission.js.map +0 -1
- package/dist/aci/identity.d.ts.map +0 -1
- package/dist/aci/identity.js.map +0 -1
- package/dist/aci/jwt-claims.d.ts +0 -756
- package/dist/aci/jwt-claims.d.ts.map +0 -1
- package/dist/aci/jwt-claims.js +0 -335
- package/dist/aci/jwt-claims.js.map +0 -1
- package/dist/aci/levels.js.map +0 -1
- package/dist/aci/mapping.js.map +0 -1
- package/dist/aci/skills.js.map +0 -1
- package/dist/aci/tiers.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-accounts.d.ts","sourceRoot":"","sources":["../../src/db/service-accounts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Service Accounts Schema
|
|
4
|
+
*
|
|
5
|
+
* Database schema for service-to-service authentication accounts
|
|
6
|
+
* using Drizzle ORM.
|
|
7
|
+
*
|
|
8
|
+
* @packageDocumentation
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
exports.serviceTokens = exports.serviceAccountAuditLog = exports.serviceAccountAuditEventEnum = exports.serviceAccounts = exports.serviceAccountStatusEnum = void 0;
|
|
12
|
+
const pg_core_1 = require("drizzle-orm/pg-core");
|
|
13
|
+
// =============================================================================
|
|
14
|
+
// ENUMS
|
|
15
|
+
// =============================================================================
|
|
16
|
+
/**
|
|
17
|
+
* Service account status enum
|
|
18
|
+
*/
|
|
19
|
+
exports.serviceAccountStatusEnum = (0, pg_core_1.pgEnum)('service_account_status', [
|
|
20
|
+
'active',
|
|
21
|
+
'revoked',
|
|
22
|
+
'suspended',
|
|
23
|
+
]);
|
|
24
|
+
// =============================================================================
|
|
25
|
+
// SERVICE ACCOUNTS TABLE
|
|
26
|
+
// =============================================================================
|
|
27
|
+
/**
|
|
28
|
+
* Service accounts table - stores service account credentials and metadata
|
|
29
|
+
*/
|
|
30
|
+
exports.serviceAccounts = (0, pg_core_1.pgTable)('service_accounts', {
|
|
31
|
+
// Primary key
|
|
32
|
+
id: (0, pg_core_1.uuid)('id').primaryKey().defaultRandom(),
|
|
33
|
+
// Unique client identifier (e.g., svc_abc123...)
|
|
34
|
+
clientId: (0, pg_core_1.text)('client_id').notNull().unique(),
|
|
35
|
+
// Hashed client secret (SHA-256)
|
|
36
|
+
clientSecret: (0, pg_core_1.text)('client_secret').notNull(),
|
|
37
|
+
// Human-readable name
|
|
38
|
+
name: (0, pg_core_1.text)('name').notNull(),
|
|
39
|
+
// Description of the service
|
|
40
|
+
description: (0, pg_core_1.text)('description'),
|
|
41
|
+
// Tenant ownership
|
|
42
|
+
tenantId: (0, pg_core_1.uuid)('tenant_id').notNull(),
|
|
43
|
+
// Permissions granted to this service
|
|
44
|
+
permissions: (0, pg_core_1.jsonb)('permissions').$type().notNull().default([]),
|
|
45
|
+
// Optional IP whitelist for additional security
|
|
46
|
+
ipWhitelist: (0, pg_core_1.jsonb)('ip_whitelist').$type(),
|
|
47
|
+
// Status
|
|
48
|
+
status: (0, exports.serviceAccountStatusEnum)('status').notNull().default('active'),
|
|
49
|
+
// Timestamps
|
|
50
|
+
createdAt: (0, pg_core_1.timestamp)('created_at', { withTimezone: true }).notNull().defaultNow(),
|
|
51
|
+
lastUsedAt: (0, pg_core_1.timestamp)('last_used_at', { withTimezone: true }),
|
|
52
|
+
secretRotatedAt: (0, pg_core_1.timestamp)('secret_rotated_at', { withTimezone: true }),
|
|
53
|
+
// User who created the account
|
|
54
|
+
createdBy: (0, pg_core_1.text)('created_by'),
|
|
55
|
+
// Additional metadata
|
|
56
|
+
metadata: (0, pg_core_1.jsonb)('metadata').$type().default({}),
|
|
57
|
+
}, (table) => ({
|
|
58
|
+
// Unique constraint on client ID for fast lookup
|
|
59
|
+
clientIdUniqueIdx: (0, pg_core_1.uniqueIndex)('service_accounts_client_id_unique_idx').on(table.clientId),
|
|
60
|
+
// Index by tenant for listing
|
|
61
|
+
tenantIdIdx: (0, pg_core_1.index)('service_accounts_tenant_id_idx').on(table.tenantId),
|
|
62
|
+
// Composite index for listing with status filter
|
|
63
|
+
tenantStatusIdx: (0, pg_core_1.index)('service_accounts_tenant_status_idx').on(table.tenantId, table.status),
|
|
64
|
+
// Index for status-based queries
|
|
65
|
+
statusIdx: (0, pg_core_1.index)('service_accounts_status_idx').on(table.status),
|
|
66
|
+
// Index for finding accounts by name within tenant
|
|
67
|
+
tenantNameIdx: (0, pg_core_1.index)('service_accounts_tenant_name_idx').on(table.tenantId, table.name),
|
|
68
|
+
// Index for audit: recently used accounts
|
|
69
|
+
lastUsedAtIdx: (0, pg_core_1.index)('service_accounts_last_used_at_idx').on(table.lastUsedAt),
|
|
70
|
+
}));
|
|
71
|
+
// =============================================================================
|
|
72
|
+
// SERVICE ACCOUNT AUDIT LOG TABLE
|
|
73
|
+
// =============================================================================
|
|
74
|
+
/**
|
|
75
|
+
* Service account audit event types
|
|
76
|
+
*/
|
|
77
|
+
exports.serviceAccountAuditEventEnum = (0, pg_core_1.pgEnum)('service_account_audit_event', [
|
|
78
|
+
'created',
|
|
79
|
+
'updated',
|
|
80
|
+
'revoked',
|
|
81
|
+
'suspended',
|
|
82
|
+
'reactivated',
|
|
83
|
+
'deleted',
|
|
84
|
+
'secret_rotated',
|
|
85
|
+
'auth_success',
|
|
86
|
+
'auth_failure',
|
|
87
|
+
'permission_denied',
|
|
88
|
+
'ip_blocked',
|
|
89
|
+
]);
|
|
90
|
+
/**
|
|
91
|
+
* Service account audit log table - tracks all changes to service accounts
|
|
92
|
+
*/
|
|
93
|
+
exports.serviceAccountAuditLog = (0, pg_core_1.pgTable)('service_account_audit_log', {
|
|
94
|
+
// Primary key
|
|
95
|
+
id: (0, pg_core_1.uuid)('id').primaryKey().defaultRandom(),
|
|
96
|
+
// Reference to service account
|
|
97
|
+
serviceAccountId: (0, pg_core_1.uuid)('service_account_id').notNull(),
|
|
98
|
+
// Client ID (stored separately for audit even if account deleted)
|
|
99
|
+
clientId: (0, pg_core_1.text)('client_id').notNull(),
|
|
100
|
+
// Tenant ID (stored separately for audit)
|
|
101
|
+
tenantId: (0, pg_core_1.uuid)('tenant_id').notNull(),
|
|
102
|
+
// Event type
|
|
103
|
+
event: (0, exports.serviceAccountAuditEventEnum)('event').notNull(),
|
|
104
|
+
// Actor who performed the action (user ID or system)
|
|
105
|
+
actorId: (0, pg_core_1.text)('actor_id'),
|
|
106
|
+
actorType: (0, pg_core_1.text)('actor_type').notNull().default('user'), // 'user', 'system', 'service'
|
|
107
|
+
// Request context
|
|
108
|
+
ipAddress: (0, pg_core_1.text)('ip_address'),
|
|
109
|
+
userAgent: (0, pg_core_1.text)('user_agent'),
|
|
110
|
+
requestId: (0, pg_core_1.text)('request_id'),
|
|
111
|
+
// Event details
|
|
112
|
+
details: (0, pg_core_1.jsonb)('details').$type().default({}),
|
|
113
|
+
// Previous state (for updates)
|
|
114
|
+
previousState: (0, pg_core_1.jsonb)('previous_state').$type(),
|
|
115
|
+
// New state (for updates)
|
|
116
|
+
newState: (0, pg_core_1.jsonb)('new_state').$type(),
|
|
117
|
+
// Timestamp
|
|
118
|
+
timestamp: (0, pg_core_1.timestamp)('timestamp', { withTimezone: true }).notNull().defaultNow(),
|
|
119
|
+
}, (table) => ({
|
|
120
|
+
// Index for looking up audit by service account
|
|
121
|
+
serviceAccountIdIdx: (0, pg_core_1.index)('service_account_audit_service_account_id_idx').on(table.serviceAccountId),
|
|
122
|
+
// Index for looking up audit by client ID (even after deletion)
|
|
123
|
+
clientIdIdx: (0, pg_core_1.index)('service_account_audit_client_id_idx').on(table.clientId),
|
|
124
|
+
// Index for tenant-wide audit queries
|
|
125
|
+
tenantIdIdx: (0, pg_core_1.index)('service_account_audit_tenant_id_idx').on(table.tenantId),
|
|
126
|
+
// Index for filtering by event type
|
|
127
|
+
eventIdx: (0, pg_core_1.index)('service_account_audit_event_idx').on(table.event),
|
|
128
|
+
// Index for time-based queries
|
|
129
|
+
timestampIdx: (0, pg_core_1.index)('service_account_audit_timestamp_idx').on(table.timestamp),
|
|
130
|
+
// Composite for tenant + time range queries
|
|
131
|
+
tenantTimestampIdx: (0, pg_core_1.index)('service_account_audit_tenant_timestamp_idx').on(table.tenantId, table.timestamp),
|
|
132
|
+
// Composite for service account + event queries
|
|
133
|
+
serviceAccountEventIdx: (0, pg_core_1.index)('service_account_audit_sa_event_idx').on(table.serviceAccountId, table.event),
|
|
134
|
+
}));
|
|
135
|
+
// =============================================================================
|
|
136
|
+
// SERVICE TOKENS TABLE (Optional - for token tracking/revocation)
|
|
137
|
+
// =============================================================================
|
|
138
|
+
/**
|
|
139
|
+
* Service tokens table - tracks issued service tokens for revocation support
|
|
140
|
+
* Optional: Only needed if you want to track and revoke individual tokens
|
|
141
|
+
*/
|
|
142
|
+
exports.serviceTokens = (0, pg_core_1.pgTable)('service_tokens', {
|
|
143
|
+
// Primary key - the JWT ID (jti)
|
|
144
|
+
id: (0, pg_core_1.uuid)('id').primaryKey().defaultRandom(),
|
|
145
|
+
// JWT ID for lookup
|
|
146
|
+
jti: (0, pg_core_1.text)('jti').notNull().unique(),
|
|
147
|
+
// Reference to service account
|
|
148
|
+
serviceAccountId: (0, pg_core_1.uuid)('service_account_id')
|
|
149
|
+
.notNull()
|
|
150
|
+
.references(() => exports.serviceAccounts.id, { onDelete: 'cascade' }),
|
|
151
|
+
// Client ID (for queries after account deletion)
|
|
152
|
+
clientId: (0, pg_core_1.text)('client_id').notNull(),
|
|
153
|
+
// Tenant ID
|
|
154
|
+
tenantId: (0, pg_core_1.uuid)('tenant_id').notNull(),
|
|
155
|
+
// Token metadata
|
|
156
|
+
issuedAt: (0, pg_core_1.timestamp)('issued_at', { withTimezone: true }).notNull(),
|
|
157
|
+
expiresAt: (0, pg_core_1.timestamp)('expires_at', { withTimezone: true }).notNull(),
|
|
158
|
+
// Revocation status
|
|
159
|
+
revokedAt: (0, pg_core_1.timestamp)('revoked_at', { withTimezone: true }),
|
|
160
|
+
revokedBy: (0, pg_core_1.text)('revoked_by'),
|
|
161
|
+
revokedReason: (0, pg_core_1.text)('revoked_reason'),
|
|
162
|
+
// Request context at issuance
|
|
163
|
+
issuedIp: (0, pg_core_1.text)('issued_ip'),
|
|
164
|
+
issuedUserAgent: (0, pg_core_1.text)('issued_user_agent'),
|
|
165
|
+
}, (table) => ({
|
|
166
|
+
// Unique index on JTI for fast lookup
|
|
167
|
+
jtiUniqueIdx: (0, pg_core_1.uniqueIndex)('service_tokens_jti_unique_idx').on(table.jti),
|
|
168
|
+
// Index for service account token queries
|
|
169
|
+
serviceAccountIdIdx: (0, pg_core_1.index)('service_tokens_service_account_id_idx').on(table.serviceAccountId),
|
|
170
|
+
// Index for tenant queries
|
|
171
|
+
tenantIdIdx: (0, pg_core_1.index)('service_tokens_tenant_id_idx').on(table.tenantId),
|
|
172
|
+
// Index for expiration cleanup
|
|
173
|
+
expiresAtIdx: (0, pg_core_1.index)('service_tokens_expires_at_idx').on(table.expiresAt),
|
|
174
|
+
// Index for revocation queries
|
|
175
|
+
revokedAtIdx: (0, pg_core_1.index)('service_tokens_revoked_at_idx').on(table.revokedAt),
|
|
176
|
+
// Composite for finding active tokens
|
|
177
|
+
activeTokensIdx: (0, pg_core_1.index)('service_tokens_active_idx').on(table.serviceAccountId, table.expiresAt, table.revokedAt),
|
|
178
|
+
}));
|
|
179
|
+
//# sourceMappingURL=service-accounts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-accounts.js","sourceRoot":"","sources":["../../src/db/service-accounts.ts"],"names":[],"mappings":"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"}
|