material_file.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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. });
  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. };