统一授权登录

This commit is contained in:
thiszhc 2023-07-01 16:24:48 +08:00
parent 6e3aec7c50
commit 14cf3be392
3 changed files with 73 additions and 40 deletions

View File

@ -2,6 +2,7 @@ import request from '@/utils/request';
import { AxiosPromise } from 'axios';
import { LoginData, LoginResult, VerifyCodeResult, TenantInfo } from './types';
import { UserInfo } from '@/api/system/user/types';
import { da } from 'element-plus/es/locale';
/**
* @param data {LoginData}
@ -9,13 +10,9 @@ import { UserInfo } from '@/api/system/user/types';
*/
export function login(data: LoginData): AxiosPromise<LoginResult> {
const params = {
tenantId: data.tenantId,
username: data.username.trim(),
password: data.password,
code: data.code,
uuid: data.uuid,
clientId: 'e5cd7e4891bf95d1d19206ce24a7b32e',
grantType: 'password'
...data,
clientId: data.clientId || 'e5cd7e4891bf95d1d19206ce24a7b32e',
grantType: data.grantType || 'password'
};
return request({
url: '/auth/login',
@ -66,19 +63,16 @@ export function getCodeImg(): AxiosPromise<VerifyCodeResult> {
*
* @param source
* */
export function socialLogin(source: string, tenantId: string, code: any, state: any): AxiosPromise<any> {
const data = {
socialCode: code,
socialState: state,
source,
tenantId,
export function callback(data: LoginData): AxiosPromise<any> {
const LoginData = {
...data,
clientId: 'e5cd7e4891bf95d1d19206ce24a7b32e',
grantType: 'social'
};
return request({
url: '/auth/social-login',
url: '/auth/social/callback',
method: 'post',
data: data
data: LoginData
});
}

View File

@ -15,10 +15,13 @@ export type RegisterForm = {
*
*/
export interface LoginData {
tenantId: string;
username: string;
password: string;
tenantId?: string;
username?: string;
password?: string;
rememberMe?: boolean;
socialCode?: string,
socialState?: string,
source?: string,
code?: string;
uuid?: string;
clientId: string;

View File

@ -3,11 +3,11 @@
</template>
<script setup lang="ts">
import { socialLogin } from '@/api/login';
import { login, callback } from '@/api/login';
import { setToken } from '@/utils/auth';
import Cookies from 'js-cookie';
import { getToken } from '@/utils/auth';
import router from '@/router';
import { LoginData } from '@/api/types';
const route = useRoute();
const loading = ref(true);
@ -17,30 +17,66 @@ const loading = ref(true);
* 接收Route传递的参数
* @param {Object} route.query.
*/
const code = route.query.code;
const state = route.query.state;
const code = route.query.code as string;
const state = route.query.state as string;
const source = route.query.source as string;
const tenantId = Cookies.get("tenantId") ? Cookies.get("tenantId") as string : '000000';
/**
* 通过code获取token
* @param {string} source
* @param {string} code
* @param {string} state
*/
await socialLogin(source, tenantId, code, state)
.then(async (res) => {
if (res.code !== 200) {
ElMessage.error(res.msg);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
return;
}
const processResponse = async (res: any) => {
if (res.code !== 200) {
throw new Error(res.msg);
}
setToken(res.data.access_token);
ElMessage.success(res.msg);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
};
const handleError = (error: any) => {
ElMessage.error(error.message);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
};
const callbackByCode = async (data: LoginData) => {
try {
const res = await callback(data);
await processResponse(res);
loading.value = false;
setToken(res.data.access_token)
ElMessage.success(res.msg);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
})
.catch(() => {
} catch (error) {
handleError(error);
}
};
const loginByCode = async (data: LoginData) => {
try {
const res = await login(data);
await processResponse(res);
loading.value = false;
} catch (error) {
handleError(error);
}
};
const init = async () => {
const data: LoginData = {
socialCode: code,
socialState: state,
tenantId: tenantId,
source: source,
clientId: 'e5cd7e4891bf95d1d19206ce24a7b32e',
grantType: 'social'
};
if (!getToken()) {
await loginByCode(data);
} else {
await callbackByCode(data);
}
};
onMounted(() => {
nextTick(() => {
init();
});
});
</script>