فهرست منبع

ignore: cloud

Jay V 5 ماه پیش
والد
کامیت
4d81f90dde
3فایلهای تغییر یافته به همراه22 افزوده شده و 27 حذف شده
  1. 15 22
      cloud/app/src/context/auth.tsx
  2. 2 1
      cloud/app/src/routes/index.tsx
  3. 5 4
      cloud/app/src/routes/workspace/[workspaceID].tsx

+ 15 - 22
cloud/app/src/context/auth.tsx

@@ -1,5 +1,3 @@
-
-
 import { useSession } from "vinxi/http"
 import { createClient } from "@openauthjs/openauth/client"
 import { getRequestEvent } from "solid-js/web"
@@ -20,7 +18,7 @@ export const getActor = query(async (): Promise<Actor.Info> => {
   const evt = getRequestEvent()
   const url = new URL(evt!.request.headers.get("referer") ?? evt!.request.url)
   const auth = await useAuthSession()
-  const [workspaceHint] = url.pathname.split("/").filter((x) => x.length > 0)
+  const [, workspaceHint] = url.pathname.split("/").filter((x) => x.length > 0)
   if (!workspaceHint) {
     if (auth.data.current) {
       const current = auth.data.account[auth.data.current]
@@ -34,7 +32,7 @@ export const getActor = query(async (): Promise<Actor.Info> => {
     }
     if (Object.keys(auth.data.account ?? {}).length > 0) {
       const current = Object.values(auth.data.account)[0]
-      await auth.update(val => ({
+      await auth.update((val) => ({
         ...val,
         current: current.id,
       }))
@@ -53,18 +51,14 @@ export const getActor = query(async (): Promise<Actor.Info> => {
   }
   const accounts = Object.keys(auth.data.account)
   const result = await Database.transaction(async (tx) => {
-    return await tx.select({
-      user: UserTable
-    })
+    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),
-        )
-      )
+      .where(and(inArray(AccountTable.id, accounts), eq(WorkspaceTable.id, workspaceHint)))
       .limit(1)
       .execute()
       .then((x) => x[0])
@@ -81,17 +75,19 @@ export const getActor = query(async (): Promise<Actor.Info> => {
   throw redirect("/auth/authorize")
 }, "actor")
 
-
 export const AuthClient = createClient({
   clientID: "app",
   issuer: import.meta.env.VITE_AUTH_URL,
 })
 
 export interface AuthSession {
-  account: Record<string, {
-    id: string
-    email: string
-  }>
+  account: Record<
+    string,
+    {
+      id: string
+      email: string
+    }
+  >
   current?: string
 }
 
@@ -106,7 +102,4 @@ export function useAuthSession() {
   })
 }
 
-
-export function AuthProvider() {
-}
-
+export function AuthProvider() { }

+ 2 - 1
cloud/app/src/routes/index.tsx

@@ -23,9 +23,10 @@ function CopyStatus() {
 const isLoggedIn = query(async () => {
   "use server"
   const actor = await getActor()
+  console.log(actor)
   if (actor.type === "account") {
     const workspaces = await withActor(() => Account.workspaces())
-    throw redirect("/" + workspaces[0].id)
+    throw redirect(`/workspace/${workspaces[0].id}`)
   }
   return false
 }, "isLoggedIn")

+ 5 - 4
cloud/app/src/routes/[workspaceID].tsx → cloud/app/src/routes/workspace/[workspaceID].tsx

@@ -42,11 +42,12 @@ const createCheckoutUrl = action(async (successUrl: string, cancelUrl: string) =
   return withActor(() => Billing.generateCheckoutUrl({ successUrl, cancelUrl }))
 }, "checkoutUrl")
 
-//export const route = {
-//  preload: () => listKeys(),
-//}
+const createPortalUrl = action(async (returnUrl: string) => {
+  "use server"
+  return withActor(() => Billing.generatePortalUrl({ returnUrl }))
+}, "portalUrl")
 
-export default function () {
+export default function() {
   const actor = createAsync(() => getActor())
 
   /////////////////