官网 初版
This commit is contained in:
89
prisma/schema.prisma
Normal file
89
prisma/schema.prisma
Normal file
@@ -0,0 +1,89 @@
|
||||
generator client {
|
||||
provider = "prisma-client"
|
||||
output = "../src/generated/prisma"
|
||||
}
|
||||
|
||||
datasource db {
|
||||
provider = "postgresql"
|
||||
}
|
||||
|
||||
model Admin {
|
||||
id String @id @default(cuid())
|
||||
username String @unique
|
||||
passwordHash String
|
||||
createdAt DateTime @default(now())
|
||||
}
|
||||
|
||||
model Addon {
|
||||
id String @id @default(cuid())
|
||||
name String
|
||||
slug String @unique
|
||||
summary String
|
||||
description String @db.Text
|
||||
iconUrl String?
|
||||
category String @default("general")
|
||||
published Boolean @default(false)
|
||||
totalDownloads Int @default(0)
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
releases Release[]
|
||||
screenshots Screenshot[]
|
||||
}
|
||||
|
||||
model Release {
|
||||
id String @id @default(cuid())
|
||||
addonId String
|
||||
version String
|
||||
changelog String @db.Text
|
||||
downloadType String @default("local")
|
||||
filePath String?
|
||||
externalUrl String?
|
||||
gameVersion String @default("")
|
||||
downloadCount Int @default(0)
|
||||
isLatest Boolean @default(false)
|
||||
createdAt DateTime @default(now())
|
||||
addon Addon @relation(fields: [addonId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@index([addonId])
|
||||
}
|
||||
|
||||
model Screenshot {
|
||||
id String @id @default(cuid())
|
||||
addonId String
|
||||
imageUrl String
|
||||
sortOrder Int @default(0)
|
||||
addon Addon @relation(fields: [addonId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@index([addonId])
|
||||
}
|
||||
|
||||
model Software {
|
||||
id String @id @default(cuid())
|
||||
name String
|
||||
slug String @unique
|
||||
description String @default("")
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
versions SoftwareVersion[]
|
||||
}
|
||||
|
||||
model SoftwareVersion {
|
||||
id String @id @default(cuid())
|
||||
softwareId String
|
||||
version String
|
||||
versionCode Int
|
||||
changelog String @db.Text
|
||||
downloadType String @default("local")
|
||||
filePath String?
|
||||
externalUrl String?
|
||||
fileSize Int @default(0)
|
||||
downloadCount Int @default(0)
|
||||
isLatest Boolean @default(false)
|
||||
forceUpdate Boolean @default(false)
|
||||
minVersion String?
|
||||
createdAt DateTime @default(now())
|
||||
software Software @relation(fields: [softwareId], references: [id], onDelete: Cascade)
|
||||
|
||||
@@unique([softwareId, version])
|
||||
@@index([softwareId])
|
||||
}
|
||||
48
prisma/seed.ts
Normal file
48
prisma/seed.ts
Normal file
@@ -0,0 +1,48 @@
|
||||
import "dotenv/config";
|
||||
import { PrismaClient } from "../src/generated/prisma/client";
|
||||
import { PrismaPg } from "@prisma/adapter-pg";
|
||||
import bcrypt from "bcryptjs";
|
||||
|
||||
const adapter = new PrismaPg({ connectionString: process.env.DATABASE_URL! });
|
||||
const prisma = new PrismaClient({ adapter });
|
||||
|
||||
async function main() {
|
||||
const username = process.env.ADMIN_USERNAME || "admin";
|
||||
const password = process.env.ADMIN_PASSWORD || "admin123";
|
||||
const passwordHash = await bcrypt.hash(password, 12);
|
||||
|
||||
await prisma.admin.upsert({
|
||||
where: { username },
|
||||
update: { passwordHash },
|
||||
create: { username, passwordHash },
|
||||
});
|
||||
|
||||
console.log(`Admin user "${username}" created/updated.`);
|
||||
|
||||
const existingAddon = await prisma.addon.findUnique({
|
||||
where: { slug: "nanami" },
|
||||
});
|
||||
|
||||
if (!existingAddon) {
|
||||
await prisma.addon.create({
|
||||
data: {
|
||||
name: "Nanami",
|
||||
slug: "nanami",
|
||||
summary: "A powerful WoW addon that enhances your gameplay experience.",
|
||||
description:
|
||||
"# Nanami\n\nNanami is a comprehensive World of Warcraft addon designed to improve your gaming experience.\n\n## Features\n\n- Feature 1\n- Feature 2\n- Feature 3",
|
||||
category: "gameplay",
|
||||
published: true,
|
||||
},
|
||||
});
|
||||
console.log("Sample addon 'Nanami' created.");
|
||||
}
|
||||
}
|
||||
|
||||
main()
|
||||
.then(() => prisma.$disconnect())
|
||||
.catch(async (e) => {
|
||||
console.error(e);
|
||||
await prisma.$disconnect();
|
||||
process.exit(1);
|
||||
});
|
||||
Reference in New Issue
Block a user