96 lines
2.2 KiB
Vue
Raw Normal View History

<template>
<div v-loading="loading" class="social-callback"></div>
</template>
<script setup lang="ts">
2023-07-01 16:24:48 +08:00
import { login, callback } from '@/api/login';
import { setToken, getToken } from '@/utils/auth';
2023-07-01 16:24:48 +08:00
import { LoginData } from '@/api/types';
const route = useRoute();
const loading = ref(true);
/**
* 接收Route传递的参数
* @param {Object} route.query.
*/
2023-07-01 16:24:48 +08:00
const code = route.query.code as string;
const state = route.query.state as string;
const source = route.query.source as string;
const stateJson = JSON.parse(atob(state));
2024-06-28 10:18:18 +08:00
const tenantId = (stateJson.tenantId as string) ? (stateJson.tenantId as string) : '000000';
const domain = stateJson.domain as string;
2023-07-01 16:24:48 +08:00
const processResponse = async (res: any) => {
if (res.code !== 200) {
throw new Error(res.msg);
}
2024-06-19 10:11:32 +08:00
if (res.data !== null) {
setToken(res.data.access_token);
}
2023-07-01 16:24:48 +08:00
ElMessage.success(res.msg);
setTimeout(() => {
2024-06-19 10:11:32 +08:00
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
}, 2000);
2023-07-01 16:24:48 +08:00
};
const handleError = (error: any) => {
ElMessage.error(error.message);
setTimeout(() => {
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
}, 2000);
2023-07-01 16:24:48 +08:00
};
const callbackByCode = async (data: LoginData) => {
try {
const res = await callback(data);
await processResponse(res);
loading.value = false;
2023-07-01 16:24:48 +08:00
} catch (error) {
handleError(error);
}
};
const loginByCode = async (data: LoginData) => {
try {
const res = await login(data);
await processResponse(res);
loading.value = false;
2023-07-01 16:24:48 +08:00
} catch (error) {
handleError(error);
}
};
const init = async () => {
2024-06-19 10:11:32 +08:00
// 如果域名不相等 则重定向处理
let host = window.location.host;
if (domain !== host) {
let urlFull = new URL(window.location.href);
2024-06-19 10:16:21 +08:00
urlFull.host = domain;
2024-06-19 10:11:32 +08:00
window.location.href = urlFull.toString();
return;
2024-06-19 10:11:32 +08:00
}
2023-07-01 16:24:48 +08:00
const data: LoginData = {
socialCode: code,
socialState: state,
tenantId: tenantId,
source: source,
2024-06-19 14:30:19 +08:00
clientId: import.meta.env.VITE_APP_CLIENT_ID,
2023-07-01 16:24:48 +08:00
grantType: 'social'
};
if (!getToken()) {
await loginByCode(data);
} else {
await callbackByCode(data);
}
};
onMounted(() => {
nextTick(() => {
init();
});
2023-07-01 16:24:48 +08:00
});
</script>