You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
144 lines
3.4 KiB
144 lines
3.4 KiB
import type { Request, Response } from 'express';
|
|
import { waitTime, defaultUser } from './utils';
|
|
|
|
const { ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION } = process.env;
|
|
|
|
/**
|
|
* 当前用户的权限,如果为空代表没登录
|
|
* current user access, if is '', user need login
|
|
* 如果是 pro 的预览,默认是有权限的
|
|
*/
|
|
let access = ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION === 'site' ? 'admin' : '';
|
|
|
|
const getAccess = () => {
|
|
return access;
|
|
};
|
|
|
|
// 代码中会兼容本地 service mock 以及部署站点的静态数据
|
|
export default {
|
|
// 支持值为 Object 和 Array
|
|
'GET /api/currentUser': (_req: Request, res: Response) => {
|
|
if (!getAccess()) {
|
|
res.status(401).send({
|
|
data: {
|
|
isLogin: false,
|
|
},
|
|
errorCode: '401',
|
|
errorMessage: '请先登录!',
|
|
success: true,
|
|
});
|
|
return;
|
|
}
|
|
res.send({
|
|
success: true,
|
|
data: {
|
|
...defaultUser,
|
|
access: getAccess(),
|
|
},
|
|
});
|
|
},
|
|
// GET POST 可省略
|
|
'GET /api/users': [
|
|
{
|
|
key: '1',
|
|
name: 'John Brown',
|
|
age: 32,
|
|
address: 'New York No. 1 Lake Park',
|
|
},
|
|
{
|
|
key: '2',
|
|
name: 'Jim Green',
|
|
age: 42,
|
|
address: 'London No. 1 Lake Park',
|
|
},
|
|
{
|
|
key: '3',
|
|
name: 'Joe Black',
|
|
age: 32,
|
|
address: 'Sidney No. 1 Lake Park',
|
|
},
|
|
],
|
|
'POST /api/login/account': async (req: Request, res: Response) => {
|
|
const { password, username, type } = req.body;
|
|
await waitTime(2000);
|
|
if (password === 'ant.design' && username === 'admin') {
|
|
res.send({
|
|
status: 'ok',
|
|
type,
|
|
currentAuthority: 'admin',
|
|
});
|
|
access = 'admin';
|
|
return;
|
|
}
|
|
if (password === 'ant.design' && username === 'user') {
|
|
res.send({
|
|
status: 'ok',
|
|
type,
|
|
currentAuthority: 'user',
|
|
});
|
|
access = 'user';
|
|
return;
|
|
}
|
|
if (type === 'mobile') {
|
|
res.send({
|
|
status: 'ok',
|
|
type,
|
|
currentAuthority: 'admin',
|
|
});
|
|
access = 'admin';
|
|
return;
|
|
}
|
|
|
|
res.send({
|
|
status: 'error',
|
|
type,
|
|
currentAuthority: 'guest',
|
|
});
|
|
access = 'guest';
|
|
},
|
|
'POST /api/login/outLogin': (_req: Request, res: Response) => {
|
|
access = '';
|
|
res.send({ data: {}, success: true });
|
|
},
|
|
'GET /api/500': (_req: Request, res: Response) => {
|
|
res.status(500).send({
|
|
timestamp: 1513932555104,
|
|
status: 500,
|
|
error: 'error',
|
|
message: 'error',
|
|
path: '/base/category/list',
|
|
});
|
|
},
|
|
'GET /api/404': (_req: Request, res: Response) => {
|
|
res.status(404).send({
|
|
timestamp: 1513932643431,
|
|
status: 404,
|
|
error: 'Not Found',
|
|
message: 'No message available',
|
|
path: '/base/category/list/2121212',
|
|
});
|
|
},
|
|
'GET /api/403': (_req: Request, res: Response) => {
|
|
res.status(403).send({
|
|
timestamp: 1513932555104,
|
|
status: 403,
|
|
error: 'Forbidden',
|
|
message: 'Forbidden',
|
|
path: '/base/category/list',
|
|
});
|
|
},
|
|
'GET /api/401': (_req: Request, res: Response) => {
|
|
res.status(401).send({
|
|
timestamp: 1513932555104,
|
|
status: 401,
|
|
error: 'Unauthorized',
|
|
message: 'Unauthorized',
|
|
path: '/base/category/list',
|
|
});
|
|
},
|
|
|
|
'GET /api/login/captcha': async (_req: Request, res: Response) => {
|
|
await waitTime(2000);
|
|
return res.json('captcha-xxx');
|
|
},
|
|
};
|