mirror of
https://github.com/Memo-2023/mana-monorepo.git
synced 2026-05-17 00:39:41 +02:00
Mirrors the frontend unification (single IndexedDB) on the backend. All services now use pgSchema() for isolation within one shared database, enabling cross-schema JOINs, simplified ops, and zero DB setup for new apps. - Migrate 7 services from pgTable() to pgSchema(): mana-user (usr), mana-media (media), todo, traces, presi, uload, cards - Update all DATABASE_URLs in .env.development, docker-compose, configs - Rewrite init-db scripts for 2 databases + 12 schemas - Rewrite setup-databases.sh for consolidated architecture - Update shared-drizzle-config default to mana_platform - Update CLAUDE.md with new database architecture docs Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
40 lines
1.5 KiB
TypeScript
40 lines
1.5 KiB
TypeScript
import { uuid, text, integer, timestamp, index, pgEnum } from 'drizzle-orm/pg-core';
|
|
import { relations } from 'drizzle-orm';
|
|
import { cardsSchema } from './schema';
|
|
import { decks } from './decks';
|
|
|
|
// Study mode enum
|
|
export const studyModeEnum = pgEnum('study_mode', ['all', 'new', 'review', 'favorites', 'random']);
|
|
|
|
export const studySessions = cardsSchema.table(
|
|
'study_sessions',
|
|
{
|
|
id: uuid('id').primaryKey().defaultRandom(),
|
|
deckId: uuid('deck_id')
|
|
.notNull()
|
|
.references(() => decks.id, { onDelete: 'cascade' }),
|
|
userId: text('user_id').notNull(),
|
|
mode: studyModeEnum('mode').notNull(),
|
|
totalCards: integer('total_cards').notNull().default(0),
|
|
completedCards: integer('completed_cards').notNull().default(0),
|
|
correctCards: integer('correct_cards').notNull().default(0),
|
|
startedAt: timestamp('started_at', { withTimezone: true }).defaultNow().notNull(),
|
|
completedAt: timestamp('completed_at', { withTimezone: true }),
|
|
timeSpentSeconds: integer('time_spent_seconds').default(0).notNull(),
|
|
},
|
|
(table) => [
|
|
index('idx_study_sessions_user_id').on(table.userId),
|
|
index('idx_study_sessions_deck_id').on(table.deckId),
|
|
index('idx_study_sessions_started_at').on(table.startedAt),
|
|
]
|
|
);
|
|
|
|
export const studySessionsRelations = relations(studySessions, ({ one }) => ({
|
|
deck: one(decks, {
|
|
fields: [studySessions.deckId],
|
|
references: [decks.id],
|
|
}),
|
|
}));
|
|
|
|
export type StudySession = typeof studySessions.$inferSelect;
|
|
export type NewStudySession = typeof studySessions.$inferInsert;
|