浏览代码

培训问诊用户,整理格式

lrf 3 年之前
父节点
当前提交
6525750939

+ 41 - 0
app/controller/consultation/config/.trainUser.js

@@ -0,0 +1,41 @@
+module.exports = {
+  create: {
+    requestBody: ['!train_id', '!name', '!phone', '!password', 'status', 'remark'],
+  },
+  destroy: {
+    params: ['!id'],
+    service: 'delete',
+  },
+  update: {
+    params: ['!id'],
+    requestBody: ['train_id', 'name', 'phone', 'password', 'status', 'remark'],
+  },
+  show: {
+    parameters: {
+      params: ['!id'],
+    },
+    service: 'fetch',
+  },
+  index: {
+    parameters: {
+      query: {
+        'meta.createdAt@start': 'meta.createdAt@start',
+        'meta.createdAt@end': 'meta.createdAt@end',
+        train_id: 'train_id',
+        name: 'name',
+        phone: 'phone',
+        status: 'status',
+      },
+    },
+    service: 'query',
+    options: {
+      query: ['skip', 'limit'],
+      sort: ['meta.createdAt'],
+      desc: true,
+      count: true,
+    },
+  },
+  login: {
+    requestBody: ['!phone', '!password', '!train_id'],
+  },
+};

+ 13 - 0
app/controller/consultation/trainUser.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.trainUser.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 培训问诊-用户
+class TrainUserController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.consultation.trainUser;
+  }
+}
+module.exports = CrudController(TrainUserController, meta);

+ 12 - 12
app/model/channel/channel.js

