ProxmoxAAS-Dashboard/scripts/login.js
Arthur Lu eecf272e99 use css vars for coloring
Signed-off-by: Arthur Lu <learthurgo@gmail.com>
2023-04-03 22:59:36 +00:00

47 lines
1.8 KiB
JavaScript

import {requestTicket, setTicket, ResponseError, NetworkError, goToPage, deleteAllCookies, requestPVE} from "./utils.js";
window.addEventListener("DOMContentLoaded", init);
async function init (){
deleteAllCookies();
let formSubmitButton = document.querySelector("#submit");
let status = document.querySelector("#status");
let realms = await requestPVE("/access/domains", "GET");
let realmSelect = document.querySelector("#realm");
realms.data.forEach((element) => {
realmSelect.add(new Option(element.comment, element.realm));
if("default" in element && element.default === 1){
realmSelect.value = element.realm;
}
});
formSubmitButton.addEventListener("click", async (e) => {
status.innerText = "";
status.style.color = "var(--content-txt-color)";
e.preventDefault();
let form = document.querySelector("form");
let formData = new FormData(form);
try {
status.innerText = "Authenticating...";
let ticket = await requestTicket(formData.get("username"), formData.get("password"), formData.get("realm"));
setTicket(ticket.data.ticket, ticket.data.CSRFPreventionToken, formData.get("username"));
status.innerText = "Authentication successful!"
status.style.color = "var(--success-color)";
goToPage("index.html");
}
catch (error) {
if(error instanceof ResponseError) { // response error is usually 401 auth failed
status.innerText = "Authentication failed.";
status.style.color = "var(--fail-color)";
}
else if (error instanceof NetworkError) {
status.innerText = "Encountered a network error.";
status.style.color = "var(--fail-color)";
}
else {
status.innerText = "An error occured.";
status.style.color = "var(--fail-color)";
console.error(error);
}
}
});
}