feat: move login/register to auth layout, add detecting and setting instance URL

This commit is contained in:
SauceyRed 2025-05-07 19:46:10 +02:00
parent e1f2a5a591
commit 4364e9fa3b

View file

@ -1,40 +1,131 @@
<template> <template>
<div id="main-container"> <div id="root-container" style="margin-top: 5dvh;">
<div id="auth-form-container"> <Loading v-if="!mounted" />
<slot /> <div v-else id="main-container">
</div> <div v-if="!instanceUrl">
<div v-if="accessToken"> <div v-if="instanceError" style="color: red;">
You're logged in! {{ instanceError }}
<button @click="logout">Log out</button> </div>
</div> <form @submit="selectInstance">
<div v-if="res"> <div>
Response: <label for="instance-url">Instance URL</label>
<p> <br>
{{ res }} <input type="url" name="instance-url" id="instance-url" required v-model="instanceUrlInput">
</p> </div>
<div>
<button type="submit">Next</button>
</div>
</form>
</div>
<div v-else id="auth-form-container">
<slot />
</div>
<div v-if="auth.accessToken.value">
You're logged in!
<form @submit="logout">
<div>
<label for="logout-password">Password</label>
<br>
<input type="password" name="logout-password" id="logout-password" v-model="form.password" required>
</div>
<div>
<button type="submit">Log out</button>
</div>
</form>
<div>
<button @click="refresh">Refresh</button>
</div>
<div>
<button @click="showUser">Show user</button>
</div>
<div>
<button @click="getUser">Get me</button>
</div>
</div>
</div> </div>
</div> </div>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import { FetchError } from 'ofetch';
const mounted = ref(false);
const apiVersion = useRuntimeConfig().public.apiVersion; const apiVersion = useRuntimeConfig().public.apiVersion;
const instanceUrl = ref<string | null>(null);
const accessToken = useCookie("access_token"); const instanceUrlInput = ref<string>();
const instanceError = ref<string>();
const res = ref(); const redirectTo = useRoute().query.redirect_to;
const auth = useAuth();
if (auth.accessToken.value) {
navigateTo(redirectTo ? redirectTo as string : useAppConfig().baseURL as string);
}
onMounted(() => {
mounted.value = true;
instanceUrl.value = localStorage.getItem("instanceUrl");
console.log("set instance url to:", instanceUrl.value);
});
async function selectInstance(e: Event) {
e.preventDefault();
if (instanceUrlInput.value) {
const instanceUrlObj = new URL(`api/v${apiVersion}/stats`, instanceUrlInput.value.endsWith("/") ? instanceUrlInput.value : instanceUrlInput.value + "/");
try {
const res = await $fetch.raw(instanceUrlObj.href);
console.log("instance res:", res);
instanceError.value = "";
const origin = new URL(res.url).origin;
localStorage.setItem("instanceUrl", origin);
instanceUrl.value = origin;
localStorage.setItem("apiBase", origin + `/api/v${apiVersion}`);
} catch (error: any) {
if (error instanceof FetchError) {
console.log("Status code:", error.response?.status);
if (error.response?.status == 404) {
instanceError.value = "An instance with that URL does not exist or is currently down.";
}
}
console.error("Error:", error);
}
}
}
const form = reactive({
password: ""
});
async function logout(e: Event) { async function logout(e: Event) {
e.preventDefault(); e.preventDefault();
accessToken.value = null; await auth.logout(form.password);
useCookie("refresh_token").value = null; console.log("logout");
res.value = await $fetch(`/api/v${apiVersion}/auth/revoke`, { credentials: "include" }); }
async function refresh(e: Event) {
e.preventDefault();
await auth.refresh();
console.log("refreshed");
}
async function getUser(e: Event) {
e.preventDefault();
await auth.getUser();
console.log("user:", auth.user.value);
}
async function showUser(e: Event) {
e.preventDefault();
console.log("user:", auth.user.value);
} }
</script> </script>
<style> <style>
#main-container { #root-container, #main-container {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;