2024-06-29 05:22:22 +00:00
|
|
|
"use server";
|
|
|
|
|
|
|
|
import { generateId } from "lucia";
|
|
|
|
import { cookies } from "next/headers";
|
|
|
|
import { redirect } from "next/navigation";
|
|
|
|
import { Argon2id } from "oslo/password";
|
|
|
|
import { lucia } from "@/lib/lucia";
|
2024-06-29 06:37:50 +00:00
|
|
|
import { daphnis, artemis } from "@/lib/prisma";
|
2024-08-25 20:33:45 +00:00
|
|
|
import { GameVersion } from "@/prisma/schemas/daphnis/generated/daphnis";
|
2024-06-29 05:22:22 +00:00
|
|
|
|
|
|
|
const signUp = async (formData: FormData) => {
|
|
|
|
const formDataRaw = {
|
|
|
|
username: formData.get("username") as string,
|
|
|
|
email: formData.get("email") as string,
|
|
|
|
accessCode: formData.get("accessCode") as string,
|
|
|
|
password: formData.get("password") as string,
|
|
|
|
confirmPassword: formData.get("confirmPassword") as string,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (formDataRaw.password !== formDataRaw.confirmPassword) {
|
|
|
|
return { error: "Passwords do not match" };
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2024-06-29 06:37:50 +00:00
|
|
|
// Check if access code is already used in daphnis database
|
|
|
|
const existingUser = await daphnis.user.findFirst({
|
2024-06-29 05:22:22 +00:00
|
|
|
where: {
|
|
|
|
accessCode: formDataRaw.accessCode,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
if (existingUser) {
|
|
|
|
return { error: "Access Code already in use" };
|
|
|
|
}
|
|
|
|
|
2024-06-29 06:37:50 +00:00
|
|
|
// Check if username is already used in daphnis database
|
|
|
|
const existingUsername = await daphnis.user.findFirst({
|
2024-06-29 05:22:22 +00:00
|
|
|
where: {
|
|
|
|
username: formDataRaw.username,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
if (existingUsername) {
|
|
|
|
return { error: "Username is currently taken" };
|
|
|
|
}
|
|
|
|
|
2024-06-29 06:37:50 +00:00
|
|
|
const existingEmail = await daphnis.user.findFirst({
|
2024-06-29 05:22:22 +00:00
|
|
|
where: {
|
|
|
|
email: formDataRaw.email,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
if (existingEmail) {
|
|
|
|
return { error: "Email is already in use" };
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if access code exists in artemis database
|
|
|
|
const existingAccessCode = await artemis.aime_card.findFirst({
|
|
|
|
where: {
|
|
|
|
access_code: formDataRaw.accessCode,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2024-08-25 20:33:45 +00:00
|
|
|
const existingAccessCodeAndPlayedGame =
|
|
|
|
await artemis.chuni_profile_data.findFirst({
|
|
|
|
where: {
|
|
|
|
user: existingAccessCode?.user,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2024-06-29 05:22:22 +00:00
|
|
|
if (!existingAccessCode) {
|
|
|
|
return { error: "Not in artemis's database, Nice try ^_^" };
|
|
|
|
}
|
|
|
|
|
|
|
|
const hashedPassword = await new Argon2id().hash(formDataRaw.password);
|
|
|
|
const userId = generateId(15);
|
|
|
|
|
2024-08-25 20:33:45 +00:00
|
|
|
const artemisUserId = existingAccessCode.user;
|
|
|
|
|
|
|
|
type GameVersionKey = keyof typeof GameVersion;
|
|
|
|
|
|
|
|
// need to make a record so we can get the game version from the db into daphnis where its stored as a string
|
|
|
|
const NumberToGameVersionKey: Record<number, GameVersionKey> = {
|
|
|
|
16: "LuminousPlus",
|
|
|
|
15: "Luminous",
|
|
|
|
14: "SunPlus",
|
|
|
|
13: "Sun",
|
|
|
|
12: "NewPlus",
|
|
|
|
11: "New",
|
|
|
|
};
|
|
|
|
|
|
|
|
const currentGameVersion = existingAccessCodeAndPlayedGame?.version;
|
|
|
|
const gameVersionKey = NumberToGameVersionKey[currentGameVersion ?? 0];
|
|
|
|
const gameIdToName = gameVersionKey
|
|
|
|
? GameVersion[gameVersionKey]
|
|
|
|
: undefined;
|
|
|
|
|
2024-06-29 06:37:50 +00:00
|
|
|
await daphnis.user.create({
|
2024-06-29 05:22:22 +00:00
|
|
|
data: {
|
2024-06-29 18:43:11 +00:00
|
|
|
UserId: artemisUserId,
|
2024-06-29 05:22:22 +00:00
|
|
|
id: userId,
|
|
|
|
username: formDataRaw.username,
|
|
|
|
email: formDataRaw.email,
|
|
|
|
accessCode: formDataRaw.accessCode,
|
2024-08-25 20:33:45 +00:00
|
|
|
gameVersion: gameIdToName,
|
2024-06-29 05:22:22 +00:00
|
|
|
hashedPassword,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
// Create session and set cookie
|
|
|
|
const session = await lucia.createSession(userId, {});
|
|
|
|
const sessionCookie = lucia.createSessionCookie(session.id);
|
|
|
|
|
|
|
|
cookies().set(
|
|
|
|
sessionCookie.name,
|
|
|
|
sessionCookie.value,
|
2024-08-25 20:33:45 +00:00
|
|
|
sessionCookie.attributes,
|
2024-06-29 05:22:22 +00:00
|
|
|
);
|
|
|
|
console.log("Account created");
|
|
|
|
|
|
|
|
// Redirect to home page
|
|
|
|
} catch (error: any) {
|
|
|
|
return { error: "Account creation failed: " + error.message };
|
|
|
|
}
|
2024-06-29 05:46:07 +00:00
|
|
|
redirect("/home");
|
2024-06-29 05:22:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export { signUp };
|