account.ts 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import { z } from "zod"
  2. import { and, eq, getTableColumns, isNull } from "drizzle-orm"
  3. import { fn } from "./util/fn"
  4. import { Database } from "./drizzle"
  5. import { Identifier } from "./identifier"
  6. import { AccountTable } from "./schema/account.sql"
  7. import { Actor } from "./actor"
  8. import { WorkspaceTable } from "./schema/workspace.sql"
  9. import { UserTable } from "./schema/user.sql"
  10. export namespace Account {
  11. export const create = fn(
  12. z.object({
  13. email: z.string().email(),
  14. id: z.string().optional(),
  15. }),
  16. async (input) =>
  17. Database.transaction(async (tx) => {
  18. const id = input.id ?? Identifier.create("account")
  19. await tx.insert(AccountTable).values({
  20. id,
  21. email: input.email,
  22. })
  23. return id
  24. }),
  25. )
  26. export const fromID = fn(z.string(), async (id) =>
  27. Database.transaction(async (tx) => {
  28. return tx
  29. .select()
  30. .from(AccountTable)
  31. .where(eq(AccountTable.id, id))
  32. .execute()
  33. .then((rows) => rows[0])
  34. }),
  35. )
  36. export const fromEmail = fn(z.string().email(), async (email) =>
  37. Database.transaction(async (tx) => {
  38. return tx
  39. .select()
  40. .from(AccountTable)
  41. .where(eq(AccountTable.email, email))
  42. .execute()
  43. .then((rows) => rows[0])
  44. }),
  45. )
  46. export const workspaces = async () => {
  47. const actor = Actor.assert("account")
  48. return Database.transaction(async (tx) =>
  49. tx
  50. .select(getTableColumns(WorkspaceTable))
  51. .from(WorkspaceTable)
  52. .innerJoin(UserTable, eq(UserTable.workspaceID, WorkspaceTable.id))
  53. .where(
  54. and(
  55. eq(UserTable.email, actor.properties.email),
  56. isNull(UserTable.timeDeleted),
  57. isNull(WorkspaceTable.timeDeleted),
  58. ),
  59. )
  60. .execute(),
  61. )
  62. }
  63. }