统一授权登录
This commit is contained in:
parent
6e3aec7c50
commit
14cf3be392
@ -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
|
||||
});
|
||||
}
|
||||
|
||||
|
@ -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;
|
||||
|
@ -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) => {
|
||||
|
||||
const processResponse = async (res: any) => {
|
||||
if (res.code !== 200) {
|
||||
ElMessage.error(res.msg);
|
||||
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
|
||||
return;
|
||||
throw new Error(res.msg);
|
||||
}
|
||||
loading.value = false;
|
||||
setToken(res.data.access_token)
|
||||
setToken(res.data.access_token);
|
||||
ElMessage.success(res.msg);
|
||||
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
|
||||
})
|
||||
.catch(() => {
|
||||
};
|
||||
|
||||
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;
|
||||
} 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>
|
||||
|
Loading…
x
Reference in New Issue
Block a user