You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

object_access_stat.go 3.8 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package db
  2. import (
  3. jcstypes "gitlink.org.cn/cloudream/jcs-pub/common/types"
  4. "gorm.io/gorm"
  5. "gorm.io/gorm/clause"
  6. )
  7. type ObjectAccessStatDB struct {
  8. *DB
  9. }
  10. func (db *DB) ObjectAccessStat() *ObjectAccessStatDB {
  11. return &ObjectAccessStatDB{db}
  12. }
  13. func (*ObjectAccessStatDB) Get(ctx SQLContext, objID jcstypes.ObjectID, spaceID jcstypes.UserSpaceID) (jcstypes.ObjectAccessStat, error) {
  14. var ret jcstypes.ObjectAccessStat
  15. err := ctx.Table("ObjectAccessStat").
  16. Where("ObjectID = ? AND UserSpaceID = ?", objID, spaceID).
  17. First(&ret).Error
  18. return ret, err
  19. }
  20. func (*ObjectAccessStatDB) GetByObjectID(ctx SQLContext, objID jcstypes.ObjectID) ([]jcstypes.ObjectAccessStat, error) {
  21. var ret []jcstypes.ObjectAccessStat
  22. err := ctx.Table("ObjectAccessStat").
  23. Where("ObjectID = ?", objID).
  24. Find(&ret).Error
  25. return ret, err
  26. }
  27. func (*ObjectAccessStatDB) BatchGetByObjectID(ctx SQLContext, objIDs []jcstypes.ObjectID) ([]jcstypes.ObjectAccessStat, error) {
  28. if len(objIDs) == 0 {
  29. return nil, nil
  30. }
  31. var ret []jcstypes.ObjectAccessStat
  32. err := ctx.Table("ObjectAccessStat").
  33. Where("ObjectID IN ?", objIDs).
  34. Find(&ret).Error
  35. return ret, err
  36. }
  37. func (*ObjectAccessStatDB) BatchGetByObjectIDOnStorage(ctx SQLContext, objIDs []jcstypes.ObjectID, spaceID jcstypes.UserSpaceID) ([]jcstypes.ObjectAccessStat, error) {
  38. if len(objIDs) == 0 {
  39. return nil, nil
  40. }
  41. var ret []jcstypes.ObjectAccessStat
  42. err := ctx.Table("ObjectAccessStat").
  43. Where("ObjectID IN ? AND UserSpaceID = ?", objIDs, spaceID).
  44. Find(&ret).Error
  45. return ret, err
  46. }
  47. func (*ObjectAccessStatDB) BatchAddCounter(ctx SQLContext, entries []AddAccessStatEntry) error {
  48. if len(entries) == 0 {
  49. return nil
  50. }
  51. for _, entry := range entries {
  52. acc := jcstypes.ObjectAccessStat{
  53. ObjectID: entry.ObjectID,
  54. UserSpaceID: entry.UserSpaceID,
  55. Counter: entry.Counter,
  56. }
  57. err := ctx.Table("ObjectAccessStat").
  58. Clauses(clause.OnConflict{
  59. Columns: []clause.Column{{Name: "ObjectID"}, {Name: "UserSpaceID"}},
  60. DoUpdates: clause.Assignments(map[string]any{
  61. "Counter": gorm.Expr("Counter + values(Counter)"),
  62. }),
  63. }).Create(&acc).Error
  64. if err != nil {
  65. return err
  66. }
  67. }
  68. return nil
  69. }
  70. func (*ObjectAccessStatDB) BatchUpdateAmountInPackage(ctx SQLContext, pkgIDs []jcstypes.PackageID, historyWeight float64) error {
  71. if len(pkgIDs) == 0 {
  72. return nil
  73. }
  74. err := ctx.Exec("UPDATE ObjectAccessStat AS o INNER JOIN Object AS obj ON o.ObjectID = obj.ObjectID SET o.Amount = o.Amount * ? + o.Counter * (1 - ?), o.Counter = 0 WHERE obj.PackageID IN ?", historyWeight, historyWeight, pkgIDs).Error
  75. return err
  76. }
  77. func (*ObjectAccessStatDB) UpdateAllAmount(ctx SQLContext, historyWeight float64) error {
  78. err := ctx.Exec("UPDATE ObjectAccessStat SET Amount = Amount * ? + Counter * (1 - ?), Counter = 0", historyWeight, historyWeight).Error
  79. return err
  80. }
  81. func (*ObjectAccessStatDB) DeleteByObjectID(ctx SQLContext, objID jcstypes.ObjectID) error {
  82. err := ctx.Table("ObjectAccessStat").Where("ObjectID = ?", objID).Delete(nil).Error
  83. return err
  84. }
  85. func (*ObjectAccessStatDB) BatchDeleteByObjectID(ctx SQLContext, objIDs []jcstypes.ObjectID) error {
  86. if len(objIDs) == 0 {
  87. return nil
  88. }
  89. err := ctx.Table("ObjectAccessStat").Where("ObjectID IN ?", objIDs).Delete(nil).Error
  90. return err
  91. }
  92. func (*ObjectAccessStatDB) DeleteInPackage(ctx SQLContext, packageID jcstypes.PackageID) error {
  93. err := ctx.Exec("DELETE o FROM ObjectAccessStat o INNER JOIN Object obj ON o.ObjectID = obj.ObjectID WHERE obj.PackageID = ?", packageID).Error
  94. return err
  95. }
  96. func (*ObjectAccessStatDB) DeleteByUserSpaceID(ctx SQLContext, spaceID jcstypes.UserSpaceID) error {
  97. err := ctx.Table("ObjectAccessStat").Where("UserSpaceID = ?", spaceID).Delete(&jcstypes.ObjectAccessStat{}).Error
  98. return err
  99. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。