user_model.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498
  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. * @var
  38. */
  39. dayMsg = ['所有', '最近24小时', '最近3天', '最近7天', '最近30天'];
  40. /**
  41. * 构造函数
  42. *
  43. * @return {void}
  44. */
  45. constructor() {
  46. let parent = super();
  47. parent.model = mongoose.model('user');
  48. parent.init();
  49. }
  50. /**
  51. * 根据用户名密码调用SSO接口获取信息
  52. *
  53. * @param {string} username
  54. * @param {string} password
  55. * @return {object}
  56. */
  57. async getInfoFromSSO(username, password) {
  58. let postData = {
  59. url: 'http://sso.smartcost.com.cn/api/jzlogin',
  60. form: {username: username, userpasswd: password},
  61. encoding: 'utf8'
  62. };
  63. return new Promise(function (resolve, reject) {
  64. try {
  65. // 请求接口
  66. Request.post(postData, function (err, postResponse, body) {
  67. if (err) {
  68. console.log('111');
  69. reject('请求错误');
  70. }
  71. if (postResponse.statusCode !== 200) {
  72. reject('通行证验证失败!');
  73. }
  74. resolve(body);
  75. });
  76. } catch (error) {
  77. reject([]);
  78. }
  79. });
  80. }
  81. /**
  82. * 根据用户手机号码调用SSO接口获取信息
  83. *
  84. * @param {string} mobile
  85. * @param {string} login 1为登录,不存在则是查询
  86. * @return {object}
  87. */
  88. async getInfoFromSSOMobile(mobile, login = '1') {
  89. const fromData = {account: mobile};
  90. if (login === '1') {
  91. fromData.login = 1;
  92. }
  93. let postData = {
  94. url: 'http://sso.smartcost.com.cn/building/api/mobile/login',
  95. form: fromData,
  96. encoding: 'utf8'
  97. };
  98. return new Promise(function (resolve, reject) {
  99. try {
  100. // 请求接口
  101. Request.post(postData, function (err, postResponse, body) {
  102. if (err) {
  103. console.log('111');
  104. reject('请求错误');
  105. }
  106. if (postResponse.statusCode !== 200) {
  107. reject('通行证验证失败!');
  108. }
  109. resolve(body);
  110. });
  111. } catch (error) {
  112. reject([]);
  113. }
  114. });
  115. }
  116. /**
  117. * 根据用户id和token调用SSO接口获取信息
  118. *
  119. * @param {string} username
  120. * @param {string} password
  121. * @return {object}
  122. */
  123. async getInfoFromSSO2(ssoID, token) {
  124. let postData = {
  125. url: 'http://sso.smartcost.com.cn/building/api/login/auth',
  126. form: {ssoID: ssoID, token: token},
  127. encoding: 'utf8'
  128. };
  129. return new Promise(function (resolve, reject) {
  130. try {
  131. // 请求接口
  132. Request.post(postData, function (err, postResponse, body) {
  133. if (err) {
  134. console.log('111');
  135. reject('请求错误');
  136. }
  137. if (postResponse.statusCode !== 200) {
  138. reject('通行证验证失败!');
  139. }
  140. resolve(body);
  141. });
  142. } catch (error) {
  143. reject([]);
  144. }
  145. });
  146. }
  147. /**
  148. * 标记用户
  149. *
  150. * @param {object} userData
  151. * @param {Object} request
  152. * @return {Promise}
  153. */
  154. async markUser(userData, request = null) {
  155. let userDataFromDb2 = await this.findDataBySsoId(userData.ssoId);
  156. let userDataFromDb = await this.findDataByName(userData.username); //后面新增的账号可淘汰这方法,当前使用是为了兼容旧的账号
  157. let result = false;
  158. userData.latest_login = new Date().getTime();
  159. if (userDataFromDb === null && userDataFromDb2 === null) {
  160. // 不存在用户则入库
  161. this.setScene();//恢复场景,用户有可能公司real_name等信息为空,不能设置为必填
  162. result = await this.addUser(userData);
  163. userDataFromDb = result;
  164. } else {
  165. // 存在则新增登录信息并更新账号信息
  166. // let condition = {ssoId: sessionUser.ssoId};
  167. let condition = {username: userData.username};
  168. let UpdateData = {
  169. email : userData.email,
  170. mobile : userData.mobile,
  171. ssoId : userData.ssoId,
  172. qq: userData.qq,
  173. latest_login:userData.latest_login,
  174. isUserActive: userData.isUserActive,
  175. };
  176. console.log("updateUser 开始 -------------------------------");
  177. let updateResult = await this.updateUser(condition,UpdateData);
  178. console.log("updateUser 完成 -------------------------------");
  179. if (updateResult.ok === 1) {
  180. let logModel = new LogModel();
  181. result = await logModel.addLoginLog(userDataFromDb._id, request);
  182. console.log("addLoginLog 完成 -------------------------------");
  183. }
  184. }
  185. request.session.sessionUser.id = userDataFromDb._id;
  186. request.session.sessionUser.real_name = userDataFromDb.real_name;
  187. request.session.sessionUser.latest_used = userDataFromDb.latest_used;//设置最近使用的编办
  188. return result;
  189. }
  190. /**
  191. * 选择场景
  192. *
  193. * @param {string} scene
  194. */
  195. setScene(scene = '') {
  196. /* switch (scene) {
  197. case 'saveInfo':
  198. this.model.schema.path('real_name').required(true);
  199. this.model.schema.path('company').required(true);
  200. this.model.schema.path('province').required(true);
  201. this.model.schema.path('version').required(true);
  202. break;
  203. case '':
  204. this.model.schema.path('real_name').required(false);
  205. this.model.schema.path('company').required(false);
  206. this.model.schema.path('province').required(false);
  207. this.model.schema.path('version').required(false);
  208. }*/
  209. }
  210. /**
  211. * 根据用户名查找数据
  212. *
  213. * @param {string} username
  214. * @return {object}
  215. */
  216. findDataByName(username) {
  217. return this.db.findOne({username: username});
  218. }
  219. /**
  220. * 根据ssoID查找数据
  221. *
  222. * @param {string} ssoId
  223. * @return {object}
  224. */
  225. findDataBySsoId(ssoId) {
  226. return this.db.findOne({ssoId: ssoId});
  227. }
  228. /**
  229. * 根据手机号查找数据
  230. *
  231. * @param {string} mobile
  232. * @return {object}
  233. */
  234. findDataByMobile(mobile) {
  235. return this.db.findOne({mobile: mobile});
  236. }
  237. /**
  238. * 根据userId查找数据
  239. *
  240. * @param {string} ssoId
  241. * @return {object}
  242. */
  243. async findDataById(id) {
  244. let objId = mongoose.Types.ObjectId(id);
  245. return await this.db.findOne({_id: objId});
  246. }
  247. async findDataByAccount(account) {
  248. let userinfo = await this.db.findOne({mobile: account});
  249. let userinfo2 = await this.db.findOne({email: account});
  250. if (userinfo) {
  251. return userinfo;
  252. } else if (userinfo2) {
  253. return userinfo2;
  254. } else {
  255. return false;
  256. }
  257. }
  258. /**
  259. * 新增用户
  260. *
  261. * @param {object} userData
  262. * @return {Promise|boolean}
  263. */
  264. addUser(userData) {
  265. let insertData = {
  266. ssoId: userData.ssoId,
  267. username: userData.username,
  268. email: userData.email,
  269. mobile: userData.mobile,
  270. qq: userData.qq,
  271. create_time: new Date().getTime(),
  272. latest_login: new Date().getTime(),
  273. isUserActive: userData.isUserActive,
  274. };
  275. return this.db.create(insertData);
  276. }
  277. //更新最近使用编办ID
  278. async updateLatestUsed(userID,compilationID){
  279. if(userID && compilationID){
  280. return await this.db.update({'_id':userID},{'latest_used':compilationID});
  281. }
  282. }
  283. /**
  284. * 更新用户数据
  285. *
  286. * @param {object} updateData
  287. * @return {Promise}
  288. */
  289. async updateUser(condition, updateData) {
  290. if (Object.keys(condition).length <= 0 || Object.keys(updateData).length <= 0) {
  291. return null;
  292. }
  293. return await this.db.update(condition, updateData);
  294. }
  295. async addVersion(condition, versionInfo){
  296. return await this.db.findOneAndUpdate(condition, {$addToSet: {versionInfo: versionInfo}});
  297. }
  298. async removeVersion(userId, compilationId){
  299. let userObjId = mongoose.Types.ObjectId(userId);
  300. return await this.db.findOneAndUpdate({_id: userObjId}, {$pull: {versionInfo: {compilationId: compilationId}}});
  301. }
  302. /**
  303. * 判断用户使用免费版还是专业版
  304. *
  305. * @param ssoId
  306. * @param compilationId
  307. * @return {version}
  308. */
  309. async getVersionFromUpgrade(ssoId, compilationId){
  310. let version = '大司空云计价(免费公用版)';
  311. let userData = await this.findDataBySsoId(ssoId);
  312. if (userData.upgrade_list !== undefined) {
  313. let compilationInfo = userData.upgrade_list.find(function (item) {
  314. return item.compilationID === compilationId;
  315. });
  316. if (compilationInfo !== undefined && compilationInfo.isUpgrade === true) {
  317. version = '大司空云计价(专业版)';
  318. }
  319. }
  320. return version;
  321. }
  322. /**
  323. * 判断用户是免费版还是专业版用户
  324. */
  325. async isFree(ssoId, compilationId) {
  326. const userData = await this.findDataBySsoId(ssoId);
  327. if (!userData) {
  328. throw '不存在此用户';
  329. }
  330. const upgrade_list = userData.upgrade_list;
  331. let free = true;
  332. if (upgrade_list && upgrade_list.length > 0) {
  333. const upgrade = upgrade_list.find(function (item) {
  334. return item.compilationID === compilationId && item.isUpgrade === true;
  335. });
  336. if (upgrade) {
  337. free = false;
  338. }
  339. }
  340. return free
  341. }
  342. /*
  343. * 添加联系人,互相添加
  344. */
  345. async addContact(userID, contactID) {
  346. const data = [
  347. { user: userID, contact: contactID },
  348. { user: contactID, contact: userID }
  349. ];
  350. const task = [];
  351. for (const { user, contact } of data) {
  352. const hasThisContact = await this.model.count({_id: mongoose.Types.ObjectId(user), 'contacts.userID': contact});
  353. // 没有则添加
  354. if (!hasThisContact) {
  355. task.push(this.model.update({_id: mongoose.Types.ObjectId(user)}, {$push: {contacts: {userID: contact}}}));
  356. }
  357. }
  358. if (task.length) {
  359. await Promise.all(task);
  360. }
  361. }
  362. async getContacts(userID) {
  363. const user = await this.model.findOne({_id: mongoose.Types.ObjectId(userID)}, 'contacts').lean();
  364. if (!user || !user.contacts || !user.contacts.length) {
  365. return [];
  366. }
  367. const userIDList = user.contacts.map(item => mongoose.Types.ObjectId(item.userID));
  368. const users = await this.model.find({_id: {$in: userIDList}}, 'real_name mobile company');
  369. return users;
  370. }
  371. /**
  372. * 获取列表
  373. *
  374. * @param {object} condition
  375. * @param {number} page
  376. * @param {Number} pageSize
  377. * @return {promise}
  378. */
  379. async getList(condition = null, page = 1, pageSize = 30, sort = {_id:-1}) {
  380. page = parseInt(page);
  381. page = page <= 1 ? 1 : page;
  382. let option = {pageSize: pageSize, offset: parseInt((page - 1) * pageSize), sort: sort};
  383. let userList = await this.db.find(condition, null, option);
  384. userList = userList.length > 0 ? userList : [];
  385. return userList;
  386. }
  387. /**
  388. * 获取过滤条件
  389. *
  390. * @return {Object}
  391. */
  392. getFilterCondition(request) {
  393. let condition = {};
  394. let regtime = request.query.regtime;
  395. regtime = regtime !== '' && regtime !== undefined ? parseInt(regtime) : 0;
  396. if (regtime !== 0) {
  397. condition.create_time = this.getTimestamp(regtime);
  398. }
  399. //最近登录时间
  400. let loginTime = request.query.loginTime;
  401. loginTime = loginTime !== '' && loginTime !== undefined ? parseInt(loginTime) : 0;
  402. if (loginTime !== 0) {
  403. condition.latest_login = this.getTimestamp(loginTime);
  404. }
  405. let version = request.query.version;
  406. if(version !== '' && version !== undefined) {
  407. condition.version = version;
  408. }
  409. // 已升级费用定额
  410. let upGrade = request.query.upGrade;
  411. if(upGrade !== '' && upGrade !== undefined){
  412. condition.upgrade_list = {"$elemMatch":{"compilationID":upGrade,"isUpgrade":true}};
  413. }
  414. // 最近使用费用定额
  415. let latestUsed = request.query.latestUsed;
  416. if(latestUsed !== '' && latestUsed !== undefined){
  417. condition.latest_used = latestUsed;
  418. }
  419. let keyword = request.query.keyword;
  420. if (keyword !== '' && keyword !== undefined) {
  421. condition.$or = [{real_name : {$regex: keyword}},{email : {$regex: keyword}},{mobile : {$regex: keyword}},{company : {$regex: keyword}}];
  422. }
  423. return condition;
  424. }
  425. /**
  426. * 获取时间戳区间
  427. *
  428. * @return {Object}
  429. */
  430. getTimestamp(type) {
  431. let startTime = '';
  432. switch (type) {
  433. case 1 :
  434. startTime = Date.parse(new Date())-86400*1000;
  435. break;
  436. case 2 :
  437. startTime = Date.parse(new Date())-86400*1000*3;
  438. break;
  439. case 3 :
  440. startTime = Date.parse(new Date())-86400*1000*7;
  441. break;
  442. case 4 :
  443. startTime = Date.parse(new Date())-86400*1000*30;
  444. break;
  445. default :
  446. break;
  447. }
  448. let endTime = Date.parse(new Date());
  449. return startTime === '' ? '' : {'$gte': startTime, '$lt': endTime};
  450. }
  451. /**
  452. * 获取daymsg
  453. *
  454. */
  455. getDayMsg(index){
  456. return this.dayMsg[index];
  457. }
  458. }
  459. export default UserModel;