mirror of
https://github.com/m-xlsea/ruoyi-plus-soybean.git
synced 2025-09-24 07:49:47 +08:00
feat: 新增单点登录回调页面
This commit is contained in:
@ -4,6 +4,7 @@ import type { SelectOption } from 'naive-ui';
|
||||
import { useLoading } from '@sa/hooks';
|
||||
import { fetchCaptchaCode, fetchTenantList } from '@/service/api';
|
||||
// import { fetchGetConfigDetail } from '@/service/api/system/config';
|
||||
import { fetchSocialAuthBinding } from '@/service/api/system';
|
||||
import { useAuthStore } from '@/store/modules/auth';
|
||||
import { useRouterPush } from '@/hooks/common/router';
|
||||
import { useFormRules, useNaiveForm } from '@/hooks/common/form';
|
||||
@ -111,8 +112,10 @@ handleLoginRember();
|
||||
|
||||
// handleRegister();
|
||||
|
||||
function handleSocialLogin(type: string) {
|
||||
console.log(type);
|
||||
async function handleSocialLogin(type: Api.System.SocialSource) {
|
||||
const { data, error } = await fetchSocialAuthBinding(type, model.tenantId);
|
||||
if (error) return;
|
||||
window.location.href = data;
|
||||
}
|
||||
</script>
|
||||
|
||||
@ -151,7 +154,8 @@ function handleSocialLogin(type: string) {
|
||||
<ButtonIcon local-icon="topiam" @click="handleSocialLogin('topiam')" />
|
||||
<ButtonIcon local-icon="maxkey" @click="handleSocialLogin('maxkey')" />
|
||||
<ButtonIcon class="color-#c71d23" icon="simple-icons:gitee" @click="handleSocialLogin('gitee')" />
|
||||
<ButtonIcon class="color-#010409" icon="mdi:github" @click="handleSocialLogin('github')" />
|
||||
<!-- <ButtonIcon class="color-#010409" icon="mdi:github" @click="handleSocialLogin('github')" /> -->
|
||||
<ButtonIcon icon="material-icon-theme:gitlab" @click="handleSocialLogin('gitlab')" />
|
||||
</NSpace>
|
||||
</div>
|
||||
<NButton type="primary" size="large" block :loading="authStore.loginLoading" @click="handleSubmit">
|
||||
|
108
src/views/_builtin/social-callback/index.vue
Normal file
108
src/views/_builtin/social-callback/index.vue
Normal file
@ -0,0 +1,108 @@
|
||||
<script setup lang="ts">
|
||||
import { onMounted, watch } from 'vue';
|
||||
import { useRoute } from 'vue-router';
|
||||
import { useLoading } from '@sa/hooks';
|
||||
import { loading as loadingHtml } from '@/plugins/loading';
|
||||
import { fetchSocialLoginCallback } from '@/service/api';
|
||||
import { useAuthStore } from '@/store/modules/auth';
|
||||
import { useRouterPush } from '@/hooks/common/router';
|
||||
|
||||
const route = useRoute();
|
||||
const authStore = useAuthStore();
|
||||
const { routerPushByKey } = useRouterPush();
|
||||
const { loading, startLoading, endLoading } = useLoading();
|
||||
|
||||
/**
|
||||
* 接收Route传递的参数
|
||||
*
|
||||
* @param {Object} route.query.
|
||||
*/
|
||||
const code = route.query.code as string;
|
||||
const state = route.query.state as string;
|
||||
const source = route.query.source as string;
|
||||
const stateJson = state ? JSON.parse(atob(state)) : {};
|
||||
const tenantId = (stateJson.tenantId as string) ?? '000000';
|
||||
const domain = (stateJson.domain as string) ?? window.location.host;
|
||||
|
||||
const processResponse = async () => {
|
||||
window.$message?.success('登录成功');
|
||||
setTimeout(() => {
|
||||
routerPushByKey('home');
|
||||
}, 2000);
|
||||
};
|
||||
|
||||
const handleError = () => {
|
||||
setTimeout(() => {
|
||||
routerPushByKey('login');
|
||||
}, 2000);
|
||||
};
|
||||
|
||||
const callbackByCode = async (data: Api.Auth.SocialLoginForm) => {
|
||||
const { error } = await fetchSocialLoginCallback({
|
||||
...data,
|
||||
clientId: import.meta.env.VITE_APP_CLIENT_ID,
|
||||
grantType: 'social'
|
||||
});
|
||||
if (error) {
|
||||
handleError();
|
||||
return;
|
||||
}
|
||||
await processResponse();
|
||||
endLoading();
|
||||
};
|
||||
|
||||
const loginByCode = async (data: Api.Auth.SocialLoginForm) => {
|
||||
try {
|
||||
await authStore.login(data);
|
||||
await processResponse();
|
||||
} catch {
|
||||
handleError();
|
||||
}
|
||||
endLoading();
|
||||
};
|
||||
|
||||
const init = async () => {
|
||||
startLoading();
|
||||
// 如果域名不相等 则重定向处理
|
||||
const host = window.location.host;
|
||||
if (domain !== host) {
|
||||
const urlFull = new URL(window.location.href);
|
||||
urlFull.host = domain;
|
||||
window.location.href = urlFull.toString();
|
||||
return;
|
||||
}
|
||||
|
||||
const data: Api.Auth.SocialLoginForm = {
|
||||
socialCode: code,
|
||||
socialState: state,
|
||||
tenantId,
|
||||
source,
|
||||
grantType: 'social'
|
||||
};
|
||||
|
||||
if (!authStore.isLogin) {
|
||||
await loginByCode(data);
|
||||
} else {
|
||||
await callbackByCode(data);
|
||||
}
|
||||
};
|
||||
|
||||
onMounted(async () => {
|
||||
await init();
|
||||
});
|
||||
|
||||
watch(loading, val => {
|
||||
if (val) {
|
||||
const app = document.getElementById('social-callback');
|
||||
if (app) {
|
||||
app.innerHTML = loadingHtml();
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div v-if="loading" id="social-callback"></div>
|
||||
</template>
|
||||
|
||||
<style scoped></style>
|
Reference in New Issue
Block a user