material_file.js 2.0 KB

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