mirror of
https://github.com/Infisical/infisical.git
synced 2025-03-29 22:02:57 +00:00
150 lines
4.5 KiB
JavaScript
150 lines
4.5 KiB
JavaScript
import Aes256Gcm from "~/components/utilities/cryptography/aes-256-gcm";
|
|
import login1 from "~/pages/api/auth/Login1";
|
|
import login2 from "~/pages/api/auth/Login2";
|
|
import getOrganizations from "~/pages/api/organization/getOrgs";
|
|
import getOrganizationUserProjects from "~/pages/api/organization/GetOrgUserProjects";
|
|
|
|
import pushKeys from "./secrets/pushKeys";
|
|
import { saveTokenToLocalStorage } from "./saveTokenToLocalStorage";
|
|
import SecurityClient from "./SecurityClient";
|
|
import Telemetry from "./telemetry/Telemetry";
|
|
|
|
const nacl = require("tweetnacl");
|
|
nacl.util = require("tweetnacl-util");
|
|
const jsrp = require("jsrp");
|
|
const client = new jsrp.client();
|
|
|
|
/**
|
|
* This function loggs in the user (whether it's right after signup, or a normal login)
|
|
* @param {*} email
|
|
* @param {*} password
|
|
* @param {*} setErrorLogin
|
|
* @param {*} router
|
|
* @param {*} isSignUp
|
|
* @returns
|
|
*/
|
|
const attemptLogin = async (
|
|
email,
|
|
password,
|
|
setErrorLogin,
|
|
router,
|
|
isSignUp,
|
|
isLogin
|
|
) => {
|
|
try {
|
|
const telemetry = new Telemetry().getInstance();
|
|
|
|
client.init(
|
|
{
|
|
username: email,
|
|
password: password,
|
|
},
|
|
async () => {
|
|
const clientPublicKey = client.getPublicKey();
|
|
|
|
const { serverPublicKey, salt } = await login1(email, clientPublicKey);
|
|
|
|
try {
|
|
client.setSalt(salt);
|
|
client.setServerPublicKey(serverPublicKey);
|
|
const clientProof = client.getProof(); // called M1
|
|
|
|
// if everything works, go the main dashboard page.
|
|
const { token, publicKey, encryptedPrivateKey, iv, tag } =
|
|
await login2(email, clientProof);
|
|
SecurityClient.setToken(token);
|
|
|
|
const privateKey = Aes256Gcm.decrypt(
|
|
encryptedPrivateKey,
|
|
iv,
|
|
tag,
|
|
password
|
|
.slice(0, 32)
|
|
.padStart(
|
|
32 + (password.slice(0, 32).length - new Blob([password]).size),
|
|
"0"
|
|
)
|
|
);
|
|
|
|
saveTokenToLocalStorage({
|
|
token,
|
|
publicKey,
|
|
encryptedPrivateKey,
|
|
iv,
|
|
tag,
|
|
privateKey,
|
|
});
|
|
|
|
const userOrgs = await getOrganizations();
|
|
const userOrgsData = userOrgs.map((org) => org._id);
|
|
|
|
let orgToLogin;
|
|
if (userOrgsData.includes(localStorage.getItem("orgData.id"))) {
|
|
orgToLogin = localStorage.getItem("orgData.id");
|
|
} else {
|
|
orgToLogin = userOrgsData[0];
|
|
localStorage.setItem("orgData.id", orgToLogin);
|
|
}
|
|
|
|
let orgUserProjects = await getOrganizationUserProjects({
|
|
orgId: orgToLogin,
|
|
});
|
|
|
|
orgUserProjects = orgUserProjects?.map((project) => project._id);
|
|
let projectToLogin;
|
|
if (
|
|
orgUserProjects.includes(localStorage.getItem("projectData.id"))
|
|
) {
|
|
projectToLogin = localStorage.getItem("projectData.id");
|
|
} else {
|
|
try {
|
|
projectToLogin = orgUserProjects[0];
|
|
localStorage.setItem("projectData.id", projectToLogin);
|
|
} catch (error) {
|
|
console.log("ERROR: User likely has no projects. ", error);
|
|
}
|
|
}
|
|
|
|
// If user is logging in for the first time, add the example keys
|
|
if (isSignUp) {
|
|
await pushKeys({
|
|
obj: {
|
|
DATABASE_URL: [
|
|
"mongodb+srv://${DB_USERNAME}:${DB_PASSWORD}@mongodb.net",
|
|
"personal",
|
|
],
|
|
DB_USERNAME: ["user1234", "personal"],
|
|
DB_PASSWORD: ["ah8jak3hk8dhiu4dw7whxwe1l", "personal"],
|
|
TWILIO_AUTH_TOKEN: [
|
|
"hgSIwDAKvz8PJfkj6xkzYqzGmAP3HLuG",
|
|
"shared",
|
|
],
|
|
WEBSITE_URL: ["http://localhost:3000", "shared"],
|
|
STRIPE_SECRET_KEY: ["sk_test_7348oyho4hfq398HIUOH78", "shared"],
|
|
},
|
|
workspaceId: projectToLogin,
|
|
env: "Development",
|
|
});
|
|
}
|
|
if (email) {
|
|
telemetry.identify(email);
|
|
telemetry.capture("User Logged In");
|
|
}
|
|
|
|
if (isLogin) {
|
|
router.push("/dashboard/");
|
|
}
|
|
} catch (error) {
|
|
setErrorLogin(true);
|
|
console.log("Login response not available");
|
|
}
|
|
}
|
|
);
|
|
} catch (error) {
|
|
console.log("Something went wrong during authentication");
|
|
}
|
|
return true;
|
|
};
|
|
|
|
export default attemptLogin;
|