2020-10-02 07:13:14 +00:00
|
|
|
import { store } from 'quasar/wrappers';
|
2021-01-30 03:19:30 +00:00
|
|
|
import { createStore } from 'vuex';
|
2021-01-31 19:40:18 +00:00
|
|
|
|
|
|
|
export interface StateInterface {
|
2021-01-31 21:21:49 +00:00
|
|
|
[key: string]: unknown;
|
2021-01-31 19:40:18 +00:00
|
|
|
}
|
2020-10-02 07:13:14 +00:00
|
|
|
|
2021-01-30 03:19:30 +00:00
|
|
|
export default store(function (/* { ssrContext } */) {
|
|
|
|
const Store = createStore({
|
2020-10-16 07:38:14 +00:00
|
|
|
modules: {},
|
2020-10-02 07:13:14 +00:00
|
|
|
|
|
|
|
// enable strict mode (adds overhead!)
|
2021-01-30 03:19:30 +00:00
|
|
|
// for dev mode and --debug builds only
|
|
|
|
strict: !!process.env.DEBUGGING,
|
2020-10-02 07:13:14 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
return Store;
|
|
|
|
});
|
2021-02-02 21:32:23 +00:00
|
|
|
|
|
|
|
import { defineStore } from 'pinia';
|
|
|
|
import { api } from 'src/boot/axios';
|
|
|
|
import { AxiosResponse } from 'axios';
|
|
|
|
import { LocalStorage } from 'quasar';
|
|
|
|
import { useUserStore, useSessionStore } from 'src/plugins/user/store';
|
|
|
|
|
|
|
|
function loadCurrentSession() {
|
|
|
|
const session = LocalStorage.getItem<FG.Session>('session');
|
|
|
|
if (session) session.expires = new Date(session.expires);
|
|
|
|
return session || undefined;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const useMainStore = defineStore({
|
|
|
|
id: 'main',
|
|
|
|
|
|
|
|
state: () => ({
|
|
|
|
session: loadCurrentSession(),
|
|
|
|
user: undefined as FG.User | undefined,
|
|
|
|
}),
|
|
|
|
|
|
|
|
getters: {
|
|
|
|
loggedIn() {
|
|
|
|
return this.session !== undefined;
|
|
|
|
},
|
|
|
|
currentUser() {
|
|
|
|
if (this.user === undefined) throw 'Not logged in, this should not be called';
|
|
|
|
return this.user;
|
|
|
|
},
|
|
|
|
permissions() {
|
|
|
|
return this.user?.permissions || [];
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
actions: {
|
|
|
|
/** Ininitalize store from saved session
|
|
|
|
* Updates session and loads current user
|
|
|
|
*/
|
|
|
|
async init() {
|
|
|
|
if (this.session) {
|
|
|
|
const sessionStore = useSessionStore();
|
|
|
|
const session = await sessionStore.getSession(this.session.token);
|
|
|
|
if (session) {
|
|
|
|
this.session = this.session;
|
|
|
|
const userStore = useUserStore();
|
|
|
|
const user = await userStore.getUser(this.session.userid);
|
|
|
|
if (user) this.user = user;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
async login(userid: string, password: string) {
|
|
|
|
try {
|
|
|
|
const { data } = await api.post<FG.Session>('/auth', { userid, password });
|
|
|
|
this.session = data;
|
|
|
|
this.session.expires = new Date(this.session.expires);
|
|
|
|
LocalStorage.set('session', this.session);
|
|
|
|
return true;
|
|
|
|
} catch ({ response }) {
|
|
|
|
return (<AxiosResponse | undefined>response)?.status || false;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
logout() {
|
|
|
|
if (!this.session) return false;
|
|
|
|
|
|
|
|
void api.delete(`/auth/${this.session.token}`);
|
|
|
|
this.$patch({
|
|
|
|
session: undefined,
|
|
|
|
user: undefined,
|
|
|
|
});
|
|
|
|
LocalStorage.remove('session');
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
|
|
|
async requestReset(userid: string) {
|
|
|
|
return await api
|
|
|
|
.post('/auth/reset', { userid })
|
|
|
|
.then(() => true)
|
|
|
|
.catch(() => false);
|
|
|
|
},
|
|
|
|
|
|
|
|
async resetPassword(token: string, password: string) {
|
|
|
|
return await api
|
|
|
|
.post('/auth/reset', { token, password })
|
|
|
|
.then(() => true)
|
|
|
|
.catch(({ response }) =>
|
|
|
|
response && 'status' in response ? (<AxiosResponse>response).status : false
|
|
|
|
);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|