123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- 'use strict';
- /**
- *
- *
- * @author Mai
- * @date
- * @version
- */
- module.exports = app => {
- class SpecPull extends app.BaseService {
- /**
- * 构造函数
- *
- * @param {Object} ctx - egg全局变量
- * @return {void}
- */
- constructor(ctx) {
- super(ctx);
- this.tableName = 's2b_spec_msg';
- }
- async tenderNeedMsg(pid, tid, timing) {
- const specProj = await this.db.get('zh_s2b_spec_proj', { id: pid });
- if (!specProj || !specProj.is_push) return false;
- switch (specProj.push_tender_type) {
- case 1:
- const filter = specProj.filter_tender ? specProj.filter_tender.split(',') : [];
- if (filter.indexOf(tid + '') >= 0) return false;
- break;
- case 2:
- const access = specProj.access_tender ? specProj.access_tender.split(',') : [];
- if (access.indexOf(tid + '') < 0) return false;
- break;
- }
- const soleTender = await this.db.get('zh_s2b_spec_tender', { id: tid, is_valid: 1 });
- const specPush = await this.db.get('zh_s2b_spec_push', { pid, tid: soleTender ? tid : 0, valid: 1, push_timing: timing });
- return !!specPush;
- }
- async addLedgerMsg(transaction, pid, tender, timing) {
- const needMsg = await this.tenderNeedMsg(pid, tender.id, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: tender.id, timing });
- }
- async addReviseMsg(transaction, pid, revise, timing) {
- const needMsg = await this.tenderNeedMsg(pid, revise.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: revise.tid, rid: revise.id, timing });
- }
- async addStageMsg(transaction, pid, stage, timing) {
- const needMsg = await this.tenderNeedMsg(pid, stage.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: stage.tid, sid: stage.id, timing });
- }
- async addAdvanceMsg(transaction, pid, advance, timing) {
- const needMsg = await this.tenderNeedMsg(pid, advance.id, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: advance.tid, advance_id: advance.id, timing });
- }
- async addMaterialMsg(transaction, pid, material, timing) {
- const needMsg = await this.tenderNeedMsg(pid, material.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: material.tid, material_id: material.id, timing });
- }
- async addSettleMsg(transaction, pid, settle, timing) {
- const needMsg = await this.tenderNeedMsg(pid, settle.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: settle.tid, settle_id: settle.id, timing });
- }
- async addChangeMsg(transaction, pid, change, timing) {
- const needMsg = await this.tenderNeedMsg(pid, change.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: change.tid, cid: change.cid, timing });
- }
- async addChangeApplyMsg(transaction, pid, change_apply, timing) {
- const needMsg = await this.tenderNeedMsg(pid, change_apply.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: change_apply.tid, c_apply_id: change_apply.id, timing });
- }
- async addChangeProjectMsg(transaction, pid, change_project, timing) {
- const needMsg = await this.tenderNeedMsg(pid, change_project.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: change_project.tid, c_proj_id: change_project.id, timing });
- }
- async addChangePlanMsg(transaction, pid, change_plan, timing) {
- const needMsg = await this.tenderNeedMsg(pid, change_plan.tid, timing);
- if (!needMsg) return;
- await transaction.insert(this.tableName, { pid, tid: change_plan.tid, c_plan_id: change_plan.id, timing });
- }
- async addReportMsg(transaction, pid, tender, stage, timing, subInfo) {
- const needMsg = await this.tenderNeedMsg(pid, stage.tid, timing);
- if (!needMsg) return;
- if (transaction) {
- await transaction.insert(this.tableName, { pid, tid: tender.id, sid: stage ? stage.id : 0, timing, extra_info: JSON.stringify(subInfo || {}) });
- } else {
- await this.db.insert(this.tableName, { pid, tid: tender.id, sid: stage ? stage.id : 0, timing, extra_info: JSON.stringify(subInfo || {}) });
- }
- }
- }
- return SpecPull;
- };
|