190 lines
5.1 KiB
Go
190 lines
5.1 KiB
Go
package influxdb
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"regexp"
|
|
"strings"
|
|
)
|
|
|
|
// Updater is general interface to embed
|
|
// with any domain level interface to do crud related ops.
|
|
type Updater interface {
|
|
CRUDLogSetter
|
|
SetID(id ID)
|
|
SetOrgID(id ID)
|
|
SetName(name string)
|
|
SetStatus(status Status)
|
|
SetDescription(description string)
|
|
}
|
|
|
|
// Getter is a general getter interface
|
|
// to return id, orgID...
|
|
type Getter interface {
|
|
GetID() ID
|
|
GetCRUDLog() CRUDLog
|
|
GetOrgID() ID
|
|
GetName() string
|
|
GetStatus() Status
|
|
GetDescription() string
|
|
}
|
|
|
|
// NotificationRule is a *Query* of a *Status Bucket* that returns the *Status*.
|
|
// When warranted by the rules, sends a *Message* to a 3rd Party
|
|
// using the *Notification Endpoint* and stores a receipt in the *Notifications Bucket*.
|
|
type NotificationRule interface {
|
|
Valid() error
|
|
Type() string
|
|
json.Marshaler
|
|
Updater
|
|
Getter
|
|
SetOwnerID(id ID)
|
|
ClearPrivateData()
|
|
GetOwnerID() ID
|
|
SetTaskID(id ID)
|
|
GetTaskID() ID
|
|
GetEndpointID() ID
|
|
GetLimit() *Limit
|
|
GenerateFlux(NotificationEndpoint) (string, error)
|
|
HasTag(key, value string) bool
|
|
}
|
|
|
|
// NotificationRuleStore represents a service for managing notification rule.
|
|
type NotificationRuleStore interface {
|
|
// UserResourceMappingService must be part of all NotificationRuleStore service,
|
|
// for create, search, delete.
|
|
UserResourceMappingService
|
|
// OrganizationService is needed for search filter
|
|
OrganizationService
|
|
|
|
// FindNotificationRuleByID returns a single notification rule by ID.
|
|
FindNotificationRuleByID(ctx context.Context, id ID) (NotificationRule, error)
|
|
|
|
// FindNotificationRules returns a list of notification rules that match filter and the total count of matching notification rules.
|
|
// Additional options provide pagination & sorting.
|
|
FindNotificationRules(ctx context.Context, filter NotificationRuleFilter, opt ...FindOptions) ([]NotificationRule, int, error)
|
|
|
|
// CreateNotificationRule creates a new notification rule and sets b.ID with the new identifier.
|
|
CreateNotificationRule(ctx context.Context, nr NotificationRule, userID ID) error
|
|
|
|
// UpdateNotificationRuleUpdateNotificationRule updates a single notification rule.
|
|
// Returns the new notification rule after update.
|
|
UpdateNotificationRule(ctx context.Context, id ID, nr NotificationRule, userID ID) (NotificationRule, error)
|
|
|
|
// PatchNotificationRule updates a single notification rule with changeset.
|
|
// Returns the new notification rule state after update.
|
|
PatchNotificationRule(ctx context.Context, id ID, upd NotificationRuleUpdate) (NotificationRule, error)
|
|
|
|
// DeleteNotificationRule removes a notification rule by ID.
|
|
DeleteNotificationRule(ctx context.Context, id ID) error
|
|
}
|
|
|
|
// Limit don't notify me more than <limit> times every <limitEvery> seconds.
|
|
// If set, limit cannot be empty.
|
|
type Limit struct {
|
|
Rate int `json:"limit,omitempty"`
|
|
// every seconds.
|
|
Every int `json:"limitEvery,omitempty"`
|
|
}
|
|
|
|
// NotificationRuleFilter represents a set of filter that restrict the returned notification rules.
|
|
type NotificationRuleFilter struct {
|
|
OrgID *ID
|
|
Organization *string
|
|
Tags []Tag
|
|
UserResourceMappingFilter
|
|
}
|
|
|
|
// Tag is a tag key-value pair.
|
|
type Tag struct {
|
|
Key string `json:"key"`
|
|
Value string `json:"value"`
|
|
}
|
|
|
|
// NewTag generates a tag pair from a string in the format key:value.
|
|
func NewTag(s string) (Tag, error) {
|
|
var tagPair Tag
|
|
|
|
matched, err := regexp.MatchString(`^[a-zA-Z0-9_]+:[a-zA-Z0-9_]+$`, s)
|
|
if !matched || err != nil {
|
|
return tagPair, &Error{
|
|
Code: EInvalid,
|
|
Msg: `tag must be in form key:value`,
|
|
}
|
|
}
|
|
|
|
slice := strings.Split(s, ":")
|
|
tagPair.Key = slice[0]
|
|
tagPair.Value = slice[1]
|
|
|
|
return tagPair, nil
|
|
}
|
|
|
|
// Valid returns an error if the tagpair is missing fields
|
|
func (t Tag) Valid() error {
|
|
if t.Key == "" || t.Value == "" {
|
|
return &Error{
|
|
Code: EInvalid,
|
|
Msg: "tag must contain a key and a value",
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// QueryParam converts a Tag to a string query parameter
|
|
func (tp *Tag) QueryParam() string {
|
|
return strings.Join([]string{tp.Key, tp.Value}, ":")
|
|
}
|
|
|
|
// QueryParams Converts NotificationRuleFilter fields to url query params.
|
|
func (f NotificationRuleFilter) QueryParams() map[string][]string {
|
|
qp := map[string][]string{}
|
|
|
|
if f.OrgID != nil {
|
|
qp["orgID"] = []string{f.OrgID.String()}
|
|
}
|
|
|
|
if f.Organization != nil {
|
|
qp["org"] = []string{*f.Organization}
|
|
}
|
|
|
|
qp["tag"] = []string{}
|
|
for _, tp := range f.Tags {
|
|
qp["tag"] = append(qp["tag"], tp.QueryParam())
|
|
}
|
|
|
|
return qp
|
|
}
|
|
|
|
// NotificationRuleUpdate is the set of upgrade fields for patch request.
|
|
type NotificationRuleUpdate struct {
|
|
Name *string `json:"name,omitempty"`
|
|
Description *string `json:"description,omitempty"`
|
|
Status *Status `json:"status,omitempty"`
|
|
}
|
|
|
|
// Valid will verify if the NotificationRuleUpdate is valid.
|
|
func (n *NotificationRuleUpdate) Valid() error {
|
|
if n.Name != nil && *n.Name == "" {
|
|
return &Error{
|
|
Code: EInvalid,
|
|
Msg: "Notification Rule Name can't be empty",
|
|
}
|
|
}
|
|
|
|
if n.Description != nil && *n.Description == "" {
|
|
return &Error{
|
|
Code: EInvalid,
|
|
Msg: "Notification Rule Description can't be empty",
|
|
}
|
|
}
|
|
|
|
if n.Status != nil {
|
|
if err := n.Status.Valid(); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|