UploadFile.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2017~2024 https://www.yiovo.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
  8. // +----------------------------------------------------------------------
  9. // | Author: 萤火科技 <admin@yiovo.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\common\model;
  13. use cores\BaseModel;
  14. use think\model\relation\BelongsTo;
  15. use app\common\enum\file\Storage as StorageEnum;
  16. use app\common\enum\file\FileType as FileTypeEnum;
  17. /**
  18. * 文件库模型
  19. * Class UploadFile
  20. * @package app\common\model
  21. */
  22. class UploadFile extends BaseModel
  23. {
  24. // 定义表名
  25. protected $name = 'upload_file';
  26. // 定义主键
  27. protected $pk = 'file_id';
  28. // 追加的字段
  29. protected $append = [
  30. 'preview_url', // 图片预览url
  31. 'external_url' // 文件外链url (用于视频文件)
  32. ];
  33. /**
  34. * 关联模型:文件库分组
  35. * @return BelongsTo
  36. */
  37. public function uploadGroup(): BelongsTo
  38. {
  39. return $this->belongsTo('UploadGroup', 'group_id');
  40. }
  41. /**
  42. * 生成预览url (preview_url)
  43. * @param $value
  44. * @param $data
  45. * @return string
  46. */
  47. public function getPreviewUrlAttr($value, $data): string
  48. {
  49. // 图片的预览图直接使用外链
  50. if ($data['file_type'] == FileTypeEnum::IMAGE) {
  51. return $this->getExternalUrlAttr($value, $data);
  52. }
  53. // 生成默认的预览图
  54. $previewPath = FileTypeEnum::data()[$data['file_type']]['preview_path'];
  55. return base_url() . $previewPath;
  56. }
  57. /**
  58. * 生成外链url (external_url)
  59. * @param $value
  60. * @param $data
  61. * @return string
  62. */
  63. public function getExternalUrlAttr($value, $data): string
  64. {
  65. // 存储方式本地:拼接当前域名
  66. if ($data['storage'] === StorageEnum::LOCAL) {
  67. $data['domain'] = rtrim(uploads_url(), '/');
  68. }
  69. return "{$data['domain']}/{$data['file_path']}";
  70. }
  71. /**
  72. * 文件详情
  73. * @param int $fileId
  74. * @return static|array|null
  75. */
  76. public static function detail(int $fileId)
  77. {
  78. return self::get($fileId);
  79. }
  80. /**
  81. * 过滤不存在的文件ID集
  82. * @param array $fileIds
  83. * @param int|null $storeId
  84. * @return array
  85. */
  86. public static function filteFileIds(array $fileIds, int $storeId = null): array
  87. {
  88. return (new static)->where('file_id', 'in', $fileIds)
  89. ->where('store_id', '=', $storeId ?: self::$storeId)
  90. ->where('is_delete', '=', 0)
  91. ->column('file_id');
  92. }
  93. }