Mercurial > gemma
view client/src/stores/user.js @ 454:516f0f84fe39
client: change login method from GET to POST
* Add `qs` as dependency for encoding form data because it is
recommended by the axios documentation.
author | Bernhard Reiter <bernhard@intevation.de> |
---|---|
date | Wed, 22 Aug 2018 11:53:40 +0200 |
parents | 8e22d1f16f81 |
children | 2ac37419f593 |
line wrap: on
line source
import { HTTP } from "../lib/http"; import qs from "qs"; const User = { namespaced: true, state: { authenticated: false, expires: null, roles: [], user: "" }, getters: { isAuthenticated: state => { return state.authenticated; }, userinfo: state => { return state.user; }, roles: state => { return state.roles; }, expires: state => { return state.expires; }, isWaterwayAdmin: state => { return state.roles.includes("waterway_admin"); }, isSysAdmin: state => { return state.roles.includes("sys_admin"); } }, mutations: { auth_success: (state, data) => { const { token, user, expires, roles } = data; localStorage.setItem("expires", expires); localStorage.setItem("roles", roles); localStorage.setItem("token", token); localStorage.setItem("user", user); state.expires = expires; state.roles = roles; state.user = user; state.authenticated = true; }, clear_auth: state => { state.authenticated = false; state.expires = null; state.roles = []; state.user = ""; localStorage.clear(); }, set_user: (state, name) => { state.user = name; }, set_roles: (state, roles) => { state.roles = roles; }, set_expires: (state, expires) => { state.expires = expires; }, set_authenticate: state => { state.authenticated = true; } }, actions: { login({ commit }, user) { // using POST is a bit more secure than GET return new Promise((resolve, reject) => { // axios will add the application/x-www-form-urlencoded header this way HTTP.post("/login", qs.stringify(user)) .then(response => { commit("auth_success", response.data); resolve(response); }) .catch(error => { commit("clear_auth"); reject(error); }); }); } } }; export default User;