官网 初版

This commit is contained in:
rucky
2026-03-18 17:13:27 +08:00
parent 879c4bdfc8
commit 241a76caeb
95 changed files with 8889 additions and 113 deletions

89
prisma/schema.prisma Normal file
View 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
View 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);
});