| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347 | 
							- /**
 
-  * 前台用户相关数据模型
 
-  *
 
-  * @author CaiAoLin
 
-  * @date 2017/6/12
 
-  * @version
 
-  */
 
- import mongoose from "mongoose";
 
- import Moment from "moment";
 
- import BaseModel from "../../common/base/base_model";
 
- const projectModel = mongoose.model('projects');
 
- const unitPriceFileModel = mongoose.model('unit_price_file');
 
- const feeRateFileModel = mongoose.model('fee_rate_file');
 
- const optionsModel = mongoose.model('options');
 
- const settingModel = mongoose.model('setting');
 
- const messageModel = mongoose.model('user_message');
 
- const logModel = mongoose.model('log');
 
- const rptCfgModel =  mongoose.model("rpt_cfg");
 
- const rptCusCfgModel = mongoose.model("rpt_customize_cfg");
 
- const comRationSecTreeModel  = mongoose.model('complementary_ration_section_tree');
 
- const blockLibModel =  mongoose.model('blockLibsModel');
 
- const comGLJLibMode =  mongoose.model('complementary_glj_lib');
 
- const comGLJSectionModel = mongoose.model('complementary_glj_section');
 
- const comRationItemsModel = mongoose.model('complementary_ration_items');
 
- const comRationCoeModel = mongoose.model('complementary_ration_coe_list');
 
- const comRationInstalModel = mongoose.model('complementary_ration_installation');
 
- const comRationInstalSectionModel = mongoose.model('complementary_ration_installationSection');
 
- const rptTplTreeMode =  mongoose.model("rpt_tpl_tree");
 
- let sysSchedule = require('../../sys_tools/models/sys_model');
 
