business.js 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. const { Op } = require('sequelize');
  2. const express = require('express');
  3. const _ = require('lodash');
  4. const { query, body } = require('express-validator');
  5. const { onSuccess, fill, md5, onError } = require('../../../utils');
  6. const { limit } = require('../../config');
  7. const check = require('../../../middleware/check');
  8. const Business = require('../../../db/models/business');
  9. const Area = require('../../../db/models/area');
  10. const router = express.Router();
  11. async function fillSingle(data) {
  12. if (data) {
  13. const { cityId, provinceId } = data;
  14. const [cItem, pItem] = await Promise.all([
  15. Area.findOne({ where: { id: cityId } }),
  16. Area.findOne({ where: { id: provinceId } }),
  17. ]);
  18. data.cityName = cItem.name;
  19. data.provinceName = pItem.name;
  20. }
  21. return data;
  22. }
  23. /**
  24. * showdoc
  25. * @catalog v1/后台/商家
  26. * @title 商家列表
  27. * @description 商家列表接口
  28. * @method GET
  29. * @url /master/business/
  30. * @param page 0 Int 页码: 不传默认取第1页数据,每页20条数据
  31. * @return {"code":0, "count":1, "data": []}
  32. * @return_param id integer id
  33. * @return_param name string 名
  34. * @return_param account string 账号
  35. * @return_param phone string 手机号
  36. * @return_param company string 公司
  37. * @return_param cityId integer 城市ID
  38. * @return_param provinceId integer 省ID
  39. * @return_param deadline string 到期时间
  40. * @return_param pwd string 密码
  41. * @return_param type integer 1审定核证机构2资源减排所有方3两个都选
  42. * @return_param cityName string 城市名称
  43. * @return_param provinceName string 省名称
  44. * @return_param lastTime string 上次登录时间
  45. * @return_param createdAt date -
  46. * @return_param updatedAt date -
  47. * @remark
  48. * @number
  49. */
  50. router.get('/', async (req, res) => {
  51. const { page = 0 } = req.query;
  52. const where = _.omit(req.query, ['page']);
  53. const info = onSuccess();
  54. info.data = await Business.findAll({ where, limit, offset: page * limit });
  55. info.data = await fill(info.data, fillSingle);
  56. if (!page) {
  57. info.count = await Business.count({ where });
  58. }
  59. res.send(info);
  60. });
  61. /**
  62. * showdoc
  63. * @catalog v1/后台/商家
  64. * @title 商家详情
  65. * @description
  66. * @method GET
  67. * @url /master/business/:id
  68. * @param :id 1 STRING 详情ID
  69. * @return {"code":0, "data": {}}
  70. * @return_param id integer id
  71. * @return_param name string 名
  72. * @return_param account string 账号
  73. * @return_param phone string 手机号
  74. * @return_param company string 公司
  75. * @return_param cityId integer 城市ID
  76. * @return_param provinceId integer 省ID
  77. * @return_param deadline string 到期时间
  78. * @return_param pwd string 密码
  79. * @return_param type integer 1审定核证机构2资源减排所有方3两个都选
  80. * @return_param cityName string 城市名称
  81. * @return_param provinceName string 省名称
  82. * @return_param lastTime string 上次登录时间
  83. * @return_param createdAt date -
  84. * @return_param updatedAt date -
  85. * @remark
  86. * @number
  87. */
  88. router.get('/:id', async (req, res) => {
  89. let data = await Business.findOne({ where: req.params });
  90. data = await fill(data, fillSingle);
  91. res.send(onSuccess(data));
  92. });
  93. /**
  94. * showdoc
  95. * @catalog v1/后台/商家
  96. * @title 商家添加
  97. * @description
  98. * @method POST
  99. * @url /master/business/
  100. * @param name 1 string 名
  101. * @param account 1 string 账号
  102. * @param phone 1 string 手机号
  103. * @param company 0 string 公司
  104. * @param cityId 1 integer 城市ID
  105. * @param provinceId 1 integer 省ID
  106. * @param deadline 0 string 到期时间
  107. * @param pwd 1 string 密码
  108. * @param type 1 integer 1审定核证机构2资源减排所有方3两个都选
  109. * @return {"code":0, "data": {}}
  110. * @remark
  111. * @number
  112. */
  113. router.post(
  114. '/',
  115. check([body(['name', 'phone', 'cityId', 'provinceId', 'pwd']).notEmpty()]),
  116. async (req, res) => {
  117. const { pwd, account, phone } = req.body;
  118. const count = await Business.count({ where: { [Op.or]: [{ phone }, { account }] } });
  119. if (count) {
  120. return res.send(onError('账号或手机号重复'));
  121. }
  122. if (pwd.length < 6) {
  123. return res.send(onError('密码不能少于6位'));
  124. }
  125. pwd && (req.body.pwd = md5(pwd));
  126. const data = await Business.create(req.body);
  127. res.send(onSuccess(data));
  128. }
  129. );
  130. /**
  131. * showdoc
  132. * @catalog v1/后台/商家
  133. * @title 重置密码
  134. * @description 重置密码接口
  135. * @method PUT
  136. * @url /master/business/pwd/:id
  137. * @param :id 1 STRING 详情ID
  138. * @param pwd 1 string 密码
  139. * @return {"code":0, "msg": "修改成功"}
  140. * @remark
  141. * @number
  142. */
  143. router.put('/pwd/:id', async (req, res) => {
  144. const { pwd } = req.body;
  145. if (pwd.length < 6) {
  146. return res.send(onError('密码不能少于6位'));
  147. }
  148. pwd && (req.body.pwd = md5(pwd));
  149. const data = await Business.update(req.body, { where: req.params, limit: 1 });
  150. res.send(onSuccess(null, '修改成功'));
  151. });
  152. /**
  153. * showdoc
  154. * @catalog v1/后台/商家
  155. * @title 商家修改
  156. * @description
  157. * @method PUT
  158. * @url /master/business/:id
  159. * @param :id 1 STRING 详情ID
  160. * @param name 0 string 名
  161. * @param account 0 string 账号
  162. * @param phone 0 string 手机号
  163. * @param company 0 string 公司
  164. * @param cityId 0 integer 城市ID
  165. * @param provinceId 0 integer 省ID
  166. * @param deadline 0 string 到期时间
  167. * @param pwd 0 string 密码
  168. * @param type 0 integer 1审定核证机构2资源减排所有方3两个都选
  169. * @return {"code":0, "msg": "修改成功"}
  170. * @remark
  171. * @number
  172. */
  173. router.put('/:id', async (req, res) => {
  174. const { pwd, phone, account } = req.body;
  175. if (pwd && pwd.length < 6) {
  176. return res.send(onError('密码不能少于6位'));
  177. }
  178. const count = await Business.count({
  179. where: { [Op.or]: [{ phone }, { account }], id: { [Op.ne]: req.params.id } },
  180. });
  181. if (count) {
  182. return res.send(onError('账号或手机号重复'));
  183. }
  184. pwd && (req.body.pwd = md5(pwd));
  185. const data = await Business.update(req.body, { where: req.params, limit: 1 });
  186. res.send(onSuccess(null, '修改成功'));
  187. });
  188. /**
  189. * showdoc
  190. * @catalog v1/后台/商家
  191. * @title 商家删除
  192. * @description
  193. * @method DELETE
  194. * @url /master/business/:id
  195. * @param :id 1 STRING 详情ID
  196. * @return {"code":0, "msg": "删除成功"}
  197. * @remark
  198. * @number
  199. */
  200. router.delete('/:id', async (req, res) => {
  201. const data = await Business.destroy({ where: req.params, limit: 1 });
  202. res.send(onSuccess(null, '删除成功'));
  203. });
  204. module.exports = router;