user.ts 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. import type { Request, Response } from 'express';
  2. const waitTime = (time: number = 100) => {
  3. return new Promise((resolve) => {
  4. setTimeout(() => {
  5. resolve(true);
  6. }, time);
  7. });
  8. };
  9. async function getFakeCaptcha(_req: Request, res: Response) {
  10. await waitTime(2000);
  11. return res.json('captcha-xxx');
  12. }
  13. const { ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION } = process.env;
  14. /**
  15. * 当前用户的权限,如果为空代表没登录
  16. * current user access, if is '', user need login
  17. * 如果是 pro 的预览,默认是有权限的
  18. */
  19. let access =
  20. ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION === 'site' ? 'admin' : '';
  21. const getAccess = () => {
  22. return access;
  23. };
  24. // 代码中会兼容本地 service mock 以及部署站点的静态数据
  25. export default {
  26. // 支持值为 Object 和 Array
  27. 'GET /api/currentUser': (_req: Request, res: Response) => {
  28. if (!getAccess()) {
  29. res.status(401).send({
  30. data: {
  31. isLogin: false,
  32. },
  33. errorCode: '401',
  34. errorMessage: '请先登录!',
  35. success: true,
  36. });
  37. return;
  38. }
  39. res.send({
  40. success: true,
  41. data: {
  42. name: 'Serati Ma',
  43. avatar:
  44. 'https://gw.alipayobjects.com/zos/antfincdn/XAosXuNZyF/BiazfanxmamNRoxxVxka.png',
  45. userid: '00000001',
  46. email: 'antdesign@alipay.com',
  47. signature: '海纳百川,有容乃大',
  48. title: '交互专家',
  49. group: '蚂蚁金服-某某某事业群-某某平台部-某某技术部-UED',
  50. tags: [
  51. {
  52. key: '0',
  53. label: '很有想法的',
  54. },
  55. {
  56. key: '1',
  57. label: '专注设计',
  58. },
  59. {
  60. key: '2',
  61. label: '辣~',
  62. },
  63. {
  64. key: '3',
  65. label: '大长腿',
  66. },
  67. {
  68. key: '4',
  69. label: '川妹子',
  70. },
  71. {
  72. key: '5',
  73. label: '海纳百川',
  74. },
  75. ],
  76. notifyCount: 12,
  77. unreadCount: 11,
  78. country: 'China',
  79. access: getAccess(),
  80. geographic: {
  81. province: {
  82. label: '浙江省',
  83. key: '330000',
  84. },
  85. city: {
  86. label: '杭州市',
  87. key: '330100',
  88. },
  89. },
  90. address: '西湖区工专路 77 号',
  91. phone: '0752-268888888',
  92. },
  93. });
  94. },
  95. // GET POST 可省略
  96. 'GET /api/users': [
  97. {
  98. key: '1',
  99. name: 'John Brown',
  100. age: 32,
  101. address: 'New York No. 1 Lake Park',
  102. },
  103. {
  104. key: '2',
  105. name: 'Jim Green',
  106. age: 42,
  107. address: 'London No. 1 Lake Park',
  108. },
  109. {
  110. key: '3',
  111. name: 'Joe Black',
  112. age: 32,
  113. address: 'Sidney No. 1 Lake Park',
  114. },
  115. ],
  116. 'POST /api/login/account': async (req: Request, res: Response) => {
  117. const { password, username, type } = req.body;
  118. await waitTime(2000);
  119. if (password === 'ant.design' && username === 'admin') {
  120. res.send({
  121. status: 'ok',
  122. type,
  123. currentAuthority: 'admin',
  124. });
  125. access = 'admin';
  126. return;
  127. }
  128. if (password === 'ant.design' && username === 'user') {
  129. res.send({
  130. status: 'ok',
  131. type,
  132. currentAuthority: 'user',
  133. });
  134. access = 'user';
  135. return;
  136. }
  137. if (type === 'mobile') {
  138. res.send({
  139. status: 'ok',
  140. type,
  141. currentAuthority: 'admin',
  142. });
  143. access = 'admin';
  144. return;
  145. }
  146. res.send({
  147. status: 'error',
  148. type,
  149. currentAuthority: 'guest',
  150. });
  151. access = 'guest';
  152. },
  153. 'POST /api/login/outLogin': (_req: Request, res: Response) => {
  154. access = '';
  155. res.send({ data: {}, success: true });
  156. },
  157. 'POST /api/register': (_req: Request, res: Response) => {
  158. res.send({ status: 'ok', currentAuthority: 'user', success: true });
  159. },
  160. 'GET /api/500': (_req: Request, res: Response) => {
  161. res.status(500).send({
  162. timestamp: 1513932555104,
  163. status: 500,
  164. error: 'error',
  165. message: 'error',
  166. path: '/base/category/list',
  167. });
  168. },
  169. 'GET /api/404': (_req: Request, res: Response) => {
  170. res.status(404).send({
  171. timestamp: 1513932643431,
  172. status: 404,
  173. error: 'Not Found',
  174. message: 'No message available',
  175. path: '/base/category/list/2121212',
  176. });
  177. },
  178. 'GET /api/403': (_req: Request, res: Response) => {
  179. res.status(403).send({
  180. timestamp: 1513932555104,
  181. status: 403,
  182. error: 'Forbidden',
  183. message: 'Forbidden',
  184. path: '/base/category/list',
  185. });
  186. },
  187. 'GET /api/401': (_req: Request, res: Response) => {
  188. res.status(401).send({
  189. timestamp: 1513932555104,
  190. status: 401,
  191. error: 'Unauthorized',
  192. message: 'Unauthorized',
  193. path: '/base/category/list',
  194. });
  195. },
  196. 'GET /api/login/captcha': getFakeCaptcha,
  197. };