opnform-host-nginx/client/stores/auth.js

85 lines
1.9 KiB
JavaScript

import { defineStore } from "pinia"
export const useAuthStore = defineStore("auth", {
state: () => {
return {
token: null,
admin_token: null,
user: null,
}
},
getters: {
check: (state) => state.user !== null && state.user !== undefined,
has_active_license: (state) => state.user !== null && state.user !== undefined && state.user.active_license !== null,
isImpersonating: (state) =>
state.admin_token !== null && state.admin_token !== undefined,
},
actions: {
// Stores admin token temporarily for impersonation
startImpersonating() {
this.setAdminToken(this.token)
},
// Stop admin impersonation
stopImpersonating() {
this.setToken(this.admin_token)
this.setAdminToken(null)
},
setToken(token) {
this.setCookie("token", token)
this.token = token
},
setAdminToken(token) {
this.setCookie("admin_token", token)
this.admin_token = token
},
setCookie(name, value) {
if (import.meta.client) {
useCookie(name).value = value
}
},
initStore(token, adminToken) {
this.token = token
this.admin_token = adminToken
},
setUser(user) {
if (!user) {
console.error("No user, logging out.")
this.setToken(null)
}
this.user = user
this.initServiceClients()
},
updateUser(payload) {
this.user = payload
this.initServiceClients()
},
initServiceClients() {
if (!this.user) return
useAmplitude().setUser(this.user)
useCrisp().setUser(this.user)
// todo: set sentry user
},
logout() {
opnFetch("logout", { method: "POST" }).catch(() => {})
this.user = null
this.setToken(null)
},
// async fetchOauthUrl() {
// const {data} = await axios.post(`/api/oauth/${provider}`)
// return data.url
// },
},
})