Compare commits
No commits in common. "b2e69e3b6192208fa752131d5ed9dc4a00ff1085" and "656d7a9e3c0c85b7f7cf90188bf944425d39d7b1" have entirely different histories.
b2e69e3b61
...
656d7a9e3c
|
@ -38,10 +38,6 @@ export const useMainStore = defineStore({
|
||||||
if (this.user === undefined) throw 'Not logged in, this should not be called';
|
if (this.user === undefined) throw 'Not logged in, this should not be called';
|
||||||
return this.user;
|
return this.user;
|
||||||
},
|
},
|
||||||
currentSession(): FG.Session {
|
|
||||||
if (this.session === undefined) throw 'Not logged in, this should not be called';
|
|
||||||
return this.session;
|
|
||||||
},
|
|
||||||
permissions(): string[] {
|
permissions(): string[] {
|
||||||
return this.user?.permissions || [];
|
return this.user?.permissions || [];
|
||||||
},
|
},
|
||||||
|
@ -67,10 +63,8 @@ export const useMainStore = defineStore({
|
||||||
},
|
},
|
||||||
|
|
||||||
async login(userid: string, password: string) {
|
async login(userid: string, password: string) {
|
||||||
const userStore = useUserStore();
|
|
||||||
try {
|
try {
|
||||||
const { data } = await api.post<FG.Session>('/auth', { userid, password });
|
const { data } = await api.post<FG.Session>('/auth', { userid, password });
|
||||||
this.user = await userStore.getUser(data.userid, true);
|
|
||||||
this.session = fixSession(data);
|
this.session = fixSession(data);
|
||||||
return true;
|
return true;
|
||||||
} catch ({ response }) {
|
} catch ({ response }) {
|
||||||
|
|
|
@ -20,10 +20,6 @@ export const useUserStore = defineStore({
|
||||||
getters: {},
|
getters: {},
|
||||||
|
|
||||||
actions: {
|
actions: {
|
||||||
/**
|
|
||||||
* @deprecated Use getUser instead, will be removed with first beta release
|
|
||||||
* @todo Remove with first beta release
|
|
||||||
*/
|
|
||||||
findUser(userid: string) {
|
findUser(userid: string) {
|
||||||
return this.users.find((user) => user.userid === userid);
|
return this.users.find((user) => user.userid === userid);
|
||||||
},
|
},
|
||||||
|
|
|
@ -70,11 +70,10 @@
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { useRouter } from 'vue-router';
|
import { useRouter } from 'vue-router';
|
||||||
import { Loading, Notify, useQuasar } from 'quasar';
|
import { Loading, Notify } from 'quasar';
|
||||||
import { api, notEmpty, PersistentStorage, useMainStore } from '@flaschengeist/api';
|
import { api, notEmpty, PersistentStorage, useMainStore, useUserStore } from '@flaschengeist/api';
|
||||||
import { PasswordInput } from '@flaschengeist/api/components';
|
import { PasswordInput } from '@flaschengeist/api/components';
|
||||||
import { defineComponent, onMounted, ref } from 'vue';
|
import { defineComponent, onMounted, ref } from 'vue';
|
||||||
import { useSessionStore } from 'app/api';
|
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'PageLogin',
|
name: 'PageLogin',
|
||||||
|
@ -89,9 +88,8 @@ export default defineComponent({
|
||||||
const mainRoute = { name: 'dashboard' };
|
const mainRoute = { name: 'dashboard' };
|
||||||
|
|
||||||
const mainStore = useMainStore();
|
const mainStore = useMainStore();
|
||||||
const sessionStore = useSessionStore();
|
const userStore = useUserStore();
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const quasar = useQuasar();
|
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
if (mainStore.session) void router.replace(mainRoute);
|
if (mainStore.session) void router.replace(mainRoute);
|
||||||
|
@ -117,14 +115,10 @@ export default defineComponent({
|
||||||
const status = await mainStore.login(userid.value, password.value);
|
const status = await mainStore.login(userid.value, password.value);
|
||||||
|
|
||||||
if (status === true) {
|
if (status === true) {
|
||||||
// On capacitor we set the lifetime to at least two weeks to not annoy users.
|
mainStore.user = await userStore.getUser(userid.value, true);
|
||||||
if (quasar.platform.is.capacitor)
|
|
||||||
void sessionStore.updateSession(14 * 24 * 60 * 60, mainStore.currentSession.token);
|
|
||||||
// Redirect user to previous page, if any.
|
|
||||||
const x = router.currentRoute.value.query['redirect'];
|
const x = router.currentRoute.value.query['redirect'];
|
||||||
void router.push(!!x && typeof x === 'string' ? { path: x } : mainRoute);
|
void router.push(typeof x === 'string' ? { path: x } : mainRoute);
|
||||||
} else {
|
} else {
|
||||||
// Login failed, notify and reset form
|
|
||||||
password.value = '';
|
password.value = '';
|
||||||
if (status === 401) {
|
if (status === 401) {
|
||||||
Notify.create({
|
Notify.create({
|
||||||
|
|
Loading…
Reference in New Issue