cloud_disk_resource.go 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. package models
  2. import (
  3. "eta_gn/eta_api/global"
  4. "eta_gn/eta_api/utils"
  5. "fmt"
  6. "strings"
  7. "time"
  8. )
  9. // 文件格式图标
  10. const (
  11. CloudDiskResourceFileTypeIconMenu = "https://hzstatic.hzinsights.com/static/icon/file_type_menu.png"
  12. CloudDiskResourceFileTypeIconUnknown = "https://hzstatic.hzinsights.com/static/icon/file_type_unknown.png"
  13. )
  14. type CloudDiskResource struct {
  15. ResourceId int `gorm:"column(resource_id);primaryKey;autoIncrement" description:"资源ID"`
  16. MenuId int `gorm:"column(menu_id)" description:"目录ID"`
  17. ResourceName string `gorm:"column(resource_name)" description:"文件名"`
  18. ResourceSuffix string `gorm:"column(resource_suffix)" description:"文件后缀名"`
  19. ResourceUrl string `gorm:"column(resource_url)" description:"文件地址"`
  20. ResourceIcon string `gorm:"column(resource_icon)" description:"文件类型图标"`
  21. AdminId int `gorm:"column(admin_id)" description:"创建人ID"`
  22. AdminName string `gorm:"column(admin_name)" description:"创建人名称"`
  23. Size int64 `gorm:"column(size)" description:"目录大小"`
  24. CreateTime time.Time `gorm:"column(create_time);autoCreateTime" description:"创建时间"`
  25. ModifyTime time.Time `gorm:"column(modify_time);autoUpdateTime" description:"修改时间"`
  26. }
  27. func (m *CloudDiskResource) TableName() string {
  28. return "cloud_disk_resource"
  29. }
  30. func (m *CloudDiskResource) Create() (err error) {
  31. err = global.DEFAULT_DmSQL.Create(m).Error
  32. return
  33. }
  34. func (m *CloudDiskResource) Update(cols []string) (err error) {
  35. err = global.DEFAULT_DmSQL.Select(cols).Updates(m).Error
  36. return
  37. }
  38. func (m *CloudDiskResource) Delete() (err error) {
  39. sql := `DELETE FROM cloud_disk_resource WHERE resource_id = ? LIMIT 1`
  40. err = global.DEFAULT_DmSQL.Raw(sql, m.ResourceId).Error
  41. return
  42. }
  43. func (m *CloudDiskResource) GetItemById(id int) (err error) {
  44. sql := fmt.Sprintf(`SELECT * FROM %s WHERE resource_id = ? LIMIT 1`, m.TableName())
  45. err = global.DEFAULT_DmSQL.Raw(sql, id).First(&m).Error
  46. return
  47. }
  48. func (m *CloudDiskResource) GetItemByCondition(condition string, pars []interface{}) (err error) {
  49. sql := fmt.Sprintf(`SELECT * FROM %s WHERE 1=1 %s LIMIT 1`, m.TableName(), condition)
  50. err = global.DEFAULT_DmSQL.Raw(sql, pars...).First(&m).Error
  51. return
  52. }
  53. func (m *CloudDiskResource) GetItemsByCondition(condition string, pars []interface{}, fieldArr []string, orderRule string) (items []*CloudDiskResource, err error) {
  54. fields := strings.Join(fieldArr, ",")
  55. if len(fieldArr) == 0 {
  56. fields = `*`
  57. }
  58. order := ``
  59. if orderRule != "" {
  60. order = ` ORDER BY ` + orderRule
  61. }
  62. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s`, fields, m.TableName(), condition, order)
  63. err = global.DEFAULT_DmSQL.Raw(sql, pars...).Find(&items).Error
  64. return
  65. }
  66. // CloudDiskCheckResourceRepeatReq 校验文件重名请求体
  67. type CloudDiskCheckResourceRepeatReq struct {
  68. MenuId int `description:"目录ID"`
  69. FileNames []string `description:"文件名"`
  70. }
  71. // CloudDiskCheckResourceRepeatResp 校验文件重名响应体
  72. type CloudDiskCheckResourceRepeatResp struct {
  73. OriginName string `description:"原文件名(包含后缀名)"`
  74. IsRepeat bool `description:"是否重复"`
  75. AvailableName string `description:"可用名"`
  76. }
  77. // CloudDiskResourceRenameReq 重命名文件请求体
  78. type CloudDiskResourceRenameReq struct {
  79. ResourceId int `description:"文件ID"`
  80. ResourceName string `description:"文件名称"`
  81. }
  82. // CloudDiskResourceDeleteReq 删除文件请求体
  83. type CloudDiskResourceDeleteReq struct {
  84. ResourceId int `description:"文件ID"`
  85. }
  86. // CloudDiskListResp 云盘列表响应体
  87. type CloudDiskListResp struct {
  88. List []*CloudDiskListItem `description:"列表数据"`
  89. CreateMenuAuth bool `description:"新建文件夹权限"`
  90. UploadResourceAuth bool `description:"上传文件的权限"`
  91. BatchDelAuth bool `description:"批量删除目录/文件的权限(仅管理员有)"`
  92. ListPath []*CloudDiskMenuResourcePath `description:"面包屑"`
  93. }
  94. // CloudDiskListItem 云盘列表数据
  95. type CloudDiskListItem struct {
  96. ItemId int `description:"ID"`
  97. ItemName string `description:"名称"`
  98. ItemType int `description:"类型: 1-目录; 2-文件"`
  99. ParentId int `description:"父级目录ID"`
  100. ParentName string `description:"父级目录文件名"`
  101. Size int64 `description:"大小"`
  102. SizeName string `description:"目录/文件大小(格式化)"`
  103. ResourceUrl string `description:"文件地址"`
  104. ItemIcon string `description:"图标"`
  105. AdminId int `description:"创建人ID"`
  106. AdminName string `description:"创建人"`
  107. CreateTime string `description:"创建时间"`
  108. ButtonAuth *CloudDiskListButton `description:"按钮权限"`
  109. }
  110. // CloudDiskListButton 云盘列表按钮权限
  111. type CloudDiskListButton struct {
  112. RenameAuth bool `description:"重命名文件夹的权限"`
  113. DelAuth bool `description:"删除文件夹的权限"`
  114. }
  115. // CloudDiskMenuResourcePath 云盘目录/文件面包屑
  116. type CloudDiskMenuResourcePath struct {
  117. MenuId int `description:"目录ID"`
  118. MenuName string `description:"目录名称"`
  119. ParentId int `description:"父级目录ID"`
  120. Sort int `description:"排序"`
  121. Selected bool `description:"是否选中"`
  122. }
  123. // GetCloudDiskMenuAndResourceList UNION获取云盘列表数据
  124. func GetCloudDiskMenuAndResourceList(menuCond, resourceCond string, menuPars, resourcePars []interface{}, orderRule string) (items []*CloudDiskListItem, err error) {
  125. //o := orm.NewOrm()
  126. base := `SELECT menu_id AS item_id, menu_name AS item_name, 1 AS item_type, parent_id, size, "" AS resource_url, "" AS item_icon, admin_id, admin_name, create_time FROM cloud_disk_menu
  127. WHERE 1=1 %s
  128. UNION
  129. SELECT resource_id, CONCAT(resource_name,resource_suffix), 2, menu_id, size, resource_url, resource_icon, admin_id, admin_name, create_time FROM cloud_disk_resource
  130. WHERE 1=1 %s %s`
  131. order := ` ORDER BY item_type ASC `
  132. if orderRule != "" {
  133. order = ` ORDER BY ` + orderRule
  134. }
  135. sql := fmt.Sprintf(base, menuCond, resourceCond, order)
  136. pars := append(menuPars, resourcePars...)
  137. err = global.DEFAULT_DmSQL.Raw(sql, pars...).Find(&items).Error
  138. return
  139. }
  140. // GetSizeTotalByMenuIds 获取目录所属文件总大小
  141. func GetSizeTotalByMenuIds(menuIds []int) (sizeTotal int64, err error) {
  142. if len(menuIds) == 0 {
  143. return
  144. }
  145. sql := `SELECT SUM(size) FROM cloud_disk_resource WHERE menu_id IN (` + utils.GetOrmInReplace(len(menuIds)) + `)`
  146. err = global.DEFAULT_DmSQL.Raw(sql, menuIds).First(&sizeTotal).Error
  147. return
  148. }
  149. // CloudDiskBatchDeleteReq 批量删除请求体
  150. type CloudDiskBatchDeleteReq struct {
  151. MenuId int `description:"当前目录ID"`
  152. MenuIds string `description:"目录IDs"`
  153. ResourceIds string `description:"文件IDs"`
  154. }
  155. // BatchDeleteCloudDiskMenuAndResource 批量删除目录及文件
  156. func BatchDeleteCloudDiskMenuAndResource(menuIds, resourceIds []int) (err error) {
  157. menuLens := len(menuIds)
  158. resourceLens := len(resourceIds)
  159. if menuLens == 0 && resourceLens == 0 {
  160. return
  161. }
  162. tx := global.DEFAULT_DmSQL.Begin()
  163. defer func() {
  164. if err != nil {
  165. _ = tx.Rollback()
  166. } else {
  167. _ = tx.Commit()
  168. }
  169. }()
  170. if menuLens > 0 {
  171. sql := `DELETE FROM cloud_disk_menu WHERE menu_id IN (` + utils.GetOrmInReplace(menuLens) + `)`
  172. if err = tx.Exec(sql, menuIds).Error; err != nil {
  173. return
  174. }
  175. sql = `DELETE FROM cloud_disk_resource WHERE menu_id IN (` + utils.GetOrmInReplace(menuLens) + `)`
  176. if err = tx.Exec(sql, menuIds).Error; err != nil {
  177. return
  178. }
  179. }
  180. if resourceLens > 0 {
  181. sql := `DELETE FROM cloud_disk_resource WHERE resource_id IN (` + utils.GetOrmInReplace(resourceLens) + `)`
  182. if err = tx.Exec(sql, resourceIds).Error; err != nil {
  183. return
  184. }
  185. }
  186. return
  187. }