- class UserModel extends BaseModel {
 
-     /**
 
-      * 企业所在地区
 
-      *
 
-      * @var {object}
 
-      */
 
-     province = ['北京', '天津', '河北', '山西', '内蒙古', '辽宁', '吉林', '黑龙江', '上海', '江苏', '浙江', '安徽',
 
-         '福建', '江西', '山东', '河南', '湖北', '湖南', '广东', '广西', '海南', '重庆', '四川', '贵州', '云南', '西藏',
 
-         '陕西', '甘肃', '青海', '宁夏', '新疆', '台湾', '香港', '澳门',];
 
-     /**
 
-      * 企业类型
 
-      *
 
-      * @var
 
-      */
 
-     companyType = ['建设单位', '设计单位',  '施工单位', '监理单位', '审核单位', '咨询公司', '招标代理', '住建部', '财政', '审计',
 
-         '造价管理站', '学校', '个人', '其他'];
 
-     /**
 
-      * 企业规模
 
-      *
 
-      * @var
 
-      */
 
-     companyScale = ['1-50', '50-100', '100-500', '500+'];
 
-     /**
 
-      * 最近天数
 
-      *
 
-      * @var
 
-      */
 
-     dayMsg = ['所有', '最近24小时', '最近3天', '最近7天', '最近30天'];
 
-     /**
 
-      * 构造函数
 
-      *
 
-      * @return {void}
 
-      */
 
-     constructor() {
 
-         let parent = super();
 
-         parent.model = mongoose.model('users');
 
-         parent.init();
 
-     }
 
-     /**
 
-      * 获取用户信息
 
-      *
 
-      * @param {object} condition
 
-      * @param {number} page
 
-      * @param {Number} pageSize
 
-      * @return {promise}
 
-      */
 
-     async getByID(condition) {
 
-         let user = await this.db.findOne(condition);
 
-         //企业所在省份、类型、规模等转换
 
-         if(this.isDef(user.province)) user._doc.province = this.province[user.province];
 
-         if(this.isDef(user.company_type)) user._doc.company_type = this.companyType[user.company_type];
 
-         if(this.isDef(user.company_scale)) user._doc.company_scale = this.companyScale[user.company_scale];
 
-         if(this.isDef(user.create_time)) user._doc.create_time = Moment(user.create_time).format('YYYY-MM-DD HH:mm:ss');
 
-         if(this.isDef(user.last_login)) user._doc.last_login = Moment(user.last_login).format('YYYY-MM-DD HH:mm:ss');
 
-         return user;
 
-     }
 
-     /**
 
-      * 获取列表
 
-      *
 
-      * @param {object} condition
 
-      * @param {number} page
 
-      * @param {Number} pageSize
 
-      * @return {promise}
 
-      */
 
-     async getList(condition = null, page = 1, pageSize = 30, sort = {_id:-1}) {
 
-         page = parseInt(page);
 
-         page = page <= 1 ? 1 : page;
 
-         let option = {pageSize: pageSize, offset: parseInt((page - 1) * pageSize), sort: sort};
 
-         let userList = await this.db.find(condition, null, option);
 
-         userList = userList.length > 0 ? userList : [];
 
-         return userList;
 
-     }
 
-     /**
 
-      * 获取过滤条件
 
-      *
 
-      * @return {Object}
 
-      */
 
-     getFilterCondition(request) {
 
-         let condition = {};
 
-         let regtime = request.query.regtime;
 
-         regtime = regtime !== '' && regtime !== undefined ? parseInt(regtime) : 0;
 
-         if (regtime !== 0) {
 
-             condition.create_time = this.getTimestamp(regtime);
 
-         }
 
-         //最近登录时间
 
-         let loginTime = request.query.loginTime;
 
-         loginTime = loginTime !== '' && loginTime !== undefined ? parseInt(loginTime) : 0;
 
-         if (loginTime !== 0) {
 
-             condition.latest_login = this.getTimestamp(loginTime);
 
-         }
 
-         let version = request.query.version;
 
-         if(version !== '' && version !== undefined) {
 
-             condition.version = version;
 
-         }
 
-         // 已升级费用定额
 
-         let upGrade = request.query.upGrade;
 
-         if(upGrade !== '' && upGrade !== undefined){
 
-             condition.upgrade_list = {"$elemMatch":{"compilationID":upGrade,"isUpgrade":true}};
 
-         }
 
-         // 最近使用费用定额
 
-         let latestUsed = request.query.latestUsed;
 
-         if(latestUsed !== '' && latestUsed !== undefined){
 
-             condition.latest_used = latestUsed;
 
-         }
 
-         // 最近登录时长
 
-         let onlineTimes = request.query.onlineTimes;
 
-         onlineTimes = onlineTimes !== '' && onlineTimes !== undefined ? parseInt(onlineTimes) : 0;
 
-         if (onlineTimes !== 0) {
 
-             condition.online_times = this.getOnlineTimestamp(onlineTimes);
 
-         }
 
-         // 企业所在地区
 
-         let province = request.query.province;
 
-         province = province !== '' && province !== undefined ? parseInt(province) - 1 : -1;
 
-         if (province !== -1) {
 
-             condition.province = province;
 
-         }
 
-         let keyword = request.query.keyword;
 
-         if (keyword !== '' && keyword !== undefined) {
 
-             condition.$or = [{real_name : {$regex: keyword}},{email : {$regex: keyword}},{mobile : {$regex: keyword}},{qq : {$regex: keyword}},{company : {$regex: keyword}}];
 
-         }
 
-         //获取ssoId列表
 
-         let ssoIds = request.query.ssoIds;
 
-         if (keyword !== '' && keyword !== undefined && ssoIds !== '' && ssoIds !== undefined) {
 
-             condition.$or.push({ssoId: JSON.parse(ssoIds)});
 
-         } else if (ssoIds !== '' && ssoIds !== undefined) {
 
-             condition.ssoId = JSON.parse(ssoIds);
 
-         }
 
-         return condition;
 
-     }
 
-     /**
 
-      * 获取时间戳区间
 
-      *
 
-      * @return {Object}
 
-      */
 
-     getTimestamp(type) {
 
-         let startTime = '';
 
-         switch (type) {
 
-             case 1 :
 
-                 startTime = Date.parse(new Date())-86400*1000;
 
-                 break;
 
-             case 2 :
 
-                 startTime = Date.parse(new Date())-86400*1000*3;
 
-                 break;
 
-             case 3 :
 
-                 startTime = Date.parse(new Date())-86400*1000*7;
 
-                 break;
 
-             case 4 :
 
-                 startTime = Date.parse(new Date())-86400*1000*30;
 
-                 break;
 
-             default :
 
-                 break;
 
-         }
 
-         let endTime =  Date.parse(new Date());
 
-         return startTime === '' ? '' : {'$gte': startTime, '$lt': endTime};
 
-     }
 
-     /**
 
-      * 获取时间戳区间
 
-      *
 
-      * @return {Object}
 
-      */
 
-     getOnlineTimestamp(type) {
 
-         let startTime = 0;
 
-         switch (type) {
 
-             case 1 :
 
-                 startTime = 1800*1000;
 
-                 break;
 
-             case 2 :
 
-                 startTime = 3600*1000;
 
-                 break;
 
-             case 3 :
 
-                 startTime = 3600*1000*2;
 
-                 break;
 
-             case 4 :
 
-                 startTime = 3600*1000*3;
 
-                 break;
 
-             default :
 
-                 break;
 
-         }
 
-         return startTime === 0 ? '' : {'$gte': startTime};
 
-     }
 
-     /**
 
-      * 获取daymsg
 
-      *
 
-      */
 
-     getDayMsg(index){
 
-         return this.dayMsg[index];
 
-     }
 
-     async deleteUser(userID,managerID){
 
-         //把用户的项目,单价文件,费率文件标记为真删除状态,然后统一调用清除项目数据的方法
 
-         let deleteInfo = {
 
-             deleted:true,
 
-             deleteDateTime : new Date(),
 
-             deleteBy:managerID,
 
-             completeDeleted:true
 
-         };
 
-         //标记删除
 
-         await unitPriceFileModel.updateMany({"user_id":userID},{"deleteInfo":deleteInfo});
 
-         await feeRateFileModel.updateMany({"userID":userID},{"deleteInfo":deleteInfo});
 
-         await projectModel.updateMany({"userID":userID},{"deleteInfo":deleteInfo});
 
-         //删除项目相关数据
 
-         await sysSchedule.clearJunkData();
 
-         //删除用户私有数据
 
-         await optionsModel.deleteMany({"user_id":userID});
 
-         await settingModel.deleteMany({"user_id":userID});
 
-         await messageModel.deleteMany({"user_id":userID});
 
-         await logModel.deleteMany({"user_id":userID});
 
-         await rptCfgModel.deleteMany({"userId":userID});
 
-         await rptCusCfgModel.deleteMany({"userId":userID});
 
-         await comRationSecTreeModel.deleteMany({"userId":userID});
 
-         await comGLJLibMode.deleteMany({"userId":userID});
 
-         await rptTplTreeMode.deleteMany({"userId":userID});
 
-         await comGLJSectionModel.deleteMany({"userId":userID});
 
-         await comRationItemsModel.deleteMany({"userId":userID});
 
-         await comRationCoeModel.deleteMany({"userId":userID});
 
-         await comRationInstalModel.deleteMany({"userId":userID});
 
-         await comRationInstalSectionModel.deleteMany({"userId":userID});
 
-         await blockLibModel.deleteMany({"userID":userID});
 
-         //最后删除用户信息:
 
-         await this.db.model.deleteOne({_id:mongoose.Types.ObjectId(userID)});
 
-         return "success";
 
-     }
 
-     async updateAllStaff(userList) {
 
-         for (const user of userList) {
 
-             const users = await this.findDataByCondition({ mobile: user.telephone });
 
-             if(users && users.is_cld === 0) {
 
-                 await this.db.model.updateMany({"_id":users._id},{"is_cld":Date.parse(new Date())/1000});
 
-             }
 
-         }
 
-         return "success";
 
-     }
 
-     /**
 
-      * 根据用户名查找数据
 
-      *
 
-      * @param {string} username
 
-      * @return {object}
 
-      */
 
-     async findDataByName(username) {
 
-         return await this.db.findOne({username: username});
 
-     }
 
-     /**
 
-      * 根据ssoID查找数据
 
-      *
 
-      * @param {string} ssoId
 
-      * @return {object}
 
-      */
 
-     async findDataBySsoId(ssoId) {
 
-         return await this.db.findOne({ssoId: ssoId});
 
-     }
 
-     /**
 
-      * 根据手机号查找数据
 
-      *
 
-      * @param {string} mobile
 
-      * @return {object}
 
-      */
 
-     async findDataByMobile(mobile) {
 
-         return await this.db.findOne({mobile: mobile});
 
-     }
 
-     /**
 
-      * 根据userId查找数据
 
-      *
 
-      * @param {string} ssoId
 
-      * @return {object}
 
-      */
 
-     async findDataById(id, fields) {
 
-         const objId = mongoose.Types.ObjectId(id);
 
-         return fields ? await this.db.findOne({_id: objId}, fields) : await this.db.findOne({_id: objId});
 
-     }
 
-     /**
 
-      * 更新用户数据
 
-      *
 
-      * @param {object} updateData
 
-      * @return {Promise}
 
-      */
 
-     async updateUser(condition, updateData) {
 
-         if (Object.keys(condition).length <= 0 || Object.keys(updateData).length <= 0) {
 
-             return null;
 
-         }
 
-         return await this.db.update(condition, updateData);
 
-     }
 
- }
 
- export default UserModel;
 
 
  |