This commit is contained in:
Frank
2025-10-03 07:36:12 -04:00
parent 600b512c9c
commit 60e21642a5

View File

@@ -1,13 +1,14 @@
import { Stripe } from "stripe"
import { Database, eq, sql } from "./drizzle"
import { and, Database, eq, sql } from "./drizzle"
import { BillingTable, PaymentTable, UsageTable } from "./schema/billing.sql"
import { Actor } from "./actor"
import { fn } from "./util/fn"
import { z } from "zod"
import { User } from "./user"
import { Resource } from "@opencode/console-resource"
import { Identifier } from "./identifier"
import { centsToMicroCents } from "./util/price"
import { UserTable } from "./schema/user.sql"
import { AccountTable } from "./schema/account.sql"
export namespace Billing {
export const CHARGE_NAME = "opencode credits"
@@ -168,10 +169,19 @@ export namespace Billing {
cancelUrl: z.string(),
}),
async (input) => {
const account = Actor.assert("user")
const user = Actor.assert("user")
const { successUrl, cancelUrl } = input
const user = await User.fromID(account.properties.userID)
const email = await Database.use((tx) =>
tx
.select({
email: AccountTable.email,
})
.from(UserTable)
.innerJoin(AccountTable, eq(UserTable.accountID, AccountTable.id))
.where(and(eq(UserTable.id, user.properties.userID), eq(UserTable.workspaceID, Actor.workspace())))
.then((rows) => rows[0]?.email),
)
const customer = await Billing.get()
const session = await Billing.stripe().checkout.sessions.create({
mode: "payment",
@@ -206,7 +216,7 @@ export namespace Billing {
},
}
: {
customer_email: user.email!,
customer_email: email,
customer_creation: "always",
}),
currency: "usd",