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 2.7 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package db
  2. import (
  3. "github.com/jmoiron/sqlx"
  4. cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
  5. "gitlink.org.cn/cloudream/storage/common/pkgs/db/model"
  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) (model.ObjectAccessStat, error) {
  15. var ret model.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) ([]model.ObjectAccessStat, error) {
  20. var ret []model.ObjectAccessStat
  21. err := sqlx.Select(ctx, &ret, "select * from ObjectAccessStat where ObjectID=?", objID)
  22. return ret, err
  23. }
  24. func (*ObjectAccessStatDB) BatchAddCounter(ctx SQLContext, entries []coormq.AddAccessStatEntry) error {
  25. sql := "insert into ObjectAccessStat(ObjectID, NodeID, Counter, Amount) " +
  26. "values(:ObjectID, :NodeID, :Counter, 0) as new" +
  27. "on duplicate key update Counter=Counter+new.Counter"
  28. err := BatchNamedExec(ctx, sql, 4, entries, nil)
  29. return err
  30. }
  31. func (*ObjectAccessStatDB) BatchUpdateAmount(ctx SQLContext, objIDs []cdssdk.ObjectID, historyWeight float64) error {
  32. stmt, args, err := sqlx.In("update ObjectAccessStat set Amount=Amount*?+Counter*(1-?), Counter = 0 where ObjectID in (?)", historyWeight, historyWeight, objIDs)
  33. if err != nil {
  34. return err
  35. }
  36. _, err = ctx.Exec(stmt, args...)
  37. return err
  38. }
  39. func (*ObjectAccessStatDB) UpdateAllAmount(ctx SQLContext, historyWeight float64) error {
  40. stmt, args, err := sqlx.In("update ObjectAccessStat set Amount=Amount*?+Counter*(1-?), Counter = 0", historyWeight, historyWeight)
  41. if err != nil {
  42. return err
  43. }
  44. _, err = ctx.Exec(stmt, args...)
  45. return err
  46. }
  47. func (*ObjectAccessStatDB) DeleteByObjectID(ctx SQLContext, objID cdssdk.ObjectID) error {
  48. _, err := ctx.Exec("delete from ObjectAccessStat where ObjectID=?", objID)
  49. return err
  50. }
  51. func (*ObjectAccessStatDB) BatchDeleteByObjectID(ctx SQLContext, objIDs []cdssdk.ObjectID) error {
  52. stmt, args, err := sqlx.In("delete from ObjectAccessStat where ObjectID in (?)", objIDs)
  53. if err != nil {
  54. return err
  55. }
  56. _, err = ctx.Exec(stmt, args...)
  57. return err
  58. }
  59. func (*ObjectAccessStatDB) DeleteInPackage(ctx SQLContext, packageID cdssdk.PackageID) error {
  60. _, err := ctx.Exec("delete ObjectAccessStat from ObjectAccessStat inner join Object on ObjectAccessStat.ObjectID = Object.ObjectID where PackageID = ?", packageID)
  61. return err
  62. }

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