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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package db
  2. import (
  3. "github.com/jmoiron/sqlx"
  4. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  5. stgmod "gitlink.org.cn/cloudream/storage/common/models"
  6. coormq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/coordinator"
  7. )
  8. type ObjectAccessStatDB struct {
  9. *DB
  10. }
  11. func (db *DB) ObjectAccessStat() *ObjectAccessStatDB {
  12. return &ObjectAccessStatDB{db}
  13. }
  14. func (*ObjectAccessStatDB) Get(ctx SQLContext, objID cdssdk.ObjectID, nodeID cdssdk.NodeID) (stgmod.ObjectAccessStat, error) {
  15. var ret stgmod.ObjectAccessStat
  16. err := sqlx.Get(ctx, &ret, "select * from ObjectAccessStat where ObjectID=? and NodeID=?", objID, nodeID)
  17. return ret, err
  18. }
  19. func (*ObjectAccessStatDB) GetByObjectID(ctx SQLContext, objID cdssdk.ObjectID) ([]stgmod.ObjectAccessStat, error) {
  20. var ret []stgmod.ObjectAccessStat
  21. err := sqlx.Select(ctx, &ret, "select * from ObjectAccessStat where ObjectID=?", objID)
  22. return ret, err
  23. }
  24. func (*ObjectAccessStatDB) BatchGetByObjectID(ctx SQLContext, objIDs []cdssdk.ObjectID) ([]stgmod.ObjectAccessStat, error) {
  25. if len(objIDs) == 0 {
  26. return nil, nil
  27. }
  28. var ret []stgmod.ObjectAccessStat
  29. stmt, args, err := sqlx.In("select * from ObjectAccessStat where ObjectID in (?)", objIDs)
  30. if err != nil {
  31. return ret, err
  32. }
  33. err = sqlx.Select(ctx, &ret, stmt, args...)
  34. return ret, err
  35. }
  36. func (*ObjectAccessStatDB) BatchGetByObjectIDOnNode(ctx SQLContext, objIDs []cdssdk.ObjectID, nodeID cdssdk.NodeID) ([]stgmod.ObjectAccessStat, error) {
  37. if len(objIDs) == 0 {
  38. return nil, nil
  39. }
  40. var ret []stgmod.ObjectAccessStat
  41. stmt, args, err := sqlx.In("select * from ObjectAccessStat where ObjectID in (?) and NodeID=?", objIDs, nodeID)
  42. if err != nil {
  43. return ret, err
  44. }
  45. err = sqlx.Select(ctx, &ret, stmt, args...)
  46. return ret, err
  47. }
  48. func (*ObjectAccessStatDB) BatchAddCounter(ctx SQLContext, entries []coormq.AddAccessStatEntry) error {
  49. if len(entries) == 0 {
  50. return nil
  51. }
  52. sql := "insert into ObjectAccessStat(ObjectID, NodeID, Counter, Amount) " +
  53. " values(:ObjectID, :NodeID, :Counter, 0) as new" +
  54. " on duplicate key update ObjectAccessStat.Counter=ObjectAccessStat.Counter+new.Counter"
  55. err := BatchNamedExec(ctx, sql, 4, entries, nil)
  56. return err
  57. }
  58. func (*ObjectAccessStatDB) BatchUpdateAmountInPackage(ctx SQLContext, pkgIDs []cdssdk.PackageID, historyWeight float64) error {
  59. if len(pkgIDs) == 0 {
  60. return nil
  61. }
  62. stmt, args, err := sqlx.In("update ObjectAccessStat inner join Object"+
  63. " on ObjectAccessStat.ObjectID = Object.ObjectID"+
  64. " set Amount=Amount*?+Counter*(1-?), Counter = 0"+
  65. " where PackageID in (?)", historyWeight, historyWeight, pkgIDs)
  66. if err != nil {
  67. return err
  68. }
  69. _, err = ctx.Exec(stmt, args...)
  70. return err
  71. }
  72. func (*ObjectAccessStatDB) UpdateAllAmount(ctx SQLContext, historyWeight float64) error {
  73. stmt, args, err := sqlx.In("update ObjectAccessStat set Amount=Amount*?+Counter*(1-?), Counter = 0", historyWeight, historyWeight)
  74. if err != nil {
  75. return err
  76. }
  77. _, err = ctx.Exec(stmt, args...)
  78. return err
  79. }
  80. func (*ObjectAccessStatDB) DeleteByObjectID(ctx SQLContext, objID cdssdk.ObjectID) error {
  81. _, err := ctx.Exec("delete from ObjectAccessStat where ObjectID=?", objID)
  82. return err
  83. }
  84. func (*ObjectAccessStatDB) BatchDeleteByObjectID(ctx SQLContext, objIDs []cdssdk.ObjectID) error {
  85. if len(objIDs) == 0 {
  86. return nil
  87. }
  88. stmt, args, err := sqlx.In("delete from ObjectAccessStat where ObjectID in (?)", objIDs)
  89. if err != nil {
  90. return err
  91. }
  92. _, err = ctx.Exec(stmt, args...)
  93. return err
  94. }
  95. func (*ObjectAccessStatDB) DeleteInPackage(ctx SQLContext, packageID cdssdk.PackageID) error {
  96. _, err := ctx.Exec("delete ObjectAccessStat from ObjectAccessStat inner join Object on ObjectAccessStat.ObjectID = Object.ObjectID where PackageID = ?", packageID)
  97. return err
  98. }

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