package db import ( "gitlink.org.cn/cloudream/jcs-pub/client/types" "gorm.io/gorm" "gorm.io/gorm/clause" ) type PackageAccessStatDB struct { *DB } func (db *DB) PackageAccessStat() *PackageAccessStatDB { return &PackageAccessStatDB{db} } func (*PackageAccessStatDB) Get(ctx SQLContext, pkgID types.PackageID, spaceID types.UserSpaceID) (types.PackageAccessStat, error) { var ret types.PackageAccessStat err := ctx.Table("PackageAccessStat").Where("PackageID = ? AND UserSpaceID = ?", pkgID, spaceID).First(&ret).Error return ret, err } func (*PackageAccessStatDB) GetByPackageID(ctx SQLContext, pkgID types.PackageID) ([]types.PackageAccessStat, error) { var ret []types.PackageAccessStat err := ctx.Table("PackageAccessStat").Where("PackageID = ?", pkgID).Find(&ret).Error return ret, err } func (*PackageAccessStatDB) BatchGetByPackageID(ctx SQLContext, pkgIDs []types.PackageID) ([]types.PackageAccessStat, error) { if len(pkgIDs) == 0 { return nil, nil } var ret []types.PackageAccessStat err := ctx.Table("PackageAccessStat").Where("PackageID IN (?)", pkgIDs).Find(&ret).Error return ret, err } func (*PackageAccessStatDB) BatchAddCounter(ctx SQLContext, entries []AddAccessStatEntry) error { if len(entries) == 0 { return nil } accs := make([]types.PackageAccessStat, len(entries)) for i, e := range entries { accs[i] = types.PackageAccessStat{ PackageID: e.PackageID, UserSpaceID: e.UserSpaceID, Counter: e.Counter, } } return ctx.Clauses(clause.OnConflict{ Columns: []clause.Column{{Name: "PackageID"}, {Name: "UserSpaceID"}}, DoUpdates: clause.Assignments(map[string]any{ "Counter": gorm.Expr("Counter + values(Counter)"), }), }).Table("PackageAccessStat").Create(&accs).Error } func (*PackageAccessStatDB) BatchUpdateAmount(ctx SQLContext, pkgIDs []types.PackageID, historyWeight float64) error { if len(pkgIDs) == 0 { return nil } sql := "UPDATE PackageAccessStat SET Amount = Amount * ? + Counter * (1 - ?), Counter = 0 WHERE PackageID IN (?)" return ctx.Exec(sql, historyWeight, historyWeight, pkgIDs).Error } func (*PackageAccessStatDB) UpdateAllAmount(ctx SQLContext, historyWeight float64) error { sql := "UPDATE PackageAccessStat SET Amount = Amount * ? + Counter * (1 - ?), Counter = 0" return ctx.Exec(sql, historyWeight, historyWeight).Error } func (*PackageAccessStatDB) DeleteByPackageID(ctx SQLContext, pkgID types.PackageID) error { return ctx.Table("PackageAccessStat").Where("PackageID = ?", pkgID).Delete(&types.PackageAccessStat{}).Error } func (*PackageAccessStatDB) DeleteByUserSpaceID(ctx SQLContext, spaceID types.UserSpaceID) error { return ctx.Table("PackageAccessStat").Where("UserSpaceID = ?", spaceID).Delete(&types.PackageAccessStat{}).Error }