material_file.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. 'use strict';
  2. const fs = require('fs');
  3. const path = require('path');
  4. /**
  5. * 附件表 数据模型
  6. * @author LanJianRong
  7. * @date 2020/6/30
  8. * @version
  9. */
  10. module.exports = app => {
  11. class MaterialFile extends app.BaseService {
  12. /**
  13. * 构造函数
  14. *
  15. * @param {Object} ctx - egg全局变量
  16. * @return {void}
  17. */
  18. constructor(ctx) {
  19. super(ctx);
  20. this.tableName = 'material_file';
  21. }
  22. /**
  23. * 获取当前标段所有上传的附件
  24. * @param {Number} tenderId 标段id
  25. * @param {Number} mid 期id
  26. * @return {Promise<void>} 数据库查询实例
  27. */
  28. async getAllMaterialFiles(tenderId, mid) {
  29. const where = mid ? { tid: tenderId, mid } : { tid: tenderId };
  30. return await this.db.select(this.tableName, {
  31. where,
  32. });
  33. }
  34. /**
  35. * 存储上传的文件信息至数据库
  36. * @param {Array} payload 载荷
  37. * @return {Promise<void>} 数据库插入执行实例
  38. */
  39. async saveFileMsgToDb(payload) {
  40. return await this.db.insert(this.tableName, payload);
  41. }
  42. /**
  43. * 获取单个文件信息
  44. * @param {Number} id 文件id
  45. * @return {Promise<void>} 数据库查询实例
  46. */
  47. async getMaterialFileById(id) {
  48. return await this.getDataByCondition({ id });
  49. }
  50. /**
  51. * 删除附件
  52. * @param {Number} id - 附件id
  53. * @return {void}
  54. */
  55. async delete(id) {
  56. return await this.deleteById(id);
  57. }
  58. }
  59. return MaterialFile;
  60. };