user.ts 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import { MockMethod } from 'vite-plugin-mock';
  2. import { resultError, resultSuccess, getRequestToken, requestParams, baseUrl } from '../_util';
  3. import { PageEnum } from '/@/enums/pageEnum';
  4. export function createFakeUserList() {
  5. return [
  6. {
  7. userId: '1',
  8. username: 'admin',
  9. realname: '管理员',
  10. avatar: 'https://q1.qlogo.cn/g?b=qq&nk=190848757&s=640',
  11. desc: 'manager',
  12. password: '123456',
  13. token: 'fakeToken1',
  14. homePath: PageEnum.BASE_HOME,
  15. roles: [
  16. {
  17. roleName: 'Super Admin',
  18. value: 'super',
  19. },
  20. ],
  21. },
  22. {
  23. userId: '2',
  24. username: 'jeecg',
  25. password: '123456',
  26. realname: '测试用户',
  27. avatar: 'https://q1.qlogo.cn/g?b=qq&nk=339449197&s=640',
  28. desc: 'tester',
  29. token: 'fakeToken2',
  30. homePath: PageEnum.BASE_HOME,
  31. roles: [
  32. {
  33. roleName: 'Tester',
  34. value: 'test',
  35. },
  36. ],
  37. },
  38. ];
  39. }
  40. const fakeCodeList: any = {
  41. '1': ['1000', '3000', '5000'],
  42. '2': ['2000', '4000', '6000'],
  43. };
  44. export default [
  45. // mock user login
  46. {
  47. url: `${baseUrl}/sys/login`,
  48. timeout: 200,
  49. method: 'post',
  50. response: ({ body }) => {
  51. const { username, password } = body;
  52. const checkUser = createFakeUserList().find(
  53. (item) => item.username === username && password === item.password
  54. );
  55. if (!checkUser) {
  56. return resultError('Incorrect account or password!');
  57. }
  58. const { userId, username: _username, token, realname, desc, roles } = checkUser;
  59. return resultSuccess({
  60. roles,
  61. userId,
  62. username: _username,
  63. token,
  64. realname,
  65. desc,
  66. });
  67. },
  68. },
  69. {
  70. url: `${baseUrl}/sys/user/getUserInfo`,
  71. method: 'get',
  72. response: (request: requestParams) => {
  73. const token = getRequestToken(request);
  74. if (!token) return resultError('Invalid token');
  75. const checkUser = createFakeUserList().find((item) => item.token === token);
  76. if (!checkUser) {
  77. return resultError('The corresponding user information was not obtained!');
  78. }
  79. return resultSuccess(checkUser);
  80. },
  81. },
  82. {
  83. url: `${baseUrl}/sys/permission/getPermCode`,
  84. timeout: 200,
  85. method: 'get',
  86. response: (request: requestParams) => {
  87. const token = getRequestToken(request);
  88. if (!token) return resultError('Invalid token');
  89. const checkUser = createFakeUserList().find((item) => item.token === token);
  90. if (!checkUser) {
  91. return resultError('Invalid token!');
  92. }
  93. const codeList = fakeCodeList[checkUser.userId];
  94. return resultSuccess(codeList);
  95. },
  96. },
  97. {
  98. url: `${baseUrl}/sys/logout`,
  99. timeout: 200,
  100. method: 'get',
  101. response: (request: requestParams) => {
  102. const token = getRequestToken(request);
  103. if (!token) return resultError('Invalid token');
  104. const checkUser = createFakeUserList().find((item) => item.token === token);
  105. if (!checkUser) {
  106. return resultError('Invalid token!');
  107. }
  108. return resultSuccess(undefined, { message: 'Token has been destroyed' });
  109. },
  110. },
  111. {
  112. url: `${baseUrl}/sys/randomImage/1629428467008`,
  113. timeout: 200,
  114. method: 'get',
  115. response: (request: requestParams) => {
  116. const result =
  117. 'data:image/jpg;base64,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';
  118. return resultSuccess(result);
  119. },
  120. },
  121. ] as MockMethod[];