summaryrefslogtreecommitdiffhomepage
path: root/packages/cloud/function/src
diff options
context:
space:
mode:
Diffstat (limited to 'packages/cloud/function/src')
-rw-r--r--packages/cloud/function/src/auth.ts140
-rw-r--r--packages/cloud/function/src/log-processor.ts49
2 files changed, 0 insertions, 189 deletions
diff --git a/packages/cloud/function/src/auth.ts b/packages/cloud/function/src/auth.ts
deleted file mode 100644
index 776855e46..000000000
--- a/packages/cloud/function/src/auth.ts
+++ /dev/null
@@ -1,140 +0,0 @@
-import { z } from "zod"
-import { issuer } from "@openauthjs/openauth"
-import type { Theme } from "@openauthjs/openauth/ui/theme"
-import { createSubjects } from "@openauthjs/openauth/subject"
-import { THEME_OPENAUTH } from "@openauthjs/openauth/ui/theme"
-import { GithubProvider } from "@openauthjs/openauth/provider/github"
-import { GoogleOidcProvider } from "@openauthjs/openauth/provider/google"
-import { CloudflareStorage } from "@openauthjs/openauth/storage/cloudflare"
-import { Account } from "@opencode/cloud-core/account.js"
-import { Workspace } from "@opencode/cloud-core/workspace.js"
-import { Actor } from "@opencode/cloud-core/actor.js"
-import { Resource } from "@opencode/cloud-resource"
-import { Database } from "@opencode/cloud-core/drizzle/index.js"
-
-type Env = {
- AuthStorage: KVNamespace
-}
-
-export const subjects = createSubjects({
- account: z.object({
- accountID: z.string(),
- email: z.string(),
- }),
- user: z.object({
- userID: z.string(),
- workspaceID: z.string(),
- }),
-})
-
-const MY_THEME: Theme = {
- ...THEME_OPENAUTH,
- logo: "https://opencode.ai/favicon.svg",
-}
-
-export default {
- async fetch(request: Request, env: Env, ctx: ExecutionContext) {
- const result = await issuer({
- theme: MY_THEME,
- providers: {
- github: GithubProvider({
- clientID: Resource.GITHUB_CLIENT_ID_CONSOLE.value,
- clientSecret: Resource.GITHUB_CLIENT_SECRET_CONSOLE.value,
- scopes: ["read:user", "user:email"],
- }),
- google: GoogleOidcProvider({
- clientID: Resource.GOOGLE_CLIENT_ID.value,
- scopes: ["openid", "email"],
- }),
- // email: CodeProvider({
- // async request(req, state, form, error) {
- // console.log(state)
- // const params = new URLSearchParams()
- // if (error) {
- // params.set("error", error.type)
- // }
- // if (state.type === "start") {
- // return Response.redirect(process.env.AUTH_FRONTEND_URL + "/auth/email?" + params.toString(), 302)
- // }
- //
- // if (state.type === "code") {
- // return Response.redirect(process.env.AUTH_FRONTEND_URL + "/auth/code?" + params.toString(), 302)
- // }
- //
- // return new Response("ok")
- // },
- // async sendCode(claims, code) {
- // const email = z.string().email().parse(claims.email)
- // const cmd = new SendEmailCommand({
- // Destination: {
- // ToAddresses: [email],
- // },
- // FromEmailAddress: `SST <auth@${Resource.Email.sender}>`,
- // Content: {
- // Simple: {
- // Body: {
- // Html: {
- // Data: `Your pin code is <strong>${code}</strong>`,
- // },
- // Text: {
- // Data: `Your pin code is ${code}`,
- // },
- // },
- // Subject: {
- // Data: "SST Console Pin Code: " + code,
- // },
- // },
- // },
- // })
- // await ses.send(cmd)
- // },
- // }),
- },
- storage: CloudflareStorage({
- namespace: env.AuthStorage,
- }),
- subjects,
- async success(ctx, response) {
- console.log(response)
-
- let email: string | undefined
-
- if (response.provider === "github") {
- const emails = (await fetch("https://api.github.com/user/emails", {
- headers: {
- Authorization: `Bearer ${response.tokenset.access}`,
- "User-Agent": "opencode",
- Accept: "application/vnd.github+json",
- },
- }).then((x) => x.json())) as any
- email = emails.find((x: any) => x.primary && x.verified)?.email
- } else if (response.provider === "google") {
- if (!response.id.email_verified) throw new Error("Google email not verified")
- email = response.id.email as string
- }
- //if (response.provider === "email") {
- // email = response.claims.email
- //}
- else throw new Error("Unsupported provider")
-
- if (!email) throw new Error("No email found")
-
- let accountID = await Account.fromEmail(email).then((x) => x?.id)
- if (!accountID) {
- console.log("creating account for", email)
- accountID = await Account.create({
- email: email!,
- })
- }
- await Actor.provide("account", { accountID, email }, async () => {
- const workspaces = await Account.workspaces()
- if (workspaces.length === 0) {
- await Workspace.create()
- }
- })
- return ctx.subject("account", accountID, { accountID, email })
- },
- }).fetch(request, env, ctx)
- return result
- },
-}
diff --git a/packages/cloud/function/src/log-processor.ts b/packages/cloud/function/src/log-processor.ts
deleted file mode 100644
index 70fcf5a44..000000000
--- a/packages/cloud/function/src/log-processor.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import { Resource } from "@opencode/cloud-resource"
-import type { TraceItem } from "@cloudflare/workers-types"
-
-export default {
- async tail(events: TraceItem[]) {
- for (const event of events) {
- if (!event.event) continue
- if (!("request" in event.event)) continue
- if (event.event.request.method !== "POST") continue
-
- const url = new URL(event.event.request.url)
- if (url.pathname !== "/zen/v1/chat/completions") return
-
- let metrics = {
- event_type: "completions",
- "cf.continent": event.event.request.cf?.continent,
- "cf.country": event.event.request.cf?.country,
- "cf.city": event.event.request.cf?.city,
- "cf.region": event.event.request.cf?.region,
- "cf.latitude": event.event.request.cf?.latitude,
- "cf.longitude": event.event.request.cf?.longitude,
- "cf.timezone": event.event.request.cf?.timezone,
- duration: event.wallTime,
- request_length: parseInt(event.event.request.headers["content-length"] ?? "0"),
- status: event.event.response?.status ?? 0,
- ip: event.event.request.headers["x-real-ip"],
- }
- for (const log of event.logs) {
- for (const message of log.message) {
- if (!message.startsWith("_metric:")) continue
- metrics = { ...metrics, ...JSON.parse(message.slice(8)) }
- }
- }
- console.log(JSON.stringify(metrics, null, 2))
-
- const ret = await fetch("https://api.honeycomb.io/1/events/zen", {
- method: "POST",
- headers: {
- "Content-Type": "application/json",
- "X-Honeycomb-Event-Time": (event.eventTimestamp ?? Date.now()).toString(),
- "X-Honeycomb-Team": Resource.HONEYCOMB_API_KEY.value,
- },
- body: JSON.stringify(metrics),
- })
- console.log(ret.status)
- console.log(await ret.text())
- }
- },
-}