summaryrefslogtreecommitdiffhomepage
path: root/cloud/app/src
diff options
context:
space:
mode:
authorJay V <[email protected]>2025-08-28 17:10:41 -0400
committerJay V <[email protected]>2025-08-28 17:10:41 -0400
commit4d81f90dded0ad3d57a75c880c919e6809087948 (patch)
tree30af0f8341e94c8d3e4ed1972cf774d24f9698b1 /cloud/app/src
parent36ec9dddb2b09ba4a7a52764637356397ee0d639 (diff)
downloadopencode-4d81f90dded0ad3d57a75c880c919e6809087948.tar.gz
opencode-4d81f90dded0ad3d57a75c880c919e6809087948.zip
ignore: cloud
Diffstat (limited to 'cloud/app/src')
-rw-r--r--cloud/app/src/context/auth.tsx37
-rw-r--r--cloud/app/src/routes/index.tsx3
-rw-r--r--cloud/app/src/routes/workspace/[workspaceID].tsx (renamed from cloud/app/src/routes/[workspaceID].tsx)9
3 files changed, 22 insertions, 27 deletions
diff --git a/cloud/app/src/context/auth.tsx b/cloud/app/src/context/auth.tsx
index afcd3feae..59fbff6e6 100644
--- a/cloud/app/src/context/auth.tsx
+++ b/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() { }
diff --git a/cloud/app/src/routes/index.tsx b/cloud/app/src/routes/index.tsx
index 7f8433e7e..7a43f2624 100644
--- a/cloud/app/src/routes/index.tsx
+++ b/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")
diff --git a/cloud/app/src/routes/[workspaceID].tsx b/cloud/app/src/routes/workspace/[workspaceID].tsx
index 1afcc979e..00e61a0c7 100644
--- a/cloud/app/src/routes/[workspaceID].tsx
+++ b/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())
/////////////////