@nitra/vite-boot 3.2.1 → 3.3.1
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 +8 -3
- package/src/token.js +14 -1
package/package.json
CHANGED
package/src/login.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { checkToken } from './token.js'
|
|
1
|
+
import { checkToken, getToken } from './token.js'
|
|
2
2
|
import { setUser } from './user.js'
|
|
3
3
|
// import { router } from './router.js'
|
|
4
4
|
// Використовуємо глобальну версію
|
|
@@ -7,7 +7,7 @@ import { router } from '@nitra/vite-boot/router'
|
|
|
7
7
|
/**
|
|
8
8
|
* Автоматичний вхід користувача
|
|
9
9
|
*
|
|
10
|
-
* @param {
|
|
10
|
+
* @param {String} token
|
|
11
11
|
*/
|
|
12
12
|
export async function autoLogin(token) {
|
|
13
13
|
if (token) {
|
|
@@ -21,9 +21,14 @@ export async function autoLogin(token) {
|
|
|
21
21
|
/**
|
|
22
22
|
* Вхід аоб на попередню або на кореневу сторінку
|
|
23
23
|
*
|
|
24
|
-
* @param {
|
|
24
|
+
* @param {Object} decoded
|
|
25
25
|
*/
|
|
26
26
|
export async function defaultLogin(decoded) {
|
|
27
|
+
// Якщо задано що токен з localStorage
|
|
28
|
+
if (import.meta.env.VITE_TOKEN_STORAGE) {
|
|
29
|
+
return localStorage.setItem(import.meta.env.TOKEN_STORAGE, getToken())
|
|
30
|
+
}
|
|
31
|
+
|
|
27
32
|
setUser(decoded)
|
|
28
33
|
const route = sessionStorage.getItem('url-before-logout') || '/'
|
|
29
34
|
return router.push(route)
|
package/src/token.js
CHANGED
|
@@ -10,7 +10,7 @@ const allowedRoles = import.meta.env.VITE_HASURA_ROLE.split(',')
|
|
|
10
10
|
* та перенаправляємо на сторінку входу
|
|
11
11
|
*
|
|
12
12
|
* @param {string} token - JWT токен
|
|
13
|
-
* @returns {{result: string,
|
|
13
|
+
* @returns {{result: string, decoded?: {}}} - Повертає результат перевірки токена
|
|
14
14
|
*/
|
|
15
15
|
export function checkToken(token) {
|
|
16
16
|
const decoded = jwtDecode(token)
|
|
@@ -38,6 +38,12 @@ 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
|
const cookieObj = new URLSearchParams(document.cookie.replaceAll('; ', '&')) // eslint-disable-line
|
|
42
48
|
const token = cookieObj.get('__session')
|
|
43
49
|
|
|
@@ -49,6 +55,13 @@ export function getToken() {
|
|
|
49
55
|
*/
|
|
50
56
|
export function cleanToken() {
|
|
51
57
|
unsetUser()
|
|
58
|
+
|
|
59
|
+
// Якщо задано що токен беремо з localStorage
|
|
60
|
+
// то й видаляємо з localStorage
|
|
61
|
+
if (import.meta.env.VITE_TOKEN_STORAGE) {
|
|
62
|
+
return localStorage.removeItem(import.meta.env.TOKEN_STORAGE)
|
|
63
|
+
}
|
|
64
|
+
|
|
52
65
|
document.cookie = `__session=; Max-Age=0; path=/; domain=${import.meta.env.VITE_DOMAIN}` // eslint-disable-line
|
|
53
66
|
}
|
|
54
67
|
|