fix: login 兼容不同的 request 版本 (#242)

* fix: login 兼容不同的 request 版本

* chore: upgrade request
This commit is contained in:
qlin 2024-05-06 15:14:26 +08:00 committed by GitHub
parent 7e9cb618f0
commit 36cc169ffe
3 changed files with 61 additions and 32 deletions

View File

@ -1,8 +1,12 @@
import { request } from '@@/core/pluginExports';
import { ApplyPluginsType, getRouter, plugin } from '@fesjs/fes'; import { ApplyPluginsType, getRouter, plugin } from '@fesjs/fes';
let config; let config;
function getLoginConfig() { function getLoginConfig() {
if (config) return config; if (config) {
return config;
}
config = plugin.applyPlugins({ config = plugin.applyPlugins({
key: 'login', key: 'login',
type: ApplyPluginsType.modify, type: ApplyPluginsType.modify,
@ -14,38 +18,63 @@ function getLoginConfig() {
return config; return config;
} }
const defaultExport = {
onRouterCreated({ router }) {
const { hasLogin, loginPath } = getLoginConfig();
if (hasLogin && loginPath) {
let isAuthenticated;
router.beforeEach(async (to, from, next) => {
if (to.path !== loginPath && !isAuthenticated) {
isAuthenticated = await hasLogin();
if (!isAuthenticated) {
return next({ path: loginPath });
}
}
next();
});
}
},
};
// ACCESS // ACCESS
export function request(memo) { if (request.version) {
if (!memo.responseInterceptors) { defaultExport.request = (memo) => {
memo.responseInterceptors = []; const config = getRunTimeConfig();
} if (config.ignore401Redirect) {
memo.responseInterceptors.push([ return memo;
(response) => response, }
(error) => {
const errorHandler = memo.errorHandler;
memo.errorHandler = (error) => {
if (error?.response?.status === 401) { if (error?.response?.status === 401) {
const router = getRouter(); const router = getRouter();
const { loginPath } = getLoginConfig(); const { loginPath } = getLoginConfig();
router.push({ path: loginPath }); router.push({ path: loginPath });
} }
throw error; errorHandler && errorHandler(error);
}, };
]); return memo;
return memo; };
}
else {
defaultExport.request = (memo) => {
if (!memo.responseInterceptors) {
memo.responseInterceptors = [];
}
memo.responseInterceptors.push([
response => response,
(error) => {
if (error?.response?.status === 401) {
const router = getRouter();
const { loginPath } = getLoginConfig();
router.push({ path: loginPath });
}
throw error;
},
]);
return memo;
};
} }
export function onRouterCreated({ router }) { export default defaultExport;
const { hasLogin, loginPath } = getLoginConfig();
if (hasLogin && loginPath) {
let isAuthenticated;
router.beforeEach(async (to, from, next) => {
if (to.path !== loginPath && !isAuthenticated) {
isAuthenticated = await hasLogin();
if (!isAuthenticated) {
return next({ path: loginPath });
}
}
next();
});
}
}

View File

@ -33,7 +33,7 @@
}, },
"dependencies": { "dependencies": {
"@fesjs/utils": "^3.0.1", "@fesjs/utils": "^3.0.1",
"@qlin/request": "^0.2.0" "@qlin/request": "^0.2.3"
}, },
"typings": "./types.d.ts" "typings": "./types.d.ts"
} }

8
pnpm-lock.yaml generated
View File

@ -650,8 +650,8 @@ importers:
specifier: ^3.0.1 specifier: ^3.0.1
version: link:../fes-utils version: link:../fes-utils
'@qlin/request': '@qlin/request':
specifier: ^0.2.0 specifier: ^0.2.3
version: 0.2.0 version: 0.2.3
vue: vue:
specifier: ^3.2.37 specifier: ^3.2.37
version: 3.3.4 version: 3.3.4
@ -3921,8 +3921,8 @@ packages:
resolution: {integrity: sha512-2LuNTFBIO0m7kKIQvvPHN6UE63VjpmL9rnEEaOOaiSPbZK+zUOYIzBAWcED+3XYzhYsd/0mD57VdxAEqqV52CQ==} resolution: {integrity: sha512-2LuNTFBIO0m7kKIQvvPHN6UE63VjpmL9rnEEaOOaiSPbZK+zUOYIzBAWcED+3XYzhYsd/0mD57VdxAEqqV52CQ==}
dev: false dev: false
/@qlin/request@0.2.0: /@qlin/request@0.2.3:
resolution: {integrity: sha512-zbCIHy7wBYy4pz/GarBeDTGmtkT2QfsCqudKQMs6wkhZ/ZMMQzAhO7d+REH89d3cdUPvw7qMnpYXYpHEg2eCeg==} resolution: {integrity: sha512-haKCRgZZWF9cZF7btRNfZQlDtJQ0uVqjwp51mqT+073V7JbL2DpUmVsRODtb3nnw9uVAHOqS9rmq+ZigwftgGg==}
dependencies: dependencies:
'@types/lodash-es': 4.17.12 '@types/lodash-es': 4.17.12
lodash-es: 4.17.21 lodash-es: 4.17.21