2026-02-05 16:00:34 +08:00
|
|
|
|
package service
|
|
|
|
|
|
|
|
|
|
|
|
import "context"
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// UserGroupRateEntry 分组下用户专属倍率/RPM 条目。
|
|
|
|
|
|
// RateMultiplier 与 RPMOverride 均为指针以支持"未设置"语义(NULL)。
|
2026-03-12 23:37:36 +08:00
|
|
|
|
type UserGroupRateEntry struct {
|
2026-04-23 03:33:52 +08:00
|
|
|
|
UserID int64 `json:"user_id"`
|
|
|
|
|
|
UserName string `json:"user_name"`
|
|
|
|
|
|
UserEmail string `json:"user_email"`
|
|
|
|
|
|
UserNotes string `json:"user_notes"`
|
|
|
|
|
|
UserStatus string `json:"user_status"`
|
|
|
|
|
|
RateMultiplier *float64 `json:"rate_multiplier,omitempty"`
|
|
|
|
|
|
RPMOverride *int `json:"rpm_override,omitempty"`
|
2026-03-12 23:37:36 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// GroupRateMultiplierInput 批量设置分组倍率的输入条目
|
|
|
|
|
|
type GroupRateMultiplierInput struct {
|
|
|
|
|
|
UserID int64 `json:"user_id"`
|
|
|
|
|
|
RateMultiplier float64 `json:"rate_multiplier"`
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// GroupRPMOverrideInput 批量设置分组 RPM override 的输入条目。
|
|
|
|
|
|
// RPMOverride 为 *int 以支持清除(nil)语义。
|
|
|
|
|
|
type GroupRPMOverrideInput struct {
|
|
|
|
|
|
UserID int64 `json:"user_id"`
|
|
|
|
|
|
RPMOverride *int `json:"rpm_override"`
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// UserGroupRateRepository 用户专属分组倍率/RPM 仓储接口。
|
|
|
|
|
|
// 允许管理员为特定用户设置分组的专属计费倍率与 RPM 上限,覆盖分组默认值。
|
2026-02-05 16:00:34 +08:00
|
|
|
|
type UserGroupRateRepository interface {
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// GetByUserID 获取用户所有专属分组 rate_multiplier(仅返回非 NULL 的条目)
|
2026-02-05 16:00:34 +08:00
|
|
|
|
GetByUserID(ctx context.Context, userID int64) (map[int64]float64, error)
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// GetByUserAndGroup 获取用户在特定分组的专属 rate_multiplier(NULL 返回 nil)
|
2026-02-05 16:00:34 +08:00
|
|
|
|
GetByUserAndGroup(ctx context.Context, userID, groupID int64) (*float64, error)
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// GetRPMOverrideByUserAndGroup 获取用户在特定分组的 rpm_override(NULL 返回 nil)
|
|
|
|
|
|
GetRPMOverrideByUserAndGroup(ctx context.Context, userID, groupID int64) (*int, error)
|
|
|
|
|
|
|
|
|
|
|
|
// GetByGroupID 获取指定分组下所有用户的专属配置(rate 与 rpm_override 任一非 NULL 即返回)
|
2026-03-12 23:37:36 +08:00
|
|
|
|
GetByGroupID(ctx context.Context, groupID int64) ([]UserGroupRateEntry, error)
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// SyncUserGroupRates 同步用户的分组专属倍率;nil 表示清空该分组的 rate_multiplier
|
2026-02-05 16:00:34 +08:00
|
|
|
|
SyncUserGroupRates(ctx context.Context, userID int64, rates map[int64]*float64) error
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// SyncGroupRateMultipliers 批量同步分组的用户专属倍率(替换整组 rate 部分)
|
2026-03-12 23:37:36 +08:00
|
|
|
|
SyncGroupRateMultipliers(ctx context.Context, groupID int64, entries []GroupRateMultiplierInput) error
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// SyncGroupRPMOverrides 批量同步分组的用户专属 RPM(替换整组 rpm_override 部分)。
|
|
|
|
|
|
// 条目中 RPMOverride 为 nil 时清空对应行的 rpm_override;非 nil 时 upsert。
|
|
|
|
|
|
SyncGroupRPMOverrides(ctx context.Context, groupID int64, entries []GroupRPMOverrideInput) error
|
|
|
|
|
|
|
|
|
|
|
|
// ClearGroupRPMOverrides 清空指定分组的所有 rpm_override(整组 rpm 部分归 NULL)
|
|
|
|
|
|
ClearGroupRPMOverrides(ctx context.Context, groupID int64) error
|
|
|
|
|
|
|
|
|
|
|
|
// DeleteByGroupID 删除指定分组的所有用户专属条目(分组删除时调用)
|
2026-02-05 16:00:34 +08:00
|
|
|
|
DeleteByGroupID(ctx context.Context, groupID int64) error
|
|
|
|
|
|
|
2026-04-23 03:33:52 +08:00
|
|
|
|
// DeleteByUserID 删除指定用户的所有专属条目(用户删除时调用)
|
2026-02-05 16:00:34 +08:00
|
|
|
|
DeleteByUserID(ctx context.Context, userID int64) error
|
|
|
|
|
|
}
|