/
auth.js
91 lines (83 loc) · 1.75 KB
/
auth.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
'use strict';
import { browserHistory } from 'react-router';
import moment from 'moment';
import cookie from 'react-cookie';
import toastr from 'toastr';
/**
* check user authentication from react router
* @param nextState
* @param replaceState
* @returns void
*/
export function isAuthRouter(nextState, replaceState) {
if (!cookie.load('x-access-token')) {
toastr.warning('Need to login.');
replaceState('/auth');
}
}
/**
* check guest from react router
* @param nextState
* @param replaceState
* @returns void
*/
export function isGuestRouter(nextState, replaceState) {
if (cookie.load('x-access-token')) {
toastr.info('Already login');
replaceState('/users');
}
}
/**
* trigger to logout for react-router
* @param nextState
* @param replaceState
* @returns void
*/
export function logOutRouter(nextState, replaceState) {
cookie.remove('x-access-token');
toastr.success('Logout successfully');
replaceState('/auth');
}
/**
* check user authentication
* @param nextState
* @param replaceState
* @returns boolean
*/
export function isAuth() {
if (cookie.load('x-access-token')) {
return true;
} else {
return false;
}
}
/**
* check user authentication
* @param nextState
* @param replaceState
* @returns boolean
*/
export function isAuthWithFailTrigger() {
if (cookie.load('x-access-token')) {
return true;
} else {
toastr.warning('Need to login.');
browserHistory.push('/auth');
}
}
/**
* get token from react cookie
* @returns token
*/
export function getToken() {
return cookie.load('x-access-token');
}
/**
* set token to react cookie
* @returns void
*/
export function setToken(token) {
cookie.save('x-access-token', token, {
expires: moment().add(1, 'h').toDate(),
});
}