mirror of
https://github.com/p-stream/backend.git
synced 2026-03-11 17:55:35 +00:00
Big 'ol fix, deleting sessions, creating users, migrations, etc
This commit is contained in:
parent
6d0e59d2ae
commit
15d1bed09c
6 changed files with 110 additions and 3 deletions
2
package-lock.json
generated
2
package-lock.json
generated
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name": "open-backend",
|
"name": "open-backend-1",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
|
|
|
||||||
94
prisma/migrations/20250310013319_init/migration.sql
Normal file
94
prisma/migrations/20250310013319_init/migration.sql
Normal file
|
|
@ -0,0 +1,94 @@
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "bookmarks" (
|
||||||
|
"tmdb_id" VARCHAR(255) NOT NULL,
|
||||||
|
"user_id" VARCHAR(255) NOT NULL,
|
||||||
|
"meta" JSONB NOT NULL,
|
||||||
|
"updated_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
|
||||||
|
CONSTRAINT "bookmarks_pkey" PRIMARY KEY ("tmdb_id","user_id")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "challenge_codes" (
|
||||||
|
"code" UUID NOT NULL,
|
||||||
|
"flow" TEXT NOT NULL,
|
||||||
|
"auth_type" VARCHAR(255) NOT NULL,
|
||||||
|
"created_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
"expires_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
|
||||||
|
CONSTRAINT "challenge_codes_pkey" PRIMARY KEY ("code")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "mikro_orm_migrations" (
|
||||||
|
"id" SERIAL NOT NULL,
|
||||||
|
"name" VARCHAR(255),
|
||||||
|
"executed_at" TIMESTAMPTZ(6) DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
|
||||||
|
CONSTRAINT "mikro_orm_migrations_pkey" PRIMARY KEY ("id")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "progress_items" (
|
||||||
|
"id" UUID NOT NULL,
|
||||||
|
"tmdb_id" VARCHAR(255) NOT NULL,
|
||||||
|
"user_id" VARCHAR(255) NOT NULL,
|
||||||
|
"season_id" VARCHAR(255),
|
||||||
|
"episode_id" VARCHAR(255),
|
||||||
|
"meta" JSONB NOT NULL,
|
||||||
|
"updated_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
"duration" BIGINT NOT NULL,
|
||||||
|
"watched" BIGINT NOT NULL,
|
||||||
|
"season_number" INTEGER,
|
||||||
|
"episode_number" INTEGER,
|
||||||
|
|
||||||
|
CONSTRAINT "progress_items_pkey" PRIMARY KEY ("id")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "sessions" (
|
||||||
|
"id" UUID NOT NULL,
|
||||||
|
"user" TEXT NOT NULL,
|
||||||
|
"created_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
"accessed_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
"expires_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
"device" TEXT NOT NULL,
|
||||||
|
"user_agent" TEXT NOT NULL,
|
||||||
|
|
||||||
|
CONSTRAINT "sessions_pkey" PRIMARY KEY ("id")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "user_settings" (
|
||||||
|
"id" TEXT NOT NULL,
|
||||||
|
"application_theme" VARCHAR(255),
|
||||||
|
"application_language" VARCHAR(255),
|
||||||
|
"default_subtitle_language" VARCHAR(255),
|
||||||
|
"proxy_urls" TEXT[],
|
||||||
|
"trakt_key" VARCHAR(255),
|
||||||
|
"febbox_key" VARCHAR(255),
|
||||||
|
|
||||||
|
CONSTRAINT "user_settings_pkey" PRIMARY KEY ("id")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "users" (
|
||||||
|
"id" TEXT NOT NULL,
|
||||||
|
"public_key" TEXT NOT NULL,
|
||||||
|
"namespace" VARCHAR(255) NOT NULL,
|
||||||
|
"created_at" TIMESTAMPTZ(0) NOT NULL,
|
||||||
|
"last_logged_in" TIMESTAMPTZ(0),
|
||||||
|
"permissions" TEXT[],
|
||||||
|
"profile" JSONB NOT NULL,
|
||||||
|
|
||||||
|
CONSTRAINT "users_pkey" PRIMARY KEY ("id")
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateIndex
|
||||||
|
CREATE UNIQUE INDEX "bookmarks_tmdb_id_user_id_unique" ON "bookmarks"("tmdb_id", "user_id");
|
||||||
|
|
||||||
|
-- CreateIndex
|
||||||
|
CREATE UNIQUE INDEX "progress_items_tmdb_id_user_id_season_id_episode_id_unique" ON "progress_items"("tmdb_id", "user_id", "season_id", "episode_id");
|
||||||
|
|
||||||
|
-- CreateIndex
|
||||||
|
CREATE UNIQUE INDEX "users_public_key_unique" ON "users"("public_key");
|
||||||
3
prisma/migrations/migration_lock.toml
Normal file
3
prisma/migrations/migration_lock.toml
Normal file
|
|
@ -0,0 +1,3 @@
|
||||||
|
# Please do not edit this file manually
|
||||||
|
# It should be added in your version-control system (e.g., Git)
|
||||||
|
provider = "postgresql"
|
||||||
|
|
@ -89,6 +89,16 @@ export default defineEventHandler(async (event) => {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.method === 'DELETE') {
|
if (event.method === 'DELETE') {
|
||||||
|
const sid = event.context.params?.sid;
|
||||||
|
const sessionExists = await prisma.sessions.findUnique({
|
||||||
|
where: { id: sid }
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!sessionExists) {
|
||||||
|
return { success: true };
|
||||||
|
}
|
||||||
|
const session = await auth.getSessionAndBump(sid);
|
||||||
|
|
||||||
await prisma.sessions.delete({
|
await prisma.sessions.delete({
|
||||||
where: { id: sessionId }
|
where: { id: sessionId }
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ import { randomUUID } from 'crypto';
|
||||||
const progressMetaSchema = z.object({
|
const progressMetaSchema = z.object({
|
||||||
title: z.string(),
|
title: z.string(),
|
||||||
poster: z.string().optional(),
|
poster: z.string().optional(),
|
||||||
type: z.enum(['movie', 'tv']),
|
type: z.enum(['movie', 'tv', 'show']),
|
||||||
year: z.number().optional()
|
year: z.number().optional()
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ import { randomUUID } from 'crypto';
|
||||||
const progressMetaSchema = z.object({
|
const progressMetaSchema = z.object({
|
||||||
title: z.string(),
|
title: z.string(),
|
||||||
poster: z.string().optional(),
|
poster: z.string().optional(),
|
||||||
type: z.enum(['movie', 'tv']),
|
type: z.enum(['movie', 'tv', 'show']),
|
||||||
year: z.number().optional()
|
year: z.number().optional()
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue