profile_controller.js 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  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);
  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 qrCode(ctx) {
  183. const size = 5;
  184. const margin = 1;
  185. try {
  186. // 获取当前用户数据
  187. const sessionUser = ctx.session.sessionUser;
  188. const text = ctx.request.header.host + '/sign?user_id=' + sessionUser.accountId + '&app_token=' + sessionUser.sessionToken;
  189. // 大小默认5,二维码周围间距默认1
  190. const img = qr.image(text || '', { type: 'png', size: size || 5, margin: margin || 1 });
  191. ctx.status = 200;
  192. ctx.type = 'image/png';
  193. ctx.body = img;
  194. } catch (e) {
  195. ctx.status = 414;
  196. ctx.set('Content-Type', 'text/html');
  197. ctx.body = '<h1>414 Request-URI Too Large</h1>';
  198. }
  199. }
  200. /**
  201. * 账号安全
  202. *
  203. * @param {object} ctx - egg全局变量
  204. * @return {void}
  205. */
  206. async safe(ctx) {
  207. // 获取当前用户数据
  208. const sessionUser = ctx.session.sessionUser;
  209. // 获取账号数据
  210. const accountData = await ctx.service.projectAccount.getDataByCondition({ id: sessionUser.accountId });
  211. // 获取修改密码的字段规则
  212. const passwordRule = ctx.service.projectAccount.rule('modifyPassword');
  213. const passwordJsValidator = await this.jsValidator.convert(passwordRule).setSelector('#password-form').build();
  214. const renderData = {
  215. accountData,
  216. passwordJsValidator,
  217. };
  218. await this.layout('profile/safe.ejs', renderData);
  219. }
  220. }
  221. return ProfileController;
  222. };