WXWorkLogin.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. const md5 = require("md5");
  2. const API = require("../../lib/API");
  3. const { BaseStdResponse } = require("../../BaseStdResponse");
  4. const db = require("../../plugin/DataBase/db");
  5. const {
  6. getUserInfo,
  7. getUserID
  8. } = require("../../plugin/WXWork/GetInfo");
  9. class WXWorkLogin extends API {
  10. constructor() {
  11. super();
  12. this.setMethod("POST");
  13. this.setPath("/User/WXWorkLogin");
  14. }
  15. createSession(uuid, salt) {
  16. return md5(`${uuid}${salt}${new Date().getTime()}`);
  17. }
  18. async onRequest(req, res) {
  19. const { code } = req.body;
  20. if (!code) {
  21. res.json({ ...BaseStdResponse.MISSING_PARAMETER, endpoint: 7841686 });
  22. return;
  23. }
  24. try {
  25. const idRes = await getUserID(code);
  26. if (!idRes || !idRes.success) {
  27. return res.json({ ...BaseStdResponse.ERR, endpoint: 7894377, msg: `登录失败!${idRes.msg}` });
  28. }
  29. const wxid = idRes.userid;
  30. const session = this.createSession(wxid, Math.random().toFixed(6).slice(-6));
  31. let sql = 'SELECT uuid, username, avatar FROM users WHERE wxid = ?';
  32. let rows = await db.query(sql, [wxid]);
  33. let result, uuid, username, avatar;
  34. if (rows.length > 0) {
  35. // 用户存在,更新 session
  36. ({ uuid, username, avatar } = rows[0]);
  37. avatar = avatar && avatar != '' ? avatar : 'https://git.vthc.cn/avatars/1';
  38. const updateQuery = 'UPDATE users SET session = ? WHERE wxid = ?';
  39. result = await db.query(updateQuery, [session, wxid]);
  40. } else {
  41. // 用户不存在,注册用户
  42. const infoRes = await getUserInfo(wxid);
  43. if (!infoRes || !infoRes.success) {
  44. return res.json({ ...BaseStdResponse.ERR, endpoint: 7894198, msg: `登录失败!${infoRes.msg}` });
  45. }
  46. ({ name: username, avatar } = infoRes);
  47. // TODO 企微扫码登录不会返回用户头像 这里疏忽了 后面再改
  48. avatar = avatar && avatar != '' ? avatar : 'https://git.vthc.cn/avatars/1';
  49. uuid = md5(Date.now() + wxid + code);
  50. // 查询users表中是否有用户
  51. const userCountQuery = 'SELECT COUNT(*) as count FROM users';
  52. const [userCountResult] = await db.query(userCountQuery);
  53. const userCount = userCountResult.count;
  54. // 如果是第一个注册的用户 授予admin权限
  55. const admin = userCount === 0 ? 1 : 0;
  56. const insertQuery = 'INSERT INTO users (uuid, username, wxid, avatar, session, admin) VALUES (?, ?, ?, ?, ?, ?)';
  57. result = await db.query(insertQuery, [uuid, username, wxid, avatar, session, admin]);
  58. }
  59. if (result && result.affectedRows > 0) {
  60. return res.json({
  61. ...BaseStdResponse.OK,
  62. data: {
  63. uuid,
  64. username,
  65. wxid,
  66. avatar,
  67. session
  68. }
  69. });
  70. } else {
  71. return res.json({ ...BaseStdResponse.ERR, endpoint: 7894378, msg: '登录失败!' });
  72. }
  73. } catch (error) {
  74. this.logger.error(`企业微信登录失败!${error.stack}`)
  75. return res.json({ ...BaseStdResponse.ERR, endpoint: 7894379, msg: '登录失败!' });
  76. }
  77. }
  78. }
  79. module.exports.WXWorkLogin = WXWorkLogin;