mirror of
https://github.com/nestriness/nestri.git
synced 2025-12-12 08:45:38 +02:00
## Description <!-- Briefly describe the purpose and scope of your changes --> <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Introduced a new subscription API endpoint for managing subscriptions and products. - Enhanced subscription management with new entities and functionalities. - Added functionality to retrieve current timestamps in both local and UTC formats. - Added Polar.sh integration with customer portal and checkout session creation APIs. - **Refactor** - Redesigned team details to now present members and subscription information instead of a plan type. - Enhanced member management by incorporating role assignments. - Streamlined user data handling and removed legacy subscription event logic. - Simplified error handling in actor functions for better clarity. - Updated plan types and UI labels to reflect new subscription tiers. - Improved database indexing for Steam user data. - **Chores** - Updated the database schema with new tables and fields to support subscription, team, and member enhancements. - Extended identifier prefixes to broaden system integration. - Added new secrets related to pricing plans in infrastructure configuration. - Configured API and auth routing with new domain and routing rules. <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
21 lines
677 B
TypeScript
21 lines
677 B
TypeScript
import { teamIndexes } from "../team/team.sql";
|
|
import { timestamps, utc, teamID } from "../drizzle/types";
|
|
import { index, pgTable, text, uniqueIndex, varchar } from "drizzle-orm/pg-core";
|
|
|
|
export const role = ["admin", "member", "owner"] as const;
|
|
|
|
export const memberTable = pgTable(
|
|
"member",
|
|
{
|
|
...teamID,
|
|
...timestamps,
|
|
role: text("role", { enum: role }).notNull(),
|
|
timeSeen: utc("time_seen"),
|
|
email: varchar("email", { length: 255 }).notNull(),
|
|
},
|
|
(table) => [
|
|
...teamIndexes(table),
|
|
index("email_global").on(table.email),
|
|
uniqueIndex("member_email").on(table.teamID, table.email),
|
|
],
|
|
); |