import { and, desc, eq } from "drizzle-orm"; import type { Db } from "@paperclip/db"; import { activityLog } from "@paperclip/db"; export interface ActivityFilters { companyId: string; agentId?: string; entityType?: string; entityId?: string; } export function activityService(db: Db) { return { list: (filters: ActivityFilters) => { const conditions = [eq(activityLog.companyId, filters.companyId)]; if (filters.agentId) { conditions.push(eq(activityLog.agentId, filters.agentId)); } if (filters.entityType) { conditions.push(eq(activityLog.entityType, filters.entityType)); } if (filters.entityId) { conditions.push(eq(activityLog.entityId, filters.entityId)); } return db.select().from(activityLog).where(and(...conditions)).orderBy(desc(activityLog.createdAt)); }, create: (data: typeof activityLog.$inferInsert) => db .insert(activityLog) .values(data) .returning() .then((rows) => rows[0]), }; }