SpaceNinjaServer-RU/src/controllers/api/loginController.ts

73 lines
2.7 KiB
TypeScript
Raw Normal View History

/* eslint-disable @typescript-eslint/no-unused-vars */
import { RequestHandler } from "express";
2024-05-15 21:55:59 +02:00
import { config } from "@/src/services/configService";
import buildConfig from "@/static/data/buildConfig.json";
2023-05-19 15:22:48 -03:00
import { toLoginRequest } from "@/src/helpers/loginHelpers";
import { Account } from "@/src/models/loginModel";
import { createAccount, isCorrectPassword } from "@/src/services/loginService";
import { ILoginResponse } from "@/src/types/loginTypes";
2024-01-06 16:26:58 +01:00
import { logger } from "@/src/utils/logger";
2023-05-19 15:22:48 -03:00
2023-06-05 04:16:49 +08:00
// eslint-disable-next-line @typescript-eslint/no-misused-promises
2023-05-19 15:22:48 -03:00
const loginController: RequestHandler = async (request, response) => {
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-argument
const body = JSON.parse(request.body); // parse octet stream of json data to json object
const loginRequest = toLoginRequest(body);
2023-05-19 15:22:48 -03:00
2024-09-03 17:23:42 +03:00
const account = await Account.findOne({ email: loginRequest.email });
2024-05-28 13:45:06 +02:00
const nonce = Math.round(Math.random() * Number.MAX_SAFE_INTEGER);
2023-05-19 15:22:48 -03:00
if (!account && config.autoCreateAccount && loginRequest.ClientType != "webui") {
try {
const newAccount = await createAccount({
email: loginRequest.email,
password: loginRequest.password,
DisplayName: loginRequest.email.substring(0, loginRequest.email.indexOf("@")),
2024-09-03 20:21:09 +03:00
Nonce: nonce
});
2024-01-06 16:26:58 +01:00
logger.debug("created new account");
// eslint-disable-next-line @typescript-eslint/no-unused-vars
const { email, password, ...databaseAccount } = newAccount;
const newLoginResponse: ILoginResponse = {
...databaseAccount,
2024-05-15 21:55:59 +02:00
BuildLabel: buildConfig.buildLabel,
2024-09-03 17:23:42 +03:00
NatHash: "0",
SteamId: "0"
};
response.json(newLoginResponse);
return;
} catch (error: unknown) {
if (error instanceof Error) {
throw new Error(`error creating account ${error.message}`);
}
}
}
//email not found or incorrect password
if (!account || !isCorrectPassword(loginRequest.password, account.password)) {
response.status(400).json({ error: "incorrect login data" });
return;
}
2024-05-28 13:45:06 +02:00
if (account.Nonce == 0 || loginRequest.ClientType != "webui") {
account.Nonce = nonce;
}
2024-09-03 20:21:09 +03:00
await account.save();
2024-05-28 13:45:06 +02:00
const { email, password, ...databaseAccount } = account.toJSON();
const newLoginResponse: ILoginResponse = {
2023-05-19 15:22:48 -03:00
...databaseAccount,
2024-05-15 21:55:59 +02:00
BuildLabel: buildConfig.buildLabel,
2024-09-03 17:23:42 +03:00
NatHash: "0",
SteamId: "0"
};
2023-05-19 15:22:48 -03:00
response.json(newLoginResponse);
2023-05-19 15:22:48 -03:00
};
export { loginController };