advance_file.js 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. 'use strict';
  2. /**
  3. * 附件表 数据模型
  4. * @author LanJianRong
  5. * @date 2020/8/17
  6. * @version
  7. */
  8. module.exports = app => {
  9. class AdvanceFile extends app.BaseService {
  10. /**
  11. * 构造函数
  12. * @param {Object} ctx - egg全局变量
  13. * @return {void}
  14. */
  15. constructor(ctx) {
  16. super(ctx);
  17. this.tableName = 'advance_file';
  18. }
  19. /**
  20. * 获取文件
  21. * @param {*} payload 载荷|查询条件
  22. */
  23. async getAdvanceFiles(payload) {
  24. const { ctx } = this;
  25. const result = await this.db.select(this.tableName, { where: payload });
  26. const list = result.map(item => {
  27. if (!ctx.helper.canPreview(item.fileext)) {
  28. item.filepath = `/tender/${ctx.tender.id}/advance/${item.vid}/file/${item.id}/download`;
  29. } else {
  30. item.filepath = this.ctx.app.config.fujianOssPath + item.filepath;
  31. }
  32. return item;
  33. });
  34. return list;
  35. }
  36. /**
  37. * 存储上传的文件信息至数据库
  38. * @param {Array} payload 载荷
  39. * @return {Promise<void>} 数据库插入执行实例
  40. */
  41. async saveFileMsgToDb(payload) {
  42. return await this.db.insert(this.tableName, payload);
  43. }
  44. /**
  45. * 删除附件
  46. * @param {Number} id - 附件id
  47. * @return {void}
  48. */
  49. async delete(id) {
  50. return await this.deleteById(id);
  51. }
  52. /**
  53. * 根据预付款id删除附件
  54. * @param {String} vid - 预付款id
  55. * @return {void}
  56. */
  57. async deleteByVid(vid) {
  58. await this.db.delete(this.tableName, {
  59. vid,
  60. });
  61. }
  62. }
  63. return AdvanceFile;
  64. };