wechat_controller.js 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Ellisran
  6. * @date 2020/7/2
  7. * @version
  8. */
  9. const moment = require('moment');
  10. // const Controller = require('egg').Controller;
  11. const crypto = require('crypto');
  12. const maintainConst = require('../const/maintain');
  13. const wxConst = require('../const/wechat_template.js');
  14. const smsTypeConst = require('../const/sms_type');
  15. module.exports = app => {
  16. class WechatController extends app.BaseController {
  17. /**
  18. * 接入微信
  19. *
  20. * @param {Object} ctx - egg全局页面
  21. * @return {void}
  22. */
  23. async index(ctx) {
  24. try {
  25. const signature = ctx.query.signature;
  26. const timestamp = ctx.query.timestamp;
  27. const nonce = ctx.query.nonce;
  28. const echostr = ctx.query.echostr;
  29. const array = [ctx.app.config.wechatAll.token, timestamp, nonce];
  30. array.sort();
  31. const tempStr = array.join('');
  32. const hashCode = crypto.createHash('sha1');
  33. const resultCode = hashCode.update(tempStr, 'utf8').digest('hex');
  34. if (resultCode === signature) {
  35. ctx.body = echostr;
  36. // res.send(echostr);
  37. } else {
  38. throw '验证失败';
  39. }
  40. } catch (e) {
  41. console.log(e);
  42. }
  43. }
  44. /**
  45. * 微信登录验证
  46. *
  47. * @param {Object} ctx - egg全局页面
  48. * @return {void}
  49. */
  50. async oauth(ctx) {
  51. const redirect_uri = ctx.query.redirect_uri;
  52. const url = await app.wechat.oauth.getAuthorizeURL(redirect_uri, '', 'snsapi_userinfo');
  53. ctx.redirect(url);
  54. }
  55. /**
  56. * 绑定页面
  57. *
  58. * @param {Object} ctx - egg全局页面
  59. * @return {void}
  60. */
  61. async bind(ctx) {
  62. try {
  63. const user = await app.wechat.oauth.getUser(ctx.session.wechatToken.openid);
  64. const errorMessage = ctx.session.loginError;
  65. // 显示完删除
  66. ctx.session.loginError = null;
  67. // 获取系统维护信息
  68. const maintainData = await ctx.service.maintain.getDataById(1);
  69. const renderData = {
  70. maintainData,
  71. maintainConst,
  72. errorMessage,
  73. user,
  74. };
  75. await ctx.render('wechat/bind.ejs', renderData);
  76. } catch (e) {
  77. const renderData = {
  78. status: 1,
  79. msg: e,
  80. };
  81. await ctx.render('wechat/tips.ejs', renderData);
  82. }
  83. }
  84. async bindwx(ctx) {
  85. try {
  86. const result = await ctx.service.projectAccount.accountCheck(ctx.request.body);
  87. if (!result) {
  88. throw '用户名或密码错误';
  89. }
  90. if (result === 2) {
  91. throw '该账号已被停用,请联系销售人员';
  92. }
  93. const accountData = result;
  94. if (accountData.wx_openid || ctx.session.wechatToken.openid === accountData.wx_openid) {
  95. throw '该账号已经绑定过微信';
  96. }
  97. const wxAccountData = await ctx.service.projectAccount.getDataByCondition({ wx_openid: ctx.session.wechatToken.openid });
  98. if (wxAccountData) {
  99. throw '该微信号已绑定过本项目账号';
  100. }
  101. const user = await app.wechat.oauth.getUser(ctx.session.wechatToken.openid);
  102. const result2 = await ctx.service.projectAccount.bindWx(accountData.id, ctx.session.wechatToken.openid, user.nickname);
  103. if (!result2) {
  104. throw '绑定失败';
  105. }
  106. const projectData = await ctx.service.project.getDataById(accountData.project_id);
  107. // 绑定成功通知
  108. const templateId = 'ElT988uf7EV8ROPKSAX7z7tN9ZxZCDMaXK5ouc9N49E';
  109. const url = '';
  110. const msgData = {
  111. first: {
  112. value: '微信绑定成功',
  113. },
  114. keyword1: {
  115. value: accountData.account,
  116. },
  117. keyword2: {
  118. value: '项目编号' + projectData.code + ' 账号' + accountData.account + ' 绑定成功',
  119. },
  120. remark: {
  121. value: '欢迎使用纵横云计量,我们竭诚为您服务。',
  122. },
  123. };
  124. await app.wechat.api.sendTemplate(ctx.session.wechatToken.openid, templateId, url, '', msgData);
  125. const renderData = {
  126. status: 0,
  127. msg: '绑定成功',
  128. };
  129. await ctx.render('wechat/tips.ejs', renderData);
  130. } catch (error) {
  131. this.log(error);
  132. ctx.session.loginError = error;
  133. ctx.redirect('/wx/bind');
  134. }
  135. }
  136. // 设置用户微信登录项目,跳转到对应wap页面
  137. async url2wap(ctx) {
  138. try {
  139. if (!ctx.query.project || !ctx.query.url) {
  140. throw '参数有误';
  141. }
  142. const code = ctx.query.project;
  143. // 查找项目数据
  144. const projectData = await ctx.service.project.getProjectByCode(code.toString().trim());
  145. if (projectData === null) {
  146. throw '不存在项目数据';
  147. }
  148. const pa = await ctx.service.projectAccount.getDataByCondition({ project_id: projectData.id, wx_openid: ctx.session.wechatToken.openid });
  149. if (!pa) {
  150. throw '该微信号未绑定此项目';
  151. }
  152. if (pa.enable !== 1) {
  153. throw '该账号已被停用,请联系销售人员';
  154. }
  155. // 设置项目和用户session记录
  156. const result = await ctx.service.projectAccount.accountLogin({ project: projectData, accountData: pa }, 3);
  157. if (!result) {
  158. throw '登录出错';
  159. }
  160. ctx.redirect(ctx.query.url);
  161. } catch (error) {
  162. const renderData = {
  163. status: 1,
  164. msg: error,
  165. };
  166. await ctx.render('wechat/tips.ejs', renderData);
  167. }
  168. }
  169. async project(ctx) {
  170. try {
  171. // const user = await app.wechat.oauth.getUser(ctx.session.wechatToken.openid);
  172. const openid = ctx.session.wechatToken.openid;
  173. // const openid = 'fasdfklahsdklf';
  174. const paList = await ctx.service.projectAccount.getAllDataByCondition({ where: { wx_openid: openid } });
  175. const pidList = ctx.app._.uniq(ctx.app._.map(paList, 'project_id'));
  176. const pList = [];
  177. const redirect_url = ctx.protocol + '://' + ctx.host + '/wap/dashboard';
  178. for (const p of pidList) {
  179. const pro = await ctx.service.project.getDataById(p);
  180. pList.push(pro);
  181. }
  182. if (pList.length === 0) {
  183. throw '该微信号未绑定任何项目';
  184. }
  185. // 获取系统维护信息
  186. const maintainData = await ctx.service.maintain.getDataById(1);
  187. const renderData = {
  188. maintainData,
  189. maintainConst,
  190. // user,
  191. pList,
  192. redirect_url,
  193. };
  194. // ctx.body = renderData;
  195. await ctx.render('wechat/project.ejs', renderData);
  196. } catch (e) {
  197. const renderData = {
  198. status: 1,
  199. msg: e,
  200. };
  201. await ctx.render('wechat/tips.ejs', renderData);
  202. }
  203. }
  204. async oauthTxt(ctx) {
  205. ctx.body = 't3MkWAMqplVxPjmr';
  206. }
  207. async testwx(ctx) {
  208. try {
  209. const sck = 'https://scn.ink/';
  210. // 微信模板通知
  211. const tender = {
  212. data: {
  213. name: 'XXX标段',
  214. },
  215. info: {
  216. deal_info: {
  217. buildName: 'XX项目',
  218. },
  219. },
  220. };
  221. ctx.tender = tender;
  222. const stageInfo = await ctx.service.stage.getDataById(1704);
  223. const shenpiUrl = await ctx.helper.urlToShort(ctx.protocol + '://' + ctx.host + '/wap/tender/1998/stage/' + stageInfo.order);
  224. const wechatData = {
  225. wap_url: sck + shenpiUrl,
  226. qi: stageInfo.order,
  227. status: wxConst.status.success,
  228. tips: wxConst.tips.success,
  229. code: 'P1002',
  230. };
  231. // ctx.body = { tender, wechatData };
  232. await ctx.helper.sendWechat(133, smsTypeConst.const.JL, smsTypeConst.judge.result.toString(), wxConst.template.stage, wechatData);
  233. ctx.body = 'success';
  234. } catch (error) {
  235. console.log(error);
  236. ctx.body = error;
  237. }
  238. }
  239. }
  240. return WechatController;
  241. };