material_file.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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 where = { tid };
  29. if (mid) where.mid = mid;
  30. return await this.db.select(this.tableName, {
  31. where,
  32. orders: [['upload_time', 'desc']],
  33. });
  34. }
  35. /**
  36. * 存储上传的文件信息至数据库
  37. * @param {Array} payload 载荷
  38. * @return {Promise<void>} 数据库插入执行实例
  39. */
  40. async saveFileMsgToDb(payload) {
  41. return await this.db.insert(this.tableName, payload);
  42. }
  43. /**
  44. * 获取单个文件信息
  45. * @param {Number} id 文件id
  46. * @return {Promise<void>} 数据库查询实例
  47. */
  48. async getMaterialFileById(id) {
  49. return await this.getDataByCondition({ id });
  50. }
  51. /**
  52. * 删除附件
  53. * @param {Number} id - 附件id
  54. * @return {void}
  55. */
  56. async delete(id) {
  57. return await this.deleteById(id);
  58. }
  59. }
  60. return MaterialFile;
  61. };