Spaces:
Paused
Paused
| import { pgTable, uuid, text, timestamp, index } from "drizzle-orm/pg-core"; | |
| import { agents } from "./agents.js"; | |
| import { companies } from "./companies.js"; | |
| export const agentApiKeys = pgTable( | |
| "agent_api_keys", | |
| { | |
| id: uuid("id").primaryKey().defaultRandom(), | |
| agentId: uuid("agent_id").notNull().references(() => agents.id), | |
| companyId: uuid("company_id").notNull().references(() => companies.id), | |
| name: text("name").notNull(), | |
| keyHash: text("key_hash").notNull(), | |
| lastUsedAt: timestamp("last_used_at", { withTimezone: true }), | |
| revokedAt: timestamp("revoked_at", { withTimezone: true }), | |
| createdAt: timestamp("created_at", { withTimezone: true }).notNull().defaultNow(), | |
| }, | |
| (table) => ({ | |
| keyHashIdx: index("agent_api_keys_key_hash_idx").on(table.keyHash), | |
| companyAgentIdx: index("agent_api_keys_company_agent_idx").on(table.companyId, table.agentId), | |
| }), | |
| ); | |