fee_rates_facade.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594
  1. /**
  2. * Created by chen on 2017/8/2.
  3. */
  4. let async_n = require("async");
  5. let mongoose = require('mongoose');
  6. let feeRateModel = mongoose.model('fee_rates');
  7. let feeRateFileModel = mongoose.model('fee_rate_file');
  8. let std_fee_rate_lib_model = mongoose.model('std_fee_rate_libs');
  9. let billModel=require('../../main/models/bills');//mongoose.model('bills');
  10. let projectsModel = mongoose.model('projects');
  11. let consts = require('../../main/models/project_consts');
  12. let _=require("lodash");
  13. let template = require('../controllers/feerate_template');
  14. let logger = require("../../../logs/log_helper").logger;
  15. const uuidV1 = require('uuid/v1');
  16. let EngineeringLibModel = require("../../users/models/engineering_lib_model");
  17. const scMathUtil = require('../../../public/scMathUtil').getUtil();
  18. module.exports={
  19. save:save,
  20. getData:getData,
  21. getFeeRateStandardsByProjectID:getFeeRateStandardsByProjectID,
  22. changeFeeRateStandard:changeFeeRateStandard,
  23. checkFeeRateName:checkFeeRateName,
  24. getChangeInfo:getChangeInfo,
  25. changeFeeRateFileFromCurrent:changeFeeRateFileFromCurrent,
  26. changeFeeRateFileFromOthers:changeFeeRateFileFromOthers,
  27. newFeeRateFile:newFeeRateFile,
  28. getFeeRatesByProject:getFeeRatesByProject,
  29. getGCFeeRateFiles: getGCFeeRateFiles ,
  30. setFeeRateToBill:setFeeRateToBill,
  31. updateFeeRate:updateFeeRate,
  32. updateFeeRates:updateFeeRates,
  33. updateRates:update_rates,
  34. feeRateFileSaveAs:feeRateFileSaveAs,
  35. getFeeRateByID:getFeeRateByID,
  36. changeFeeRateFile:changeFeeRateFile
  37. };
  38. let operationMap={
  39. 'ut_create':create_fee_rate,
  40. 'ut_update':update_fee_rate,
  41. 'ut_delete':delete_fee_rate
  42. };
  43. let updateFunctionMap = {
  44. 'normalUpdate':normalUpdate,
  45. 'update_rates':update_rates,
  46. 'updateStatusBySelected':updateStatusBySelected,
  47. 'feeRateFileSaveAs':feeRateFileSaveAs
  48. }
  49. function create_fee_rate() {
  50. }
  51. function update_fee_rate(user_id,datas) {
  52. if(datas.updateFunction){
  53. return updateFunctionMap[datas.updateFunction](user_id,datas);
  54. }else {
  55. return normalUpdate(user_id,datas);
  56. }
  57. }
  58. function updateStatusBySelected(user_id,datas) {
  59. return function(callback){
  60. feeRateModel.bulkWrite(generateUpdateTaks(datas.tasks),function (err,data) {
  61. console.log(data);
  62. commonCallback(callback,data,err);
  63. })
  64. }
  65. }
  66. function feeRateFileSaveAs(user_id,datas) {
  67. return function(callback){
  68. let doc = datas.doc;
  69. let projectID=datas.query.projectID;
  70. let feeRate={
  71. ID:doc.feeRateID,
  72. rates:doc.rates
  73. };
  74. delete doc._id;
  75. delete doc.rates;
  76. creatFeeRateFile(doc,feeRate,projectID).then(function (result) {
  77. commonCallback(callback,result,result.err);
  78. })
  79. }
  80. }
  81. async function creatFeeRateFile(feeRateFile,feeRate,projectID) {//预留projectID
  82. let result={
  83. err:null
  84. }
  85. try {
  86. let feeFile={
  87. id:feeRateFile.ID,
  88. name:feeRateFile.name
  89. }
  90. await projectsModel.findOneAndUpdate({ID:projectID},{'property.feeFile':feeFile});
  91. await feeRateFileModel.create(feeRateFile);
  92. await feeRateModel.create(feeRate);
  93. }catch (err){
  94. console.log(err);
  95. result.err=err;
  96. }
  97. return result;
  98. }
  99. function normalUpdate(user_id,datas) {
  100. return function(callback){
  101. console.log(datas)
  102. callback(null,'');
  103. }
  104. }
  105. function generateUpdateTaks(updateTasks) {
  106. var tasks=[];
  107. for(let u of updateTasks){
  108. let t ={
  109. updateOne:{
  110. filter:u.query,
  111. update: u.doc
  112. }
  113. }
  114. tasks.push(t);
  115. }
  116. return tasks;
  117. }
  118. function update_rates(user_id,datas) {
  119. return function(callback){
  120. feeRateModel.findOne(datas.query,['rates'],function(err, data){
  121. let doc = datas.doc;
  122. if(_.isArray(doc)){
  123. _.forEach(doc,function (item) {
  124. data.rates[item.rateIndex]=item.rate;
  125. })
  126. }else {
  127. data.rates[doc.rateIndex]=doc.rate;
  128. }
  129. data.save(function (err) {
  130. commonCallback(callback,'',err);
  131. });
  132. })
  133. }
  134. }
  135. function delete_fee_rate() {
  136. }
  137. function save (user_id, datas, callback) {
  138. let operations=[];
  139. if(_.isArray(datas)){
  140. for(let i=0;i<datas.length;i++){
  141. operations.push(operationMap[datas[i].updateType](user_id,datas[i]));
  142. }
  143. }else {
  144. operations.push(operationMap[datas.updateType](user_id,datas));
  145. }
  146. async_n.parallel(operations,function (err,results) {
  147. if(err){
  148. callback(err,'');
  149. }else {
  150. if(results.length==1){
  151. callback(null,results[0])
  152. }else {
  153. callback(null,results)
  154. }
  155. }
  156. })
  157. }
  158. function getData(projectID, callback) {
  159. getFeeRateData(projectID).then(function (result) {
  160. if(result.err){
  161. callback(1, '', null);
  162. }else {
  163. //feeRateModel
  164. callback(0, consts.projectConst.FEERATE, result.datas);
  165. }
  166. })
  167. }
  168. async function getFeeRateData(projectID) {
  169. let result={
  170. err:null
  171. }
  172. try {
  173. //
  174. /* let getProjectGLJ = +new Date();
  175. console.log("取项目工料机数据-----"+(getProjectGLJ - getenderData));*/
  176. let project = await projectsModel.findOne({ID:projectID});
  177. if (project&&project.property&&project.property.feeFile){
  178. let feeRateData = await feeRateFileModel.findOne({'ID':project.property.feeFile.id,deleteInfo:null});
  179. if(feeRateData===null){
  180. result.datas=[];
  181. }else {
  182. let feeRate = await feeRateModel.findOne({ID:feeRateData.feeRateID});
  183. feeRateData._doc.rates = feeRate?feeRate.rates:[];
  184. //
  185. feeRateData._doc.usageProjects=await getUsageProjects(feeRateData.ID);
  186. result.datas = feeRateData;
  187. }
  188. }else {
  189. result.datas=[];
  190. }
  191. logger.info("get fee rate data");
  192. }catch (err){
  193. console.log(err);
  194. result.err=err;
  195. }
  196. return result;
  197. }
  198. async function getUsageProjects(feeRateID){
  199. let projects = await projectsModel.find({'property.feeFile.id':feeRateID,'deleteInfo':null});
  200. return projects;
  201. }
  202. function commonCallback(callback,result,err) {
  203. if(err){
  204. callback(err,'');
  205. }else {
  206. callback(null,result);
  207. }
  208. }
  209. async function getFeeRateStandardsByProjectID(projectID) {
  210. logger.info("get feeRate standard, projectID:"+projectID)
  211. let feeRateStandards=[];
  212. let project = await projectsModel.findOne({ID:projectID});
  213. let temFee = await feeRateFileModel.findOne({ID:project.property.feeFile.id});
  214. feeRateStandards.push({ID:temFee.libID,libName:temFee.libName});
  215. /* let engineeringLibModel = new EngineeringLibModel();
  216. let engineeringInfo = project !== null && project.property.engineering_id !== undefined ?
  217. await engineeringLibModel.getEngineering(project.property.engineering_id) : null;
  218. if(engineeringInfo!=null){
  219. let fee_lib = engineeringInfo.fee_lib;
  220. for(let lib of fee_lib){
  221. feeRateStandards.push({ID:lib.id,libName:lib.name});
  222. }
  223. }*/
  224. return feeRateStandards;
  225. }
  226. async function changeFeeRateStandard(jdata){
  227. let data = JSON.parse(jdata);
  228. let template = await std_fee_rate_lib_model.findOne({"ID":data.newLibID});
  229. let newFeeRate = {};
  230. newFeeRate.ID =uuidV1();
  231. newFeeRate.rates=template.rates;
  232. //2019-02-25新需求,养护切换标准后还要设置旧的值到新的费率文件里
  233. let subMap = await getAllSubRatesMap(data.feeRateID);
  234. let [IDMap,childrenMap] = setRatesByMap(newFeeRate,subMap,data.decimal);
  235. sumParentRate(IDMap,childrenMap,data.decimal);
  236. await feeRateModel.create(newFeeRate);
  237. let doc={
  238. libID:data.newLibID,
  239. libName:template.libName,
  240. feeRateID: newFeeRate.ID
  241. };
  242. await feeRateFileModel.findOneAndUpdate({ID:data.feeRateFileID,deleteInfo:null},doc);
  243. await feeRateModel.deleteOne({ID:data.feeRateID});
  244. doc.rates=newFeeRate.rates;
  245. return doc;
  246. }
  247. async function getAllSubRatesMap(feeRateID){
  248. let subMap = {};
  249. let feeRate = await feeRateModel.findOne({ID:feeRateID});
  250. if(feeRate){
  251. let rates = feeRate.rates;
  252. for(let r of rates){
  253. if(r.subFeeRate){
  254. for(let p of r.subFeeRate.recodes){
  255. if(subMap[p.name]) continue;
  256. subMap[p.name] = p;
  257. }
  258. }
  259. }
  260. }
  261. return subMap;
  262. }
  263. function sumParentRate(IDMap,childrenMap,decimal){
  264. for(let ParentID in childrenMap){
  265. if(IDMap[ParentID] && IDMap[ParentID].sum !== true) continue;
  266. let childrenList = childrenMap[ParentID];
  267. let total = 0;
  268. for(let c of childrenList){
  269. let tem = c.rate?c.rate:0;
  270. tem = scMathUtil.roundForObj(tem,decimal);
  271. total = scMathUtil.roundForObj(tem + total,6);
  272. }
  273. total = scMathUtil.roundForObj(total,decimal);
  274. if(IDMap[ParentID])IDMap[ParentID].rate = total;
  275. }
  276. }
  277. function setRatesByMap(newFeeRate,subMap,decimal){
  278. let IDMap ={},childrenMap={};
  279. for(let r of newFeeRate.rates){
  280. IDMap[r.ID] = r;
  281. if(r.subFeeRate){
  282. for(let p of r.subFeeRate.recodes){
  283. let t_p = subMap[p.name];
  284. if(t_p){//找到同名的子项
  285. //获取选中的节点
  286. let selected = _.find(t_p.optionList,{"selected":true});
  287. for(let s of p.optionList){
  288. s.selected = selected && selected.name == s.name?true:false;//设置新费率的选中项
  289. }
  290. if(selected){//如果有选中项,则从valueMap中找出值并设置到rate上// ;
  291. let map = _.find(r.subFeeRate.valueMaps,{ID:selected.name});
  292. if(map){
  293. r.rate = map.value;
  294. setSubValue(p,selected.name);
  295. }
  296. }else if(t_p.editable==true){//在原来的选项中没有选中节点则说明是自已输入的,同时要是可编辑的类型,用内插法算值
  297. let ltRate = null;//
  298. let gtRate = null;
  299. for(let v of r.subFeeRate.valueMaps){
  300. if(parseFloat(v.ID)<parseFloat(t_p.value)){
  301. ltRate = v;
  302. }else if( gtRate==null && parseFloat(v.ID)>parseFloat(t_p.value)){
  303. gtRate = v;
  304. }
  305. }
  306. if(ltRate!=null&&gtRate!=null){//已经找到前后的值了
  307. let step = scMathUtil.roundForObj(gtRate.value - ltRate.value,6);
  308. let total = parseFloat(gtRate.ID) - parseFloat(ltRate.ID);
  309. r.rate =getRateByStep(ltRate.value,total,parseFloat(t_p.value) - parseFloat(ltRate.ID),step,decimal);
  310. }else if(ltRate!=null&&gtRate == null){//说明是超出了选项的最大值
  311. let share = parseFloat(t_p.value) - parseFloat(ltRate.ID);//超出了多少
  312. r.rate = getRateByStep(ltRate.value,p.step,share,p.amount,decimal)
  313. }else if(gtRate!=null&&ltRate==null){//说明是只有一个选项,且这个选项比输入的值大
  314. let step = parseFloat(gtRate.value)- 0;
  315. r.rate = getRateByStep(0,gtRate.value,parseFloat(t_p.value),step,decimal)
  316. }
  317. if(r.rate!=undefined && r.rate != null){
  318. p.value = t_p.value;
  319. setSubValue(p,t_p.value);
  320. }
  321. }
  322. }
  323. }
  324. }
  325. if(r.ParentID&&r.ParentID!=""){
  326. childrenMap[r.ParentID]?childrenMap[r.ParentID].push(r):childrenMap[r.ParentID]=[r];
  327. }
  328. }
  329. return [IDMap,childrenMap]
  330. }
  331. function getRateByStep(ltValue,total,share,step,decimal) { //min值 ,计算值的总区间, 区间中占比,步长--前端也要用到
  332. let p = scMathUtil.roundForObj(share/total,6);
  333. let a = scMathUtil.roundForObj(step * p,6) ;
  334. return scMathUtil.roundForObj(ltValue + a,decimal)
  335. }
  336. function setSubValue(p,name) {//设置综合理程的树节点的子节点的值
  337. if(p.subList && p.subList.length > 0){
  338. for(let s of p.subList){
  339. s.value = Number(name);
  340. }
  341. }
  342. }
  343. async function newFeeRateFile(userId, updateData){
  344. if(updateData.property !== null){
  345. let property = updateData.property;
  346. logger.info("Create new feeRate file for project :"+updateData.ID);
  347. let feeFile = property.feeFile;
  348. let rootProjectID = property.rootProjectID;
  349. let name = updateData.name;
  350. let newFeeRate = {};
  351. if(feeFile.id.indexOf("newFeeRate")!=-1){
  352. let temFee = await feeRateFileModel.findOne({rootProjectID:rootProjectID,name:name,deleteInfo:null});
  353. if(temFee){
  354. newFeeRate.id=temFee.ID;
  355. newFeeRate.name = temFee.name;
  356. return newFeeRate;
  357. }
  358. let temA = feeFile.id.split("@@");
  359. let libID = temA[1];
  360. let doc={
  361. userID: userId,
  362. rootProjectID:rootProjectID,
  363. name:name
  364. };
  365. if(libID!== ''){
  366. let template = await std_fee_rate_lib_model.findOne({"ID":libID});
  367. let newFeeRate = {};
  368. newFeeRate.ID =uuidV1();
  369. newFeeRate.rates=template.rates;
  370. (newFeeRate.rates || []).forEach(item => item.originalRate = item.rate);
  371. await feeRateModel.create(newFeeRate);
  372. doc.libID = libID;
  373. doc.libName = template.libName;
  374. doc.feeRateID = newFeeRate.ID;
  375. }
  376. doc.ID = uuidV1();
  377. await feeRateFileModel.create(doc);
  378. newFeeRate.id = doc.ID;
  379. newFeeRate.name =doc.name;
  380. return newFeeRate;
  381. }else {
  382. return feeFile
  383. }
  384. }
  385. return null;
  386. }
  387. async function checkFeeRateName(jdata) {
  388. let data = JSON.parse(jdata);
  389. let count = await feeRateFileModel.count({rootProjectID:data.rootProjectID,name:data.name,deleteInfo:null});
  390. if(count>0){
  391. return true;
  392. }
  393. return false;
  394. }
  395. async function getChangeInfo(jdata,compilation){
  396. let data = JSON.parse(jdata);
  397. //{ rootProjectID: 99, user_id: '76075' }
  398. const notDeleted = [{deleteInfo: null}, {'deleteInfo.deleted':false}];
  399. let result={};
  400. let treeData = [];
  401. let currentProject = await projectsModel.findOne({'ID':data.rootProjectID},['ID','NextSiblingID','ParentID','name']); //{projectID:99,name:'建设项目1'};//dummy 数据
  402. let currentTender = await projectsModel.findOne({ID: data.projectID, $or: notDeleted});
  403. if(currentProject){
  404. //剔除自身
  405. let currentFeeFile = await getFeeRatesByProject(data.rootProjectID);
  406. let currentUsedFF = currentTender.property.feeFile.id;
  407. currentProject._doc.currentOptions = _.filter(currentFeeFile, function (ff) {
  408. return ff.ID !== currentUsedFF;
  409. });
  410. }
  411. //根据用户ID 找除了当前项目的其它建设项目;
  412. let others =await projectsModel.find({'$and': [
  413. {'$or':[{'userID': data.user_id,'compilation': compilation,'projType':'Project', 'deleteInfo': null}, {'userID': data.user_id,'compilation': compilation,'projType':'Project', 'deleteInfo.deleted': {'$in': [null, false]}}]},
  414. { 'ID':{'$nin':[data.rootProjectID]}}
  415. ]},['ID','NextSiblingID','ParentID','name']);
  416. for(let o of others){
  417. o._doc.optionList = await getFeeRatesByProject(o.ID);
  418. }
  419. //获取对应用户所有文件夹
  420. let folders = await projectsModel.find({userID: data.user_id, $or: notDeleted, projType: 'Folder'}, ['ID','NextSiblingID','ParentID','name']);
  421. treeData = treeData.concat(currentProject);
  422. treeData = treeData.concat(others);
  423. treeData = treeData.concat(folders);
  424. result.currentProject=currentProject;
  425. result.others = others;
  426. result.treeData = treeData;
  427. return result;
  428. }
  429. async function getFeeRatesByProject(rootProjectID) {
  430. let feeRates = await feeRateFileModel.find({rootProjectID:rootProjectID,deleteInfo:null},['ID','name']);
  431. return feeRates;
  432. }
  433. async function setFeeRateToBill(data){
  434. data=JSON.parse(data);
  435. if(data.hasOwnProperty('bills')){
  436. await billModel.model.findOneAndUpdate(data.bills.query,data.bills.doc);
  437. }
  438. if(data.hasOwnProperty('feeRate')){
  439. await feeRateModel.findOneAndUpdate(data.feeRate.query,data.feeRate.doc);
  440. }
  441. return "ok";
  442. }
  443. async function updateFeeRate(data) {
  444. data=JSON.parse(data);
  445. return await feeRateModel.findOneAndUpdate(data.query,data.doc);
  446. }
  447. async function updateFeeRates(datas){//批量更新费率
  448. datas = JSON.parse(datas);
  449. let tasks = [];
  450. for(let d of datas){
  451. let task = {
  452. updateOne:{
  453. filter:d.query,
  454. update:d.doc
  455. }
  456. }
  457. tasks.push(task);
  458. }
  459. tasks.length > 0 ? await feeRateModel.bulkWrite(tasks) : '';
  460. return 'OK';
  461. }
  462. async function changeFeeRateFileFromCurrent(jdata){
  463. let data = JSON.parse(jdata);
  464. let newFeeRateFile=data.newFeeRateFile;
  465. await changeFeeRateFile(data,newFeeRateFile,0);
  466. let feeRateData = await feeRateFileModel.findOne({'ID':newFeeRateFile.id});
  467. if(feeRateData!==null){
  468. let feeRate = await feeRateModel.findOne({ID:feeRateData.feeRateID});
  469. feeRateData._doc.rates = feeRate.rates;
  470. }
  471. //
  472. feeRateData._doc.usageProjects=await getUsageProjects(feeRateData.ID);
  473. return feeRateData;
  474. }
  475. async function changeFeeRateFile(projectData,feeRateFile,type,userID) {
  476. let temFile=null,newFeeRateFile = {};
  477. if(type == 0){//从本建设项目中替换,直接赋值
  478. temFile = feeRateFile
  479. }else if(type == 1) {//从其它建设项目中复制
  480. let oldFeeRateFile = await feeRateFileModel.findOne({'ID':feeRateFile.id});
  481. let feeRate = await feeRateModel.findOne({ID:oldFeeRateFile.feeRateID});
  482. let newFeeRate={};
  483. if(! feeRate){
  484. throw '不存在对应费率文件';
  485. }
  486. newFeeRate.ID=uuidV1();
  487. newFeeRate.rates =feeRate.rates;
  488. newFeeRateFile.ID = uuidV1();
  489. newFeeRateFile.name = feeRateFile.name;
  490. newFeeRateFile.userID = userID;
  491. newFeeRateFile.libName = oldFeeRateFile.libName;
  492. newFeeRateFile.libID=oldFeeRateFile.libID;
  493. newFeeRateFile.rootProjectID = projectData.rootProjectID;
  494. newFeeRateFile.feeRateID =newFeeRate.ID;
  495. await feeRateModel.create(newFeeRate);
  496. await feeRateFileModel.create(newFeeRateFile);
  497. temFile={
  498. id:newFeeRateFile.ID,
  499. name:feeRateFile.name
  500. };
  501. newFeeRateFile.rates=newFeeRate.rates;//构建返回数据
  502. }
  503. await projectsModel.findOneAndUpdate({ID:projectData.projectID},{'property.feeFile':temFile});
  504. return newFeeRateFile
  505. }
  506. async function changeFeeRateFileFromOthers(jdata) {
  507. let data = JSON.parse(jdata);
  508. let newFeeRateFile = await changeFeeRateFile(data,{id:data.feeRateFileID,name:data.name},1,data.userID);
  509. /* let feeRateFile = await feeRateFileModel.findOne({'ID':data.feeRateFileID});
  510. let feeRate = await feeRateModel.findOne({ID:feeRateFile.feeRateID});
  511. let newFeeRate={};
  512. newFeeRate.ID=uuidV1();
  513. newFeeRate.rates =feeRate.rates;
  514. let newFeeRateFile = {};
  515. newFeeRateFile.ID = uuidV1();
  516. newFeeRateFile.name = data.name;
  517. newFeeRateFile.userID = data.userID;
  518. newFeeRateFile.libName = feeRateFile.libName;
  519. newFeeRateFile.libID=feeRateFile.libID;
  520. newFeeRateFile.rootProjectID = data.rootProjectID;
  521. newFeeRateFile.feeRateID =newFeeRate.ID;
  522. await feeRateModel.create(newFeeRate);
  523. await feeRateFileModel.create(newFeeRateFile);
  524. let feeFile={
  525. id:newFeeRateFile.ID,
  526. name:data.name
  527. }
  528. await projectsModel.findOneAndUpdate({ID:data.projectID},{'property.feeFile':feeFile});
  529. newFeeRateFile.rates=newFeeRate.rates;*/
  530. newFeeRateFile.usageProjects=await getUsageProjects(newFeeRateFile.ID);
  531. return newFeeRateFile;
  532. }
  533. async function getGCFeeRateFiles(userID){
  534. return await feeRateFileModel.find({userID: userID, 'deleteInfo.deleted': true, '$or': [{'deleteInfo.completeDeleted': false}, {'deleteInfo.completeDeleted': null}]});
  535. }
  536. async function getFeeRateByID(ID) {
  537. let feeRateFile = await feeRateFileModel.findOne({'ID':ID}, '-_id');
  538. let feeRate = await feeRateModel.findOne({ID:feeRateFile.feeRateID}, '-_id');
  539. return [feeRateFile,feeRate]
  540. }