user_model.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. /**
  2. * 前台用户相关数据模型
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/6/12
  6. * @version
  7. */
  8. import mongoose from "mongoose";
  9. import Moment from "moment";
  10. import BaseModel from "../../common/base/base_model";
  11. const projectModel = mongoose.model('projects');
  12. const unitPriceFileModel = mongoose.model('unit_price_file');
  13. const feeRateFileModel = mongoose.model('fee_rate_file');
  14. const optionsModel = mongoose.model('options');
  15. const settingModel = mongoose.model('setting');
  16. const messageModel = mongoose.model('user_message');
  17. const logModel = mongoose.model('log');
  18. const rptCfgModel = mongoose.model("rpt_cfg");
  19. const rptCusCfgModel = mongoose.model("rpt_customize_cfg");
  20. const comRationSecTreeModel = mongoose.model('complementary_ration_section_tree');
  21. const blockLibModel = mongoose.model('blockLibsModel');
  22. const comGLJLibMode = mongoose.model('complementary_glj_lib');
  23. const comGLJSectionModel = mongoose.model('complementary_glj_section');
  24. const comRationItemsModel = mongoose.model('complementary_ration_items');
  25. const comRationCoeModel = mongoose.model('complementary_ration_coe_list');
  26. const comRationInstalModel = mongoose.model('complementary_ration_installation');
  27. const comRationInstalSectionModel = mongoose.model('complementary_ration_installationSection');
  28. const rptTplTreeMode = mongoose.model("rpt_tpl_tree");
  29. let sysSchedule = require('../../sys_tools/models/sys_model');
  30. class UserModel extends BaseModel {
  31. /**
  32. * 企业所在地区
  33. *
  34. * @var {object}
  35. */
  36. province = ['北京', '天津', '河北', '山西', '内蒙古', '辽宁', '吉林', '黑龙江', '上海', '江苏', '浙江', '安徽',
  37. '福建', '江西', '山东', '河南', '湖北', '湖南', '广东', '广西', '海南', '重庆', '四川', '贵州', '云南', '西藏',
  38. '陕西', '甘肃', '青海', '宁夏', '新疆', '台湾', '香港', '澳门',];
  39. /**
  40. * 企业类型
  41. *
  42. * @var
  43. */
  44. companyType = ['建设单位', '设计单位', '施工单位', '监理单位', '审核单位', '咨询公司', '招标代理', '住建部', '财政', '审计',
  45. '造价管理站', '学校', '个人', '其他'];
  46. /**
  47. * 企业规模
  48. *
  49. * @var
  50. */
  51. companyScale = ['1-50', '50-100', '100-500', '500+'];
  52. /**
  53. * 最近天数
  54. *
  55. * @var
  56. */
  57. dayMsg = ['所有', '最近24小时', '最近3天', '最近7天', '最近30天'];
  58. /**
  59. * 构造函数
  60. *
  61. * @return {void}
  62. */
  63. constructor() {
  64. let parent = super();
  65. parent.model = mongoose.model('users');
  66. parent.init();
  67. }
  68. /**
  69. * 获取用户信息
  70. *
  71. * @param {object} condition
  72. * @param {number} page
  73. * @param {Number} pageSize
  74. * @return {promise}
  75. */
  76. async getByID(condition) {
  77. let user = await this.db.findOne(condition);
  78. //企业所在省份、类型、规模等转换
  79. if(this.isDef(user.province)) user._doc.province = this.province[user.province];
  80. if(this.isDef(user.company_type)) user._doc.company_type = this.companyType[user.company_type];
  81. if(this.isDef(user.company_scale)) user._doc.company_scale = this.companyScale[user.company_scale];
  82. if(this.isDef(user.create_time)) user._doc.create_time = Moment(user.create_time).format('YYYY-MM-DD HH:mm:ss');
  83. if(this.isDef(user.last_login)) user._doc.last_login = Moment(user.last_login).format('YYYY-MM-DD HH:mm:ss');
  84. return user;
  85. }
  86. /**
  87. * 获取列表
  88. *
  89. * @param {object} condition
  90. * @param {number} page
  91. * @param {Number} pageSize
  92. * @return {promise}
  93. */
  94. async getList(condition = null, page = 1, pageSize = 30, sort = {_id:-1}) {
  95. page = parseInt(page);
  96. page = page <= 1 ? 1 : page;
  97. let option = {pageSize: pageSize, offset: parseInt((page - 1) * pageSize), sort: sort};
  98. let userList = await this.db.find(condition, null, option);
  99. userList = userList.length > 0 ? userList : [];
  100. return userList;
  101. }
  102. /**
  103. * 获取过滤条件
  104. *
  105. * @return {Object}
  106. */
  107. getFilterCondition(request) {
  108. let condition = {};
  109. let regtime = request.query.regtime;
  110. regtime = regtime !== '' && regtime !== undefined ? parseInt(regtime) : 0;
  111. if (regtime !== 0) {
  112. condition.create_time = this.getTimestamp(regtime);
  113. }
  114. //最近登录时间
  115. let loginTime = request.query.loginTime;
  116. loginTime = loginTime !== '' && loginTime !== undefined ? parseInt(loginTime) : 0;
  117. if (loginTime !== 0) {
  118. condition.latest_login = this.getTimestamp(loginTime);
  119. }
  120. let version = request.query.version;
  121. if(version !== '' && version !== undefined) {
  122. condition.version = version;
  123. }
  124. // 已升级费用定额
  125. let upGrade = request.query.upGrade;
  126. if(upGrade !== '' && upGrade !== undefined){
  127. condition.upgrade_list = {"$elemMatch":{"compilationID":upGrade,"isUpgrade":true}};
  128. }
  129. // 最近使用费用定额
  130. let latestUsed = request.query.latestUsed;
  131. if(latestUsed !== '' && latestUsed !== undefined){
  132. condition.latest_used = latestUsed;
  133. }
  134. // 最近登录时长
  135. let onlineTimes = request.query.onlineTimes;
  136. onlineTimes = onlineTimes !== '' && onlineTimes !== undefined ? parseInt(onlineTimes) : 0;
  137. if (onlineTimes !== 0) {
  138. condition.online_times = this.getOnlineTimestamp(onlineTimes);
  139. }
  140. // 企业所在地区
  141. let province = request.query.province;
  142. province = province !== '' && province !== undefined ? parseInt(province) - 1 : -1;
  143. if (province !== -1) {
  144. condition.province = province;
  145. }
  146. let keyword = request.query.keyword;
  147. if (keyword !== '' && keyword !== undefined) {
  148. condition.$or = [{real_name : {$regex: keyword}},{email : {$regex: keyword}},{mobile : {$regex: keyword}},{qq : {$regex: keyword}},{company : {$regex: keyword}}];
  149. }
  150. return condition;
  151. }
  152. /**
  153. * 获取时间戳区间
  154. *
  155. * @return {Object}
  156. */
  157. getTimestamp(type) {
  158. let startTime = '';
  159. switch (type) {
  160. case 1 :
  161. startTime = Date.parse(new Date())-86400*1000;
  162. break;
  163. case 2 :
  164. startTime = Date.parse(new Date())-86400*1000*3;
  165. break;
  166. case 3 :
  167. startTime = Date.parse(new Date())-86400*1000*7;
  168. break;
  169. case 4 :
  170. startTime = Date.parse(new Date())-86400*1000*30;
  171. break;
  172. default :
  173. break;
  174. }
  175. let endTime = Date.parse(new Date());
  176. return startTime === '' ? '' : {'$gte': startTime, '$lt': endTime};
  177. }
  178. /**
  179. * 获取时间戳区间
  180. *
  181. * @return {Object}
  182. */
  183. getOnlineTimestamp(type) {
  184. let startTime = 0;
  185. switch (type) {
  186. case 1 :
  187. startTime = 1800*1000;
  188. break;
  189. case 2 :
  190. startTime = 3600*1000;
  191. break;
  192. case 3 :
  193. startTime = 3600*1000*2;
  194. break;
  195. case 4 :
  196. startTime = 3600*1000*3;
  197. break;
  198. default :
  199. break;
  200. }
  201. return startTime === 0 ? '' : {'$gte': startTime};
  202. }
  203. /**
  204. * 获取daymsg
  205. *
  206. */
  207. getDayMsg(index){
  208. return this.dayMsg[index];
  209. }
  210. async deleteUser(userID,managerID){
  211. //把用户的项目,单价文件,费率文件标记为真删除状态,然后统一调用清除项目数据的方法
  212. let deleteInfo = {
  213. deleted:true,
  214. deleteDateTime : new Date(),
  215. deleteBy:managerID,
  216. completeDeleted:true
  217. };
  218. //标记删除
  219. await unitPriceFileModel.updateMany({"user_id":userID},{"deleteInfo":deleteInfo});
  220. await feeRateFileModel.updateMany({"userID":userID},{"deleteInfo":deleteInfo});
  221. await projectModel.updateMany({"userID":userID},{"deleteInfo":deleteInfo});
  222. //删除项目相关数据
  223. await sysSchedule.clearJunkData();
  224. //删除用户私有数据
  225. await optionsModel.deleteMany({"user_id":userID});
  226. await settingModel.deleteMany({"user_id":userID});
  227. await messageModel.deleteMany({"user_id":userID});
  228. await logModel.deleteMany({"user_id":userID});
  229. await rptCfgModel.deleteMany({"userId":userID});
  230. await rptCusCfgModel.deleteMany({"userId":userID});
  231. await comRationSecTreeModel.deleteMany({"userId":userID});
  232. await comGLJLibMode.deleteMany({"userId":userID});
  233. await rptTplTreeMode.deleteMany({"userId":userID});
  234. await comGLJSectionModel.deleteMany({"userId":userID});
  235. await comRationItemsModel.deleteMany({"userId":userID});
  236. await comRationCoeModel.deleteMany({"userId":userID});
  237. await comRationInstalModel.deleteMany({"userId":userID});
  238. await comRationInstalSectionModel.deleteMany({"userId":userID});
  239. await blockLibModel.deleteMany({"userID":userID});
  240. //最后删除用户信息:
  241. await this.db.model.deleteOne({_id:mongoose.Types.ObjectId(userID)});
  242. return "success";
  243. }
  244. async updateAllStaff(userList) {
  245. for (const user of userList) {
  246. const users = await this.findDataByCondition({ mobile: user.telephone });
  247. if(users && users.is_cld === 0) {
  248. await this.db.model.updateMany({"_id":users._id},{"is_cld":Date.parse(new Date())/1000});
  249. }
  250. }
  251. return "success";
  252. }
  253. /**
  254. * 根据用户名查找数据
  255. *
  256. * @param {string} username
  257. * @return {object}
  258. */
  259. async findDataByName(username) {
  260. return await this.db.findOne({username: username});
  261. }
  262. /**
  263. * 根据ssoID查找数据
  264. *
  265. * @param {string} ssoId
  266. * @return {object}
  267. */
  268. async findDataBySsoId(ssoId) {
  269. return await this.db.findOne({ssoId: ssoId});
  270. }
  271. /**
  272. * 根据手机号查找数据
  273. *
  274. * @param {string} mobile
  275. * @return {object}
  276. */
  277. async findDataByMobile(mobile) {
  278. return await this.db.findOne({mobile: mobile});
  279. }
  280. /**
  281. * 根据userId查找数据
  282. *
  283. * @param {string} ssoId
  284. * @return {object}
  285. */
  286. async findDataById(id, fields) {
  287. const objId = mongoose.Types.ObjectId(id);
  288. return fields ? await this.db.findOne({_id: objId}, fields) : await this.db.findOne({_id: objId});
  289. }
  290. }
  291. export default UserModel;