| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- import { z } from "zod"
- import { fn } from "./util/fn"
- import { centsToMicroCents } from "./util/price"
- import { Actor } from "./actor"
- import { Database, eq } from "./drizzle"
- import { Identifier } from "./identifier"
- import { UserTable } from "./schema/user.sql"
- import { BillingTable } from "./schema/billing.sql"
- import { WorkspaceTable } from "./schema/workspace.sql"
- import { Key } from "./key"
- export namespace Workspace {
- export const create = fn(z.void(), async () => {
- const account = Actor.assert("account")
- const workspaceID = Identifier.create("workspace")
- await Database.transaction(async (tx) => {
- await tx.insert(WorkspaceTable).values({
- id: workspaceID,
- })
- await tx.insert(UserTable).values({
- workspaceID,
- id: Identifier.create("user"),
- email: account.properties.email,
- name: "",
- })
- await tx.insert(BillingTable).values({
- workspaceID,
- id: Identifier.create("billing"),
- balance: 0,
- })
- })
- await Actor.provide(
- "system",
- {
- workspaceID,
- },
- async () => {
- await Key.create({ name: "Default API Key" })
- },
- )
- return workspaceID
- })
- export async function list() {
- const account = Actor.assert("account")
- return Database.use(async (tx) => {
- return tx
- .select({
- id: WorkspaceTable.id,
- slug: WorkspaceTable.slug,
- name: WorkspaceTable.name,
- })
- .from(UserTable)
- .innerJoin(WorkspaceTable, eq(UserTable.workspaceID, WorkspaceTable.id))
- .where(eq(UserTable.email, account.properties.email))
- })
- }
- }
|