import { goToPage, requestPVE, setTitleAndHeader, setAppearance, requestAPI } from "./utils.js"; import { alert } from "./dialog.js"; window.addEventListener("DOMContentLoaded", init); async function init () { await deleteAllCookies(); setAppearance(); setTitleAndHeader(); const formSubmitButton = document.querySelector("#submit"); const realms = await requestPVE("/access/domains", "GET"); const 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) => { e.preventDefault(); const form = document.querySelector("form"); const formData = new FormData(form); formSubmitButton.innerText = "Authenticating..."; const ticket = await requestTicket(formData.get("username"), formData.get("password"), formData.get("realm")); if (ticket.status === 200) { formSubmitButton.innerText = "LOGIN"; goToPage("index.html"); } else if (ticket.status === 401) { alert("Authenticaton failed."); formSubmitButton.innerText = "LOGIN"; } else if (ticket.status === 408) { alert("Network error."); formSubmitButton.innerText = "LOGIN"; } else { alert("An error occured."); formSubmitButton.innerText = "LOGIN"; console.error(ticket.error); } }); } async function requestTicket (username, password, realm) { const response = await requestAPI("/access/ticket", "POST", { username: `${username}@${realm}`, password }, false); return response; } async function deleteAllCookies () { await requestAPI("/access/ticket", "DELETE"); }