user_model.js 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. /**
  2. * 用户业务模型
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/6/9
  6. * @version
  7. */
  8. import mongoose from "mongoose";
  9. import Request from "request";
  10. import BaseModel from "../../common/base/base_model"
  11. import LogModel from "./log_model";
  12. class UserModel extends BaseModel {
  13. /**
  14. * 企业所在地区
  15. *
  16. * @var {object}
  17. */
  18. province = ['北京', '天津', '河北', '山西', '内蒙古', '辽宁', '吉林', '黑龙江', '上海', '江苏', '浙江', '安徽',
  19. '福建', '江西', '山东', '河南', '湖北', '湖南', '广东', '广西', '海南', '重庆', '四川', '贵州', '云南', '西藏',
  20. '陕西', '甘肃', '青海', '宁夏', '新疆', '台湾', '香港', '澳门',];
  21. /**
  22. * 企业类型
  23. *
  24. * @var
  25. */
  26. companyType = ['建设单位', '设计单位', '施工单位', '监理单位', '审核单位', '咨询公司', '招标代理', '住建部', '财政', '审计',
  27. '造价管理站', '学校', '个人', '其他'];
  28. /**
  29. * 企业规模
  30. *
  31. * @var
  32. */
  33. companyScale = ['1-50', '50-100', '100-500', '500+'];
  34. /**
  35. * 构造函数
  36. *
  37. * @return {void}
  38. */
  39. constructor() {
  40. let parent = super();
  41. parent.model = mongoose.model('user');
  42. parent.init();
  43. }
  44. /**
  45. * 根据用户名密码调用SSO接口获取信息
  46. *
  47. * @param {string} username
  48. * @param {string} password
  49. * @return {object}
  50. */
  51. async getInfoFromSSO(username, password) {
  52. let postData = {
  53. url: 'http://sso.smartcost.com.cn/api/jzlogin',
  54. form: {username: username, userpasswd: password},
  55. encoding: 'utf8'
  56. };
  57. return new Promise(function (resolve, reject) {
  58. try {
  59. // 请求接口
  60. Request.post(postData, function (err, postResponse, body) {
  61. if (err) {
  62. console.log('111');
  63. throw '请求错误';
  64. }
  65. if (postResponse.statusCode !== 200) {
  66. throw '通行证验证失败!';
  67. }
  68. resolve(body);
  69. });
  70. } catch (error) {
  71. reject([]);
  72. }
  73. });
  74. }
  75. /**
  76. * 根据用户id和token调用SSO接口获取信息
  77. *
  78. * @param {string} username
  79. * @param {string} password
  80. * @return {object}
  81. */
  82. async getInfoFromSSO2(ssoID, token) {
  83. let postData = {
  84. url: 'http://sso.smartcost.com.cn/building/api/login/auth',
  85. form: {ssoID: ssoID, token: token},
  86. encoding: 'utf8'
  87. };
  88. return new Promise(function (resolve, reject) {
  89. try {
  90. // 请求接口
  91. Request.post(postData, function (err, postResponse, body) {
  92. if (err) {
  93. console.log('111');
  94. throw '请求错误';
  95. }
  96. if (postResponse.statusCode !== 200) {
  97. throw '通行证验证失败!';
  98. }
  99. resolve(body);
  100. });
  101. } catch (error) {
  102. reject([]);
  103. }
  104. });
  105. }
  106. /**
  107. * 标记用户
  108. *
  109. * @param {object} userData
  110. * @param {Object} request
  111. * @return {Promise}
  112. */
  113. async markUser(userData, request = null) {
  114. let userDataFromDb2 = await this.findDataBySsoId(userData.ssoId);
  115. let userDataFromDb = await this.findDataByName(userData.username); //后面新增的账号可淘汰这方法,当前使用是为了兼容旧的账号
  116. let result = false;
  117. userData.latest_login = new Date().getTime();
  118. if (userDataFromDb === null && userDataFromDb2 === null) {
  119. // 不存在用户则入库
  120. this.setScene();//恢复场景,用户有可能公司real_name等信息为空,不能设置为必填
  121. result = await this.addUser(userData);
  122. userDataFromDb = result;
  123. } else {
  124. // 存在则新增登录信息并更新账号信息
  125. // let condition = {ssoId: sessionUser.ssoId};
  126. let condition = {username: userData.username};
  127. let UpdateData = {
  128. email : userData.email,
  129. mobile : userData.mobile,
  130. ssoId : userData.ssoId,
  131. latest_login:userData.latest_login,
  132. isUserActive: userData.isUserActive,
  133. };
  134. let updateResult = await this.updateUser(condition,UpdateData);
  135. if (updateResult.ok === 1) {
  136. let logModel = new LogModel();
  137. result = await logModel.addLoginLog(userDataFromDb._id, request);
  138. }
  139. }
  140. request.session.sessionUser.id = userDataFromDb._id;
  141. request.session.sessionUser.real_name = userDataFromDb.real_name;
  142. request.session.sessionUser.latest_used = userDataFromDb.latest_used;//设置最近使用的编办
  143. return result;
  144. }
  145. /**
  146. * 选择场景
  147. *
  148. * @param {string} scene
  149. */
  150. setScene(scene = '') {
  151. /* switch (scene) {
  152. case 'saveInfo':
  153. this.model.schema.path('real_name').required(true);
  154. this.model.schema.path('company').required(true);
  155. this.model.schema.path('province').required(true);
  156. this.model.schema.path('version').required(true);
  157. break;
  158. case '':
  159. this.model.schema.path('real_name').required(false);
  160. this.model.schema.path('company').required(false);
  161. this.model.schema.path('province').required(false);
  162. this.model.schema.path('version').required(false);
  163. }*/
  164. }
  165. /**
  166. * 根据用户名查找数据
  167. *
  168. * @param {string} username
  169. * @return {object}
  170. */
  171. findDataByName(username) {
  172. return this.db.findOne({username: username});
  173. }
  174. /**
  175. * 根据ssoID查找数据
  176. *
  177. * @param {string} ssoId
  178. * @return {object}
  179. */
  180. findDataBySsoId(ssoId) {
  181. return this.db.findOne({ssoId: ssoId});
  182. }
  183. /**
  184. * 根据手机号查找数据
  185. *
  186. * @param {string} mobile
  187. * @return {object}
  188. */
  189. findDataByMobile(mobile) {
  190. return this.db.findOne({mobile: mobile});
  191. }
  192. /**
  193. * 根据userId查找数据
  194. *
  195. * @param {string} ssoId
  196. * @return {object}
  197. */
  198. async findDataById(id) {
  199. let objId = mongoose.Types.ObjectId(id);
  200. return await this.db.findOne({_id: objId});
  201. }
  202. async findDataByAccount(account) {
  203. let userinfo = await this.db.findOne({mobile: account});
  204. let userinfo2 = await this.db.findOne({email: account});
  205. if (userinfo) {
  206. return userinfo;
  207. } else if (userinfo2) {
  208. return userinfo2;
  209. } else {
  210. return false;
  211. }
  212. }
  213. /**
  214. * 新增用户
  215. *
  216. * @param {object} userData
  217. * @return {Promise|boolean}
  218. */
  219. addUser(userData) {
  220. let insertData = {
  221. ssoId: userData.ssoId,
  222. username: userData.username,
  223. email: userData.email,
  224. mobile: userData.mobile,
  225. create_time: new Date().getTime(),
  226. latest_login: new Date().getTime(),
  227. isUserActive: userData.isUserActive,
  228. };
  229. return this.db.create(insertData);
  230. }
  231. //更新最近使用编办ID
  232. async updateLatestUsed(userID,compilationID){
  233. if(userID && compilationID){
  234. return await this.db.update({'_id':userID},{'latest_used':compilationID});
  235. }
  236. }
  237. /**
  238. * 更新用户数据
  239. *
  240. * @param {object} updateData
  241. * @return {Promise}
  242. */
  243. async updateUser(condition, updateData) {
  244. if (Object.keys(condition).length <= 0 || Object.keys(updateData).length <= 0) {
  245. return null;
  246. }
  247. return await this.db.update(condition, updateData);
  248. }
  249. async addVersion(condition, versionInfo){
  250. return await this.db.findOneAndUpdate(condition, {$addToSet: {versionInfo: versionInfo}});
  251. }
  252. async removeVersion(userId, compilationId){
  253. let userObjId = mongoose.Types.ObjectId(userId);
  254. return await this.db.findOneAndUpdate({_id: userObjId}, {$pull: {versionInfo: {compilationId: compilationId}}});
  255. }
  256. /**
  257. * 判断用户使用免费版还是专业版
  258. *
  259. * @param ssoId
  260. * @param compilationId
  261. * @return {version}
  262. */
  263. async getVersionFromUpgrade(ssoId, compilationId){
  264. let version = '纵横公路养护造价(云版)';//'纵横公路养护造价(免费云版)'; 2019-03-28 需求修改,听说不知道多久的以后还会改回来--勿删!!!!!
  265. /*let userData = await this.findDataBySsoId(ssoId);
  266. if (userData.upgrade_list !== undefined) {
  267. let compilationInfo = userData.upgrade_list.find(function (item) {
  268. return item.compilationID === compilationId;
  269. });
  270. if (compilationInfo !== undefined && compilationInfo.isUpgrade === true) {
  271. version = '纵横公路养护造价(专业云版)';
  272. }
  273. }*/
  274. return version;
  275. }
  276. }
  277. export default UserModel;