profile_controller.js 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. 'use strict';
  2. /**
  3. * 账号相关控制器
  4. *
  5. * @author CaiAoLin
  6. * @date 2018/1/26
  7. * @version
  8. */
  9. const profileMenu = require('../../config/menu').profileMenu;
  10. const qr = require('qr-image');
  11. module.exports = app => {
  12. class ProfileController extends app.BaseController {
  13. /**
  14. * 构造函数
  15. *
  16. * @param {Object} ctx - egg全局context
  17. * @return {void}
  18. */
  19. constructor(ctx) {
  20. super(ctx);
  21. ctx.subMenu = profileMenu;
  22. }
  23. /**
  24. * 账号资料页面
  25. *
  26. * @param {Object} ctx - egg全局变量
  27. * @return {void}
  28. */
  29. async info(ctx) {
  30. // 获取当前用户数据
  31. const sessionUser = ctx.session.sessionUser;
  32. // 获取账号数据
  33. const accountData = await ctx.service.projectAccount.getDataByCondition({ id: sessionUser.accountId });
  34. // 获取基础数据的字段规则
  35. const baseRule = ctx.service.projectAccount.rule('profileBase');
  36. const baseJsValidator = await this.jsValidator.convert(baseRule).setSelector('#base-form').build();
  37. const renderData = {
  38. accountData,
  39. baseJsValidator,
  40. };
  41. await this.layout('profile/info.ejs', renderData);
  42. }
  43. /**
  44. * 保存基本信息
  45. *
  46. * @param {Object} ctx - egg全局变量
  47. * @return {void}
  48. */
  49. async saveBase(ctx) {
  50. try {
  51. // 获取当前用户数据
  52. const sessionUser = ctx.session.sessionUser;
  53. // 获取基础数据的字段规则
  54. const baseRule = ctx.service.projectAccount.rule('profileBase');
  55. ctx.helper.validate(baseRule);
  56. const result = await ctx.service.projectAccount.save(ctx.request.body, sessionUser.accountId);
  57. if (!result) {
  58. throw '保存信息失败';
  59. }
  60. this.setMessage('修改成功', this.messageType.SUCCESS);
  61. } catch (error) {
  62. this.log(error);
  63. this.setMessage(error.toString(), this.messageType.ERROR);
  64. }
  65. ctx.redirect(ctx.request.header.referer);
  66. }
  67. /**
  68. * 修改密码操作
  69. *
  70. * @param {Object} ctx - egg全局变量
  71. * @return {void}
  72. */
  73. async modifyPassword(ctx) {
  74. const password = ctx.request.body.password;
  75. const newPassword = ctx.request.body.new_password;
  76. try {
  77. const sessionUser = ctx.session.sessionUser;
  78. let accountId = sessionUser.accountId;
  79. accountId = parseInt(accountId);
  80. if (isNaN(accountId) || accountId <= 0) {
  81. throw '参数错误';
  82. }
  83. // 验证数据
  84. const passwordRule = ctx.service.projectAccount.rule('modifyPassword');
  85. ctx.helper.validate(passwordRule);
  86. const result = await ctx.service.projectAccount.modifyPassword(accountId, password, newPassword);
  87. if (!result) {
  88. throw '修改密码失败';
  89. }
  90. this.setMessage('修改密码成功', this.messageType.SUCCESS);
  91. } catch (error) {
  92. this.setMessage(error.toString(), this.messageType.ERROR);
  93. }
  94. ctx.redirect(ctx.request.header.referer);
  95. }
  96. /**
  97. * 设置短信验证码
  98. *
  99. * @param {object} ctx - egg全局变量
  100. * @return {void}
  101. */
  102. async getCode(ctx) {
  103. const response = {
  104. err: 0,
  105. msg: '',
  106. };
  107. try {
  108. const sessionUser = ctx.session.sessionUser;
  109. const mobile = ctx.request.body.mobile;
  110. const rule = { mobile: { type: 'mobile', allowEmpty: false } };
  111. ctx.helper.validate(rule);
  112. const result = await ctx.service.projectAccount.setSMSCode(sessionUser.accountId, mobile);
  113. if (!result) {
  114. throw '获取验证码失败';
  115. }
  116. } catch (error) {
  117. response.err = 1;
  118. response.msg = error.toString();
  119. }
  120. ctx.body = response;
  121. }
  122. /**
  123. * 绑定认证手机
  124. *
  125. * @param {object} ctx - egg全局变量
  126. * @return {void}
  127. */
  128. async bindMobile(ctx) {
  129. try {
  130. const rule = ctx.service.projectAccount.rule('bindMobile');
  131. ctx.helper.validate(rule);
  132. const sessionUser = ctx.session.sessionUser;
  133. const result = await ctx.service.projectAccount.bindMobile(sessionUser.accountId, ctx.request.body, ctx.session.sessionProject.id);
  134. if (!result) {
  135. throw '绑定手机失败!';
  136. }
  137. this.setMessage('绑定成功', this.messageType.SUCCESS);
  138. } catch (error) {
  139. console.log(error);
  140. this.setMessage(error.toString(), this.messageType.ERROR);
  141. }
  142. ctx.redirect(ctx.request.header.referer);
  143. }
  144. /**
  145. * 短信通知
  146. *
  147. * @param {object} ctx - egg全局变量
  148. * @return {void}
  149. */
  150. async sms(ctx) {
  151. // 获取当前用户数据
  152. const sessionUser = ctx.session.sessionUser;
  153. // 获取账号数据
  154. const accountData = await ctx.service.projectAccount.getDataByCondition({ id: sessionUser.accountId });
  155. const renderData = {
  156. accountData,
  157. };
  158. await this.layout('profile/sms.ejs', renderData);
  159. }
  160. /**
  161. * 电子签名
  162. *
  163. * @param {object} ctx - egg全局变量
  164. * @return {void}
  165. */
  166. async sign(ctx) {
  167. // 获取当前用户数据
  168. const sessionUser = ctx.session.sessionUser;
  169. // 获取账号数据
  170. const accountData = await ctx.service.projectAccount.getDataByCondition({ id: sessionUser.accountId });
  171. const renderData = {
  172. accountData,
  173. };
  174. await this.layout('profile/sign.ejs', renderData);
  175. }
  176. /**
  177. * 电子签名删除
  178. *
  179. * @param {object} ctx - egg全局变量
  180. * @return {void}
  181. */
  182. async signDelete(ctx) {
  183. const response = {
  184. err: 0,
  185. msg: '',
  186. };
  187. try {
  188. const sessionUser = ctx.session.sessionUser;
  189. // 获取账号数据
  190. const accountData = await ctx.service.projectAccount.getDataByCondition({ id: sessionUser.accountId });
  191. if (accountData.sign_path === '') {
  192. throw '不存在签名';
  193. }
  194. const result = await ctx.service.projectAccount.update({ sign_path: '' }, { id: sessionUser.accountId });
  195. if (!result) {
  196. throw '移除签名失败';
  197. }
  198. } catch (error) {
  199. response.err = 1;
  200. response.msg = error.toString();
  201. }
  202. ctx.body = response;
  203. }
  204. /**
  205. * 生成二维码
  206. *
  207. * @param {object} ctx - egg全局变量
  208. * @return {void}
  209. */
  210. async qrCode(ctx) {
  211. const size = 5;
  212. const margin = 1;
  213. try {
  214. // 获取当前用户数据
  215. const sessionUser = ctx.session.sessionUser;
  216. const text = ctx.request.header.host + '/sign?user_id=' + sessionUser.accountId + '&app_token=' + sessionUser.sessionToken;
  217. // 大小默认5,二维码周围间距默认1
  218. const img = qr.image(text || '', { type: 'png', size: size || 5, margin: margin || 1 });
  219. ctx.status = 200;
  220. ctx.type = 'image/png';
  221. ctx.body = img;
  222. } catch (e) {
  223. ctx.status = 414;
  224. ctx.set('Content-Type', 'text/html');
  225. ctx.body = '<h1>414 Request-URI Too Large</h1>';
  226. }
  227. }
  228. /**
  229. * 账号安全
  230. *
  231. * @param {object} ctx - egg全局变量
  232. * @return {void}
  233. */
  234. async safe(ctx) {
  235. // 获取当前用户数据
  236. const sessionUser = ctx.session.sessionUser;
  237. // 获取账号数据
  238. const accountData = await ctx.service.projectAccount.getDataByCondition({ id: sessionUser.accountId });
  239. // 获取修改密码的字段规则
  240. const passwordRule = ctx.service.projectAccount.rule('modifyPassword');
  241. const passwordJsValidator = await this.jsValidator.convert(passwordRule).setSelector('#password-form').build();
  242. const renderData = {
  243. accountData,
  244. passwordJsValidator,
  245. };
  246. await this.layout('profile/safe.ejs', renderData);
  247. }
  248. }
  249. return ProfileController;
  250. };