CET-vue-3.0/src/api/sys/user.ts

187 lines
4.6 KiB
TypeScript
Raw Normal View History

2021-10-20 14:32:09 +08:00
import { defHttp } from '/@/utils/http/axios';
import { LoginParams, LoginResultModel, GetUserInfoModel } from './model/userModel';
import { ErrorMessageMode } from '/#/axios';
import {useMessage} from "/@/hooks/web/useMessage";
const { createMessage, createErrorModal } = useMessage();
enum Api {
Login = '/sys/login',
phoneLogin = '/sys/phoneLogin',
Logout = '/sys/logout',
GetUserInfo = '/sys/user/getUserInfo',
2022-03-10 09:47:29 +08:00
// 获取系统权限
// 1、查询用户拥有的按钮/表单访问权限
// 2、所有权限
// 3、系统安全模式
2021-10-20 14:32:09 +08:00
GetPermCode = '/sys/permission/getPermCode',
//新加的获取图形验证码的接口
getInputCode = '/sys/randomImage',
//获取短信验证码的接口
getCaptcha = '/sys/sms',
//注册接口
registerApi = '/sys/user/register',
//校验用户接口
checkOnlyUser = '/sys/user/checkOnlyUser',
2022-03-10 09:47:29 +08:00
//SSO登录校验
validateCasLogin = '/sys/cas/client/validateLogin',
2021-10-20 14:32:09 +08:00
//校验手机号
phoneVerify = '/sys/user/phoneVerification',
//修改密码
passwordChange = '/sys/user/passwordChange',
2022-03-10 09:47:29 +08:00
//第三方登录
thirdLogin = '/sys/thirdLogin/getLoginUser',
//第三方登录
getThirdCaptcha = '/sys/thirdSms',
//获取二维码信息
getLoginQrcode = '/sys/getLoginQrcode',
//监控二维码扫描状态
getQrcodeToken = '/sys/getQrcodeToken',
2021-10-20 14:32:09 +08:00
}
/**
* @description: user login api
*/
export function loginApi(params: LoginParams, mode: ErrorMessageMode = 'modal') {
return defHttp.post<LoginResultModel>(
{
url: Api.Login,
params,
},
{
errorMessageMode: mode,
}
);
}
/**
* @description: user phoneLogin api
*/
export function phoneLoginApi(params: LoginParams, mode: ErrorMessageMode = 'modal') {
return defHttp.post<LoginResultModel>(
{
url: Api.phoneLogin,
params,
},
{
errorMessageMode: mode,
}
);
}
/**
* @description: getUserInfo
*/
export function getUserInfo() {
2022-03-10 09:47:29 +08:00
return defHttp.get<GetUserInfoModel>({ url: Api.GetUserInfo }, { errorMessageMode: 'none' });
2021-10-20 14:32:09 +08:00
}
export function getPermCode() {
2022-03-10 09:47:29 +08:00
return defHttp.get({ url: Api.GetPermCode });
2021-10-20 14:32:09 +08:00
}
export function doLogout() {
return defHttp.get({ url: Api.Logout });
}
export function getCodeInfo(currdatetime) {
let url = Api.getInputCode+`/${currdatetime}`
return defHttp.get({ url: url });
}
/**
* @description:
*/
export function getCaptcha(params) {
return new Promise((resolve, reject) => {
2022-03-10 09:47:29 +08:00
defHttp.post({url:Api.getCaptcha,params},{isTransformResponse: false}).then(res=>{
2021-10-20 14:32:09 +08:00
console.log(res)
if(res.success){
resolve(true)
}else{
createErrorModal({ title: '错误提示', content: res.message||'未知问题' });
reject()
}
});
})
}
/**
* @description:
*/
export function register(params) {
return defHttp.post({url: Api.registerApi,params},{isReturnNativeResponse: true})
}
/**
*
* @param params
*/
export const checkOnlyUser = (params) =>
defHttp.get({url: Api.checkOnlyUser, params},{isTransformResponse:false});
/**
*
* @param params
*/
export const phoneVerify = (params) =>
defHttp.post({url: Api.phoneVerify, params},{isTransformResponse:false});
/**
*
* @param params
*/
export const passwordChange = (params) =>
defHttp.get({url: Api.passwordChange, params},{isTransformResponse:false});
2022-03-10 09:47:29 +08:00
/**
* @description:
*/
export function thirdLogin(params, mode: ErrorMessageMode = 'modal') {
return defHttp.get<LoginResultModel>(
{
url: `${Api.thirdLogin}/${params.token}/${params.thirdType}`,
},
{
errorMessageMode: mode,
}
);
}
/**
* @description:
*/
export function setThirdCaptcha(params) {
return new Promise((resolve, reject) => {
defHttp.post({url:Api.getThirdCaptcha,params},{isTransformResponse: false}).then(res=>{
console.log(res)
if(res.success){
resolve(true)
}else{
createErrorModal({ title: '错误提示', content: res.message||'未知问题' });
reject()
}
});
})
}
/**
*
*/
export function getLoginQrcode() {
let url = Api.getLoginQrcode
return defHttp.get({ url: url });
}
/**
*
*/
export function getQrcodeToken(params) {
let url = Api.getQrcodeToken
return defHttp.get({ url: url,params});
}
/**
* SSO登录校验
*/
export async function validateCasLogin(params) {
let url = Api.validateCasLogin
return defHttp.get({ url: url,params});
}