@nitra/vite-boot 3.3.2 → 3.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/login.js +14 -13
- package/src/token.js +7 -11
package/package.json
CHANGED
package/src/login.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { checkToken } from './token.js'
|
|
1
|
+
import { getToken, checkToken } from './token.js'
|
|
2
2
|
import { setUser } from './user.js'
|
|
3
3
|
// import { router } from './router.js'
|
|
4
4
|
// Використовуємо глобальну версію
|
|
@@ -6,16 +6,19 @@ import { router } from '@nitra/vite-boot/router'
|
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Автоматичний вхід користувача
|
|
9
|
-
*
|
|
10
|
-
* @param {String} token
|
|
11
9
|
*/
|
|
12
|
-
export async function autoLogin(
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
10
|
+
export async function autoLogin() {
|
|
11
|
+
const token = getToken()
|
|
12
|
+
if (!token) {
|
|
13
|
+
return
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const check = checkToken(token)
|
|
17
|
+
if (check.result !== 'ok') {
|
|
18
|
+
return
|
|
18
19
|
}
|
|
20
|
+
|
|
21
|
+
return defaultLogin(check.decoded, token)
|
|
19
22
|
}
|
|
20
23
|
|
|
21
24
|
/**
|
|
@@ -24,11 +27,9 @@ export async function autoLogin(token) {
|
|
|
24
27
|
* @param {Object} decoded
|
|
25
28
|
* @param {String} raw? - необов'язково, але потрібно якщо використовується localStorage
|
|
26
29
|
*/
|
|
27
|
-
export async function defaultLogin(decoded, raw
|
|
30
|
+
export async function defaultLogin(decoded, raw) {
|
|
28
31
|
// Якщо задано що токен з localStorage
|
|
29
|
-
|
|
30
|
-
return localStorage.setItem(import.meta.env.VITE_TOKEN_STORAGE, raw)
|
|
31
|
-
}
|
|
32
|
+
localStorage.setItem('__session', raw)
|
|
32
33
|
|
|
33
34
|
setUser(decoded)
|
|
34
35
|
const route = sessionStorage.getItem('url-before-logout') || '/'
|
package/src/token.js
CHANGED
|
@@ -38,16 +38,15 @@ export function checkToken(token) {
|
|
|
38
38
|
* Токен з кукі
|
|
39
39
|
*/
|
|
40
40
|
export function getToken() {
|
|
41
|
-
// Якщо задано що токен беремо з localStorage
|
|
42
|
-
if (import.meta.env.VITE_TOKEN_STORAGE) {
|
|
43
|
-
return localStorage.getItem(import.meta.env.TOKEN_STORAGE)
|
|
44
|
-
}
|
|
45
|
-
|
|
46
41
|
// інакше з кукі
|
|
47
42
|
const cookieObj = new URLSearchParams(document.cookie.replaceAll('; ', '&')) // eslint-disable-line
|
|
48
43
|
const token = cookieObj.get('__session')
|
|
44
|
+
if (token) {
|
|
45
|
+
return token
|
|
46
|
+
}
|
|
49
47
|
|
|
50
|
-
|
|
48
|
+
// Якщо задано що токен беремо з localStorage
|
|
49
|
+
return localStorage.getItem('__session')
|
|
51
50
|
}
|
|
52
51
|
|
|
53
52
|
/**
|
|
@@ -56,11 +55,8 @@ export function getToken() {
|
|
|
56
55
|
export function cleanToken() {
|
|
57
56
|
unsetUser()
|
|
58
57
|
|
|
59
|
-
//
|
|
60
|
-
|
|
61
|
-
if (import.meta.env.VITE_TOKEN_STORAGE) {
|
|
62
|
-
return localStorage.removeItem(import.meta.env.TOKEN_STORAGE)
|
|
63
|
-
}
|
|
58
|
+
// видаляємо з localStorage
|
|
59
|
+
localStorage.removeItem('__session')
|
|
64
60
|
|
|
65
61
|
document.cookie = `__session=; Max-Age=0; path=/; domain=${import.meta.env.VITE_DOMAIN}` // eslint-disable-line
|
|
66
62
|
}
|