@@ -1,9 +1,9 @@
-"use strict";
-const Schema = require("mongoose").Schema;
-const moment = require("moment");
-const metaPlugin = require("naf-framework-mongoose-free/lib/model/meta-plugin");
-const { Secret } = require("naf-framework-mongoose-free/lib/model/schema");
-const { ObjectId } = require("mongoose").Types;
+'use strict';
+const Schema = require('mongoose').Schema;
+const moment = require('moment');
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+const { Secret } = require('naf-framework-mongoose-free/lib/model/schema');
+const { ObjectId } = require('mongoose').Types;
 // 科技频道表
 const channel = {
   room_id: { type: String }, // 房间id,服务生成,从2001开始
@@ -12,9 +12,9 @@ const channel = {
   origin: { type: String }, // 来源
   type: { type: String }, // 类别
   brief: { type: String }, // 简介
-  create_time: { type: String }, //更新时间
-  status: { type: String, default: "0" }, // 0-准备中;1-开始;-1-结束
-  role: { type: String, required: false, default: "7" }, // 角色
+  create_time: { type: String }, // 更新时间
+  status: { type: String, default: '0' }, // 0-准备中;1-开始;-1-结束
+  role: { type: String, required: false, default: '7' }, // 角色
   remark: { type: String },
 };
 const schema = new Schema(channel, { toJSON: { virtuals: true } });
@@ -22,9 +22,9 @@ schema.index({ id: 1 });
 schema.index({ room_id: 1 });
 schema.index({ title: 1 });
 schema.index({ type: 1 });
-schema.index({ "meta.createdAt": 1 });
+schema.index({ 'meta.createdAt': 1 });
 schema.plugin(metaPlugin);
-module.exports = (app) => {
+module.exports = app => {
   const { mongoose } = app;
-  return mongoose.model("Channel", schema, "channel");
+  return mongoose.model('Channel', schema, 'channel');
 };

+ 9 - 9
app/model/channel/channelVideo.js

@@ -1,9 +1,9 @@
-"use strict";
-const Schema = require("mongoose").Schema;
-const moment = require("moment");
-const metaPlugin = require("naf-framework-mongoose-free/lib/model/meta-plugin");
-const { Secret } = require("naf-framework-mongoose-free/lib/model/schema");
-const { ObjectId } = require("mongoose").Types;
+'use strict';
+const Schema = require('mongoose').Schema;
+const moment = require('moment');
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+const { Secret } = require('naf-framework-mongoose-free/lib/model/schema');
+const { ObjectId } = require('mongoose').Types;
 // 科技频道-视频表
 const channel_video = {
   channel_id: { type: String }, // 关联的channel的id
@@ -18,9 +18,9 @@ const schema = new Schema(channel_video, { toJSON: { virtuals: true } });
 schema.index({ id: 1 });
 schema.index({ channel_id: 1 });
 schema.index({ title: 1 });
-schema.index({ "meta.createdAt": 1 });
+schema.index({ 'meta.createdAt': 1 });
 schema.plugin(metaPlugin);
-module.exports = (app) => {
+module.exports = app => {
   const { mongoose } = app;
-  return mongoose.model("ChannelVideo", schema, "channelVideo");
+  return mongoose.model('ChannelVideo', schema, 'channelVideo');
 };

+ 25 - 0
app/model/consultation/trainUser.js

@@ -0,0 +1,25 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const moment = require('moment');
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+const { Secret } = require('naf-framework-mongoose-free/lib/model/schema');
+const { ObjectId } = require('mongoose').Types;
+// 培训问诊--用户表
+const trainUser = {
+  train_id: { type: String, zh: '培训问诊id' },
+  name: { type: String, zh: '姓名' },
+  phone: { type: String, zh: '电话' },
+  password: { type: Secret, select: false }, // 注册密码
+  status: { type: String, zh: '状态', default: '0' }, // 0-待审;1-审核通过;2-审核拒绝
+  remark: { type: String },
+};
+const schema = new Schema(trainUser, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ phone: 1 });
+schema.index({ name: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.plugin(metaPlugin);
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('TrainUser', schema, 'trainUser');
+};

+ 60 - 50
app/router.js

@@ -16,7 +16,7 @@ function getIPAdress() {
     }
   }
 }
-module.exports = (app) => {
+module.exports = app => {
   const { router, controller } = app;
   const { routePrefix, cluster } = app.config;
   const ipAddress = getIPAdress();
@@ -24,69 +24,79 @@ module.exports = (app) => {
   router.get(`${routePrefix}`, controller.home.index);
   router.get(`${routePrefix}/util/getConfig`, controller.util.getConfig);
   // user
-  require("./z_router/user/admin")(app); // 管理员
-  require("./z_router/user/expert")(app); // 专家
-  require("./z_router/user/inviteCode")(app); // 邀请码
-  require("./z_router/user/mechanism")(app); // 机构
-  require("./z_router/user/organization")(app); // 机构(o)
-  require("./z_router/user/personal")(app); // 个人账号
-  require("./z_router/user/personChat")(app); // 聊天消息
-  require("./z_router/user/personRoom")(app); // 聊天室
+  console.log('user');
+  require('./z_router/user/admin')(app); // 管理员
+  require('./z_router/user/expert')(app); // 专家
+  require('./z_router/user/inviteCode')(app); // 邀请码
+  require('./z_router/user/mechanism')(app); // 机构
+  require('./z_router/user/organization')(app); // 机构(o)
+  require('./z_router/user/personal')(app); // 个人账号
+  require('./z_router/user/personChat')(app); // 聊天消息
+  require('./z_router/user/personRoom')(app); // 聊天室
 
   // channel
-  require("./z_router/channel/channel")(app); // 科技频道
-  require("./z_router/channel/channelVideo")(app); // 科技频道视频
+  console.log('channel');
+  require('./z_router/channel/channel')(app); // 科技频道
+  require('./z_router/channel/channelVideo')(app); // 科技频道视频
 
-  // consultation\
-  require("./z_router/consultation/trainLive")(app); // 培训问诊
-  require("./z_router/consultation/trainChat")(app); // 培训问诊聊天
-  require("./z_router/consultation/trainVideo")(app); // 培训问诊视频表
+  // consultation
+  console.log('consultation');
+  require('./z_router/consultation/trainLive')(app); // 培训问诊
+  require('./z_router/consultation/trainChat')(app); // 培训问诊聊天
+  require('./z_router/consultation/trainVideo')(app); // 培训问诊视频表
+  require('./z_router/consultation/trainUser')(app); // 培训问诊用户
 
   // cysci
-  require("./z_router/cysci/cashing")(app); // 高企申报兑换
-  require("./z_router/cysci/coupons")(app); // 创新券
-  require("./z_router/cysci/couponsApply")(app); // 创新券申领
-  require("./z_router/cysci/declare")(app); // 高企申报
-  require("./z_router/cysci/reward")(app); // 研发补贴,奖励兑换申领
+  console.log('cysci');
+  require('./z_router/cysci/cashing')(app); // 高企申报兑换
+  require('./z_router/cysci/coupons')(app); // 创新券
+  require('./z_router/cysci/couponsApply')(app); // 创新券申领
+  require('./z_router/cysci/declare')(app); // 高企申报
+  require('./z_router/cysci/reward')(app); // 研发补贴,奖励兑换申领
 
   // dock
-  require("./z_router/dock/dock")(app); // 展会
-  require("./z_router/dock/dockChat")(app); // 展会公共聊天
-  require("./z_router/dock/dockImgtxt")(app); // 展会图文
-  require("./z_router/dock/dockTranscation")(app); // 展会合同备份
-  require("./z_router/dock/dockUser")(app); // 展会用户
-  require("./z_router/dock/dockVideo")(app); // 展会视频
+  console.log('dock');
+  require('./z_router/dock/dock')(app); // 展会
+  require('./z_router/dock/dockChat')(app); // 展会公共聊天
+  require('./z_router/dock/dockImgtxt')(app); // 展会图文
+  require('./z_router/dock/dockTranscation')(app); // 展会合同备份
+  require('./z_router/dock/dockUser')(app); // 展会用户
+  require('./z_router/dock/dockVideo')(app); // 展会视频
 
   // kjzl
-  require("./z_router/kjzl/kjzlChat")(app); // 科教之旅-评价表
-  require("./z_router/kjzl/kjzlExpertView")(app); // 科教之旅-专家视点
-  require("./z_router/kjzl/kjzlMedium")(app); // 科教之旅-机构
-  require("./z_router/kjzl/kjzlMiniVideo")(app); // 科教微视频
-  require("./z_router/kjzl/kjzlOrder")(app); // 科教之旅-订单
-  require("./z_router/kjzl/kjzlRefute")(app); // 科教之旅-辟谣
+  console.log('kjzl');
+  require('./z_router/kjzl/kjzlChat')(app); // 科教之旅-评价表
+  require('./z_router/kjzl/kjzlExpertView')(app); // 科教之旅-专家视点
+  require('./z_router/kjzl/kjzlMedium')(app); // 科教之旅-机构
+  require('./z_router/kjzl/kjzlMiniVideo')(app); // 科教微视频
+  require('./z_router/kjzl/kjzlOrder')(app); // 科教之旅-订单
+  require('./z_router/kjzl/kjzlRefute')(app); // 科教之旅-辟谣
 
   // news
-  require("./z_router/news/column")(app); // 栏目
-  require("./z_router/news/interview")(app); // 嘉宾访谈
-  require("./z_router/news/news")(app); // 信息
-  require("./z_router/news/notice")(app); // 通知管理
-  require("./z_router/news/product")(app); // 产品
-  require("./z_router/news/projectSolic")(app); // 项目征集
-  require("./z_router/news/question")(app); // 调研考察
-  require("./z_router/news/roadShow")(app); // 项目路演
-  require("./z_router/news/science")(app); // 科技新闻
-  require("./z_router/news/survey")(app); // 建言献策,网上调查
-  require("./z_router/news/universal")(app); // 科学普及
-  require("./z_router/news/viewPoint")(app); // 智库视点
+  console.log('news');
+  require('./z_router/news/column')(app); // 栏目
+  require('./z_router/news/interview')(app); // 嘉宾访谈
+  require('./z_router/news/news')(app); // 信息
+  require('./z_router/news/notice')(app); // 通知管理
+  require('./z_router/news/product')(app); // 产品
+  require('./z_router/news/projectSolic')(app); // 项目征集
+  require('./z_router/news/question')(app); // 调研考察
+  require('./z_router/news/roadShow')(app); // 项目路演
+  require('./z_router/news/science')(app); // 科技新闻
+  require('./z_router/news/survey')(app); // 建言献策,网上调查
+  require('./z_router/news/universal')(app); // 科学普及
+  require('./z_router/news/viewPoint')(app); // 智库视点
 
   // system
-  require("./z_router/system/category")(app); // 字典分类
-  require("./z_router/system/code")(app); // 字典
-  require("./z_router/system/menu")(app); // 菜单
-  require("./z_router/system/role")(app); // 角色
+  console.log('system');
+  require('./z_router/system/category')(app); // 字典分类
+  require('./z_router/system/code')(app); // 字典
+  require('./z_router/system/menu')(app); // 菜单
+  require('./z_router/system/role')(app); // 角色
 
   // statistics
-  require("./z_router/statistics/index")(app); // 统计
+  console.log('statistics');
+  require('./z_router/statistics/index')(app); // 统计
 
   // patent
-};;;
+};

+ 35 - 0
app/service/consultation/trainUser.js

@@ -0,0 +1,35 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+const jwt = require('jsonwebtoken');
+
+// 培训问诊用户
+class TrainUserService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'trainuser');
+    this.model = this.ctx.model.Consultation.TrainUser;
+  }
+  /**
+   * 登陆
+   * @param {Object} params 登陆信息
+   * @property phone 电话
+   * @property password 密码
+   * @property train_id 培训问诊id
+   */
+  async login({ phone, password, train_id }) {
+    const object = await this.model.findOne({ train_id, phone }, '+password');
+    if (!object) throw new BusinessError(ErrorCode.DATA_NOT_EXIST, '未找到用户的信息');
+    const { password: op, status } = object;
+    const { secret } = op;
+    if (status !== '1') throw new BusinessError(ErrorCode.ACCESS_DENIED, '拒绝访问!');
+    if (secret !== password) throw new BusinessError(ErrorCode.BAD_PASSWORD, '密码错误');
+    const data = _.omit(JSON.parse(JSON.stringify(object)), [ 'meta', 'password', '__v' ]);
+    const { secret: secrets } = this.config.jwt;
+    const token = jwt.sign(data, secrets);
+    return token;
+  }
+}
+
+module.exports = TrainUserService;

+ 30 - 0
app/z_router/consultation/trainUser.js

@@ -0,0 +1,30 @@
+'use strict';
+// 路由配置
+const rkey = 'trainUser';
+const ckey = 'consultation.trainUser';
+const keyZh = '培训问诊-用户';
+const routes = [
+  { method: 'post', path: `${rkey}/login`, controller: `${ckey}.login`, name: `${ckey}login`, zh: `${keyZh}登陆` },
+  { method: 'get', path: `${rkey}`, controller: `${ckey}.index`, name: `${ckey}Query`, zh: `${keyZh}列表查询` },
+  { method: 'get', path: `${rkey}/:id`, controller: `${ckey}.show`, name: `${ckey}Show`, zh: `${keyZh}查询` },
+  { method: 'post', path: `${rkey}`, controller: `${ckey}.create`, middleware: [ 'password' ], name: `${ckey}Create`, zh: `创建${keyZh}` },
+  { method: 'post', path: `${rkey}/:id`, controller: `${ckey}.update`, name: `${ckey}Update`, zh: `修改${keyZh}` },
+  { method: 'delete', path: `${rkey}/:id`, controller: `${ckey}.destroy`, name: `${ckey}Delete`, zh: `删除${keyZh}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  console.log(`${keyZh}:  ${rkey}`);
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}/${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]({ enable: true }));
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};