| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- import { getRequestEvent } from "solid-js/web"
- import { and, Database, eq, inArray } from "@opencode/cloud-core/drizzle/index.js"
- import { WorkspaceTable } from "@opencode/cloud-core/schema/workspace.sql.js"
- import { UserTable } from "@opencode/cloud-core/schema/user.sql.js"
- import { query, redirect } from "@solidjs/router"
- import { AccountTable } from "@opencode/cloud-core/schema/account.sql.js"
- import { Actor } from "@opencode/cloud-core/actor.js"
- import { createClient } from "@openauthjs/openauth/client"
- import { useAuthSession } from "./auth.session"
- export const AuthClient = createClient({
- clientID: "app",
- issuer: import.meta.env.VITE_AUTH_URL,
- })
- export const getActor = query(async (): Promise<Actor.Info> => {
- "use server"
- const evt = getRequestEvent()
- if (!evt) throw new Error("No request event")
- const url = new URL(evt.request.headers.has("x-server-id") ? evt.request.headers.get("referer")! : evt.request.url)
- const auth = await useAuthSession()
- const splits = url.pathname.split("/").filter(Boolean)
- if (splits[0] !== "workspace") {
- if (auth.data.current) {
- const current = auth.data.account[auth.data.current]
- return {
- type: "account",
- properties: {
- email: current.email,
- accountID: current.id,
- },
- }
- }
- if (Object.keys(auth.data.account ?? {}).length > 0) {
- const current = Object.values(auth.data.account)[0]
- await auth.update((val) => ({
- ...val,
- current: current.id,
- }))
- return {
- type: "account",
- properties: {
- email: current.email,
- accountID: current.id,
- },
- }
- }
- return {
- type: "public",
- properties: {},
- }
- }
- const workspaceHint = splits[1]
- const accounts = Object.keys(auth.data.account ?? {})
- const result = await Database.transaction(async (tx) => {
- return await tx
- .select({
- user: UserTable,
- })
- .from(AccountTable)
- .innerJoin(UserTable, and(eq(UserTable.email, AccountTable.email)))
- .innerJoin(WorkspaceTable, eq(WorkspaceTable.id, UserTable.workspaceID))
- .where(and(inArray(AccountTable.id, accounts), eq(WorkspaceTable.id, workspaceHint)))
- .limit(1)
- .execute()
- .then((x) => x[0])
- })
- if (result) {
- return {
- type: "user",
- properties: {
- userID: result.user.id,
- workspaceID: result.user.workspaceID,
- },
- }
- }
- throw redirect("/auth/authorize")
- }, "actor")
|