Documentation
¶
Index ¶
- func CurrentDate() string
- type LiveUsageTracker
- type NoopUsageTracker
- type Store
- func (s *Store) CountAgentsByUser(ctx context.Context, userID string) (int, error)
- func (s *Store) CountDomainsByUser(ctx context.Context, userID string) (int, error)
- func (s *Store) GetStorageBytes(ctx context.Context, userID string) (int64, error)
- func (s *Store) GetUsageSummary(ctx context.Context, userID, bucketDate string) (*UsageSummary, error)
- func (s *Store) IncrementUsageSummary(ctx context.Context, userID, bucketDate, direction string) error
- func (s *Store) MessagesThisMonth(ctx context.Context, userID string) (int, error)
- func (s *Store) RecordUsageEvent(ctx context.Context, event *UsageEvent) error
- type UsageEvent
- type UsageSummary
- type UsageTracker
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CurrentDate ¶
func CurrentDate() string
CurrentDate returns today's date as a string in YYYY-MM-DD format.
Types ¶
type LiveUsageTracker ¶
type LiveUsageTracker struct {
// contains filtered or unexported fields
}
LiveUsageTracker is the real implementation backed by the billing store.
func NewUsageTracker ¶
func NewUsageTracker(store *Store) *LiveUsageTracker
func (*LiveUsageTracker) RecordAndCheck ¶
type NoopUsageTracker ¶
type NoopUsageTracker struct{}
NoopUsageTracker always allows everything. Used when billing is disabled.
func NewNoopUsageTracker ¶
func NewNoopUsageTracker() *NoopUsageTracker
func (*NoopUsageTracker) RecordAndCheck ¶
type Store ¶
type Store struct {
// contains filtered or unexported fields
}
func (*Store) CountAgentsByUser ¶
func (*Store) CountDomainsByUser ¶ added in v0.3.0
CountDomainsByUser returns the number of domains owned by the user. Used by the limits enforcer to check max_domains caps. Counts every row in domains regardless of verification status; an unverified domain still consumes a slot until the user deletes it.
func (*Store) GetStorageBytes ¶ added in v0.3.0
GetStorageBytes returns the user's current materialized storage bytes from account_usage. Returns 0 with no error if the user has no row yet — the trigger in migration 016 lazily creates the row on first message insert, so a pre-message user legitimately has 0 storage.
func (*Store) GetUsageSummary ¶
func (*Store) IncrementUsageSummary ¶
func (*Store) MessagesThisMonth ¶ added in v0.3.0
MessagesThisMonth returns the user's inbound+outbound message count for the current UTC calendar month, summed from usage_summaries. Returns 0 with no error if the user has no rows yet. The reference is time.Now().UTC() so server clocks crossing midnight UTC roll the counter consistently with the daily bucket_date written by IncrementUsageSummary.
func (*Store) RecordUsageEvent ¶
func (s *Store) RecordUsageEvent(ctx context.Context, event *UsageEvent) error
type UsageEvent ¶
type UsageSummary ¶
type UsageTracker ¶
type UsageTracker interface {
// RecordAndCheck records a usage event. Always returns true.
RecordAndCheck(ctx context.Context, userID, agentID, domain, direction string) (allowed bool, err error)
}
UsageTracker records usage events. Always allows the action (no quota enforcement).