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.

package.go 5.8 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. package db2
  2. import (
  3. "fmt"
  4. "gorm.io/gorm"
  5. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  6. "gitlink.org.cn/cloudream/storage/common/pkgs/db2/model"
  7. )
  8. type PackageDB struct {
  9. *DB
  10. }
  11. func (db *DB) Package() *PackageDB {
  12. return &PackageDB{DB: db}
  13. }
  14. func (db *PackageDB) GetByID(ctx SQLContext, packageID cdssdk.PackageID) (model.Package, error) {
  15. var ret model.Package
  16. err := ctx.Table("Package").Where("PackageID = ?", packageID).First(&ret).Error
  17. return ret, err
  18. }
  19. func (db *PackageDB) GetByName(ctx SQLContext, bucketID cdssdk.BucketID, name string) (model.Package, error) {
  20. var ret model.Package
  21. err := ctx.Table("Package").Where("BucketID = ? AND Name = ?", bucketID, name).First(&ret).Error
  22. return ret, err
  23. }
  24. func (db *PackageDB) BatchTestPackageID(ctx SQLContext, pkgIDs []cdssdk.PackageID) (map[cdssdk.PackageID]bool, error) {
  25. if len(pkgIDs) == 0 {
  26. return make(map[cdssdk.PackageID]bool), nil
  27. }
  28. var avaiIDs []cdssdk.PackageID
  29. err := ctx.Table("Package").
  30. Select("PackageID").
  31. Where("PackageID IN ?", pkgIDs).
  32. Find(&avaiIDs).Error
  33. if err != nil {
  34. return nil, err
  35. }
  36. avaiIDMap := make(map[cdssdk.PackageID]bool)
  37. for _, pkgID := range avaiIDs {
  38. avaiIDMap[pkgID] = true
  39. }
  40. return avaiIDMap, nil
  41. }
  42. func (*PackageDB) BatchGetAllPackageIDs(ctx SQLContext, start int, count int) ([]cdssdk.PackageID, error) {
  43. var ret []cdssdk.PackageID
  44. err := ctx.Table("Package").Select("PackageID").Limit(count).Offset(start).Find(&ret).Error
  45. return ret, err
  46. }
  47. func (db *PackageDB) GetUserBucketPackages(ctx SQLContext, userID cdssdk.UserID, bucketID cdssdk.BucketID) ([]model.Package, error) {
  48. var ret []model.Package
  49. err := ctx.Table("UserBucket").
  50. Select("Package.*").
  51. Joins("JOIN Package ON UserBucket.BucketID = Package.BucketID").
  52. Where("UserBucket.UserID = ? AND UserBucket.BucketID = ?", userID, bucketID).
  53. Find(&ret).Error
  54. return ret, err
  55. }
  56. func (db *PackageDB) GetBucketPackages(ctx SQLContext, bucketID cdssdk.BucketID) ([]model.Package, error) {
  57. var ret []model.Package
  58. err := ctx.Table("Package").
  59. Select("Package.*").
  60. Where("BucketID = ?", bucketID).
  61. Find(&ret).Error
  62. return ret, err
  63. }
  64. // IsAvailable 判断一个用户是否拥有指定对象
  65. func (db *PackageDB) IsAvailable(ctx SQLContext, userID cdssdk.UserID, packageID cdssdk.PackageID) (bool, error) {
  66. var pkgID cdssdk.PackageID
  67. err := ctx.Table("Package").
  68. Select("Package.PackageID").
  69. Joins("JOIN UserBucket ON Package.BucketID = UserBucket.BucketID").
  70. Where("Package.PackageID = ? AND UserBucket.UserID = ?", packageID, userID).
  71. Scan(&pkgID).Error
  72. if err == gorm.ErrRecordNotFound {
  73. return false, nil
  74. }
  75. if err != nil {
  76. return false, fmt.Errorf("find package failed, err: %w", err)
  77. }
  78. return true, nil
  79. }
  80. // GetUserPackage 获得Package,如果用户没有权限访问,则不会获得结果
  81. func (db *PackageDB) GetUserPackage(ctx SQLContext, userID cdssdk.UserID, packageID cdssdk.PackageID) (model.Package, error) {
  82. var ret model.Package
  83. err := ctx.Table("Package").
  84. Select("Package.*").
  85. Joins("JOIN UserBucket ON Package.BucketID = UserBucket.BucketID").
  86. Where("Package.PackageID = ? AND UserBucket.UserID = ?", packageID, userID).
  87. First(&ret).Error
  88. return ret, err
  89. }
  90. // 在指定名称的Bucket中查找指定名称的Package
  91. func (*PackageDB) GetUserPackageByName(ctx SQLContext, userID cdssdk.UserID, bucketName string, packageName string) (model.Package, error) {
  92. var ret model.Package
  93. err := ctx.Table("Package").
  94. Select("Package.*").
  95. Joins("JOIN Bucket ON Package.BucketID = Bucket.BucketID").
  96. Joins("JOIN UserBucket ON Bucket.BucketID = UserBucket.BucketID").
  97. Where("Package.Name = ? AND Bucket.Name = ? AND UserBucket.UserID = ?", packageName, bucketName, userID).
  98. First(&ret).Error
  99. return ret, err
  100. }
  101. func (db *PackageDB) Create(ctx SQLContext, bucketID cdssdk.BucketID, name string) (cdssdk.Package, error) {
  102. var packageID int64
  103. err := ctx.Table("Package").
  104. Select("PackageID").
  105. Where("Name = ? AND BucketID = ?", name, bucketID).
  106. Scan(&packageID).Error
  107. if err != nil {
  108. return cdssdk.Package{}, err
  109. }
  110. if packageID != 0 {
  111. return cdssdk.Package{}, gorm.ErrDuplicatedKey
  112. }
  113. newPackage := cdssdk.Package{Name: name, BucketID: bucketID, State: cdssdk.PackageStateNormal}
  114. if err := ctx.Create(&newPackage).Error; err != nil {
  115. return cdssdk.Package{}, fmt.Errorf("insert package failed, err: %w", err)
  116. }
  117. return newPackage, nil
  118. }
  119. func (*PackageDB) Delete(ctx SQLContext, packageID cdssdk.PackageID) error {
  120. err := ctx.Delete(&model.Package{}, "PackageID = ?", packageID).Error
  121. return err
  122. }
  123. // 删除与Package相关的所有数据
  124. func (db *PackageDB) DeleteComplete(ctx SQLContext, packageID cdssdk.PackageID) error {
  125. if err := db.Package().Delete(ctx, packageID); err != nil {
  126. return fmt.Errorf("delete package state: %w", err)
  127. }
  128. if err := db.ObjectAccessStat().DeleteInPackage(ctx, packageID); err != nil {
  129. return fmt.Errorf("delete from object access stat: %w", err)
  130. }
  131. if err := db.ObjectBlock().DeleteInPackage(ctx, packageID); err != nil {
  132. return fmt.Errorf("delete from object block failed, err: %w", err)
  133. }
  134. if err := db.PinnedObject().DeleteInPackage(ctx, packageID); err != nil {
  135. return fmt.Errorf("deleting pinned objects in package: %w", err)
  136. }
  137. if err := db.Object().DeleteInPackage(ctx, packageID); err != nil {
  138. return fmt.Errorf("deleting objects in package: %w", err)
  139. }
  140. if err := db.PackageAccessStat().DeleteByPackageID(ctx, packageID); err != nil {
  141. return fmt.Errorf("deleting package access stat: %w", err)
  142. }
  143. return nil
  144. }
  145. func (*PackageDB) ChangeState(ctx SQLContext, packageID cdssdk.PackageID, state string) error {
  146. err := ctx.Exec("UPDATE Package SET State = ? WHERE PackageID = ?", state, packageID).Error
  147. return err
  148. }

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