export const state = () => ({ username: null, id: null, isAuthenticated: false, isStaff: false }) export const mutations = { setUsername(state, username) { state.username = username }, setUserId(state, userId) { state.id = userId }, clearUsername(state) { state.username = null }, setAuthenticated(state, isAuthenticated) { state.isAuthenticated = isAuthenticated }, setIsStaff(state, isStaff) { state.isStaff = isStaff } } export const getters = { isAuthenticated(state) { return state.isAuthenticated }, getUsername(state) { return state.username }, getUserId(state) { return state.id }, isStaff(state) { return state.isStaff } } export const actions = { async authenticateUser({ commit }, authData) { try { await this.$services.auth.login(authData.username, authData.password) commit('setAuthenticated', true) } catch(error) { throw new Error('The credential is invalid') } }, async initAuth({ commit }) { try { const user = await this.$services.user.getMyProfile() commit('setAuthenticated', true) commit('setUsername', user.username) commit('setUserId', user.id) commit('setIsStaff', user.isStaff) } catch { commit('setAuthenticated', false) commit('setIsStaff', false) } }, async logout({ commit }) { await this.$services.auth.logout() commit('setAuthenticated', false) commit('setIsStaff', false) commit('clearUsername') } }