Introduce NotificationChannelStorage, NotificationPreferenceStorage, NotificationStateStorage, and NotificationRecordStorage interfaces with KV-based implementations. Extend the Storage composite interface and add migration 10 (no-op for KV prefix-based storage). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
71 lines
3.1 KiB
Go
71 lines
3.1 KiB
Go
// This file is part of the happyDomain (R) project.
|
|
// Copyright (c) 2020-2026 happyDomain
|
|
// Authors: Pierre-Olivier Mercier, et al.
|
|
//
|
|
// This program is offered under a commercial and under the AGPL license.
|
|
// For commercial licensing, contact us at <contact@happydomain.org>.
|
|
//
|
|
// For AGPL licensing:
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Affero General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package notification
|
|
|
|
import (
|
|
"time"
|
|
|
|
"git.happydns.org/happyDomain/model"
|
|
)
|
|
|
|
// NotificationChannelStorage provides persistence for notification channels.
|
|
type NotificationChannelStorage interface {
|
|
ListChannelsByUser(userId happydns.Identifier) ([]*happydns.NotificationChannel, error)
|
|
GetChannel(channelId happydns.Identifier) (*happydns.NotificationChannel, error)
|
|
CreateChannel(ch *happydns.NotificationChannel) error
|
|
UpdateChannel(ch *happydns.NotificationChannel) error
|
|
DeleteChannel(channelId happydns.Identifier) error
|
|
}
|
|
|
|
// NotificationPreferenceStorage provides persistence for notification preferences.
|
|
type NotificationPreferenceStorage interface {
|
|
ListPreferencesByUser(userId happydns.Identifier) ([]*happydns.NotificationPreference, error)
|
|
GetPreference(prefId happydns.Identifier) (*happydns.NotificationPreference, error)
|
|
CreatePreference(pref *happydns.NotificationPreference) error
|
|
UpdatePreference(pref *happydns.NotificationPreference) error
|
|
DeletePreference(prefId happydns.Identifier) error
|
|
}
|
|
|
|
// NotificationStateStorage provides persistence for notification state tracking.
|
|
type NotificationStateStorage interface {
|
|
GetState(checkerID string, target happydns.CheckTarget, userId happydns.Identifier) (*happydns.NotificationState, error)
|
|
PutState(state *happydns.NotificationState) error
|
|
DeleteState(checkerID string, target happydns.CheckTarget, userId happydns.Identifier) error
|
|
ListStatesByUser(userId happydns.Identifier) ([]*happydns.NotificationState, error)
|
|
}
|
|
|
|
// NotificationRecordStorage provides persistence for notification audit records.
|
|
type NotificationRecordStorage interface {
|
|
CreateRecord(rec *happydns.NotificationRecord) error
|
|
ListRecordsByUser(userId happydns.Identifier, limit int) ([]*happydns.NotificationRecord, error)
|
|
DeleteRecordsOlderThan(before time.Time) error
|
|
}
|
|
|
|
// UserGetter is a narrow interface for loading users in the notification context.
|
|
type UserGetter interface {
|
|
GetUser(id happydns.Identifier) (*happydns.User, error)
|
|
}
|
|
|
|
// DomainGetter is a narrow interface for loading domains in the notification context.
|
|
type DomainGetter interface {
|
|
GetDomain(id happydns.Identifier) (*happydns.Domain, error)
|
|
}
|