Nuxt/examples/auth-routes/store/index.js
2020-11-30 23:44:04 +01:00

38 lines
847 B
JavaScript

import axios from 'axios'
export const state = () => ({
authUser: null
})
export const mutations = {
SET_USER (state, user) {
state.authUser = user
}
}
export const actions = {
// nuxtServerInit is called by Nuxt before server-rendering every page
nuxtServerInit ({ commit }, { req }) {
if (req.session && req.session.authUser) {
commit('SET_USER', req.session.authUser)
}
},
async login ({ commit }, { username, password }) {
try {
const { data } = await axios.post('/api/login', { username, password })
commit('SET_USER', data)
} catch (error) {
if (error.response && error.response.status === 401) {
throw new Error('Bad credentials')
}
throw error
}
},
async logout ({ commit }) {
await axios.post('/api/logout')
commit('SET_USER', null)
}
}