influxdb/dbrp_mapping.go

96 lines
3.1 KiB
Go
Raw Normal View History

package platform
import (
2018-08-01 18:54:32 +00:00
"bytes"
"context"
"errors"
"strings"
"unicode"
)
// DBRPMappingService provides a mapping of cluster, database and retention policy to an organization ID and bucket ID.
type DBRPMappingService interface {
// FindBy returns the dbrp mapping the for cluster, db and rp.
FindBy(ctx context.Context, cluster, db, rp string) (*DBRPMapping, error)
// Find returns the first dbrp mapping the matches the filter.
Find(ctx context.Context, filter DBRPMappingFilter) (*DBRPMapping, error)
// FindMany returns a list of dbrp mappings that match filter and the total count of matching dbrp mappings.
FindMany(ctx context.Context, filter DBRPMappingFilter, opt ...FindOptions) ([]*DBRPMapping, int, error)
// Create creates a new dbrp mapping, if a different mapping exists an error is returned.
Create(ctx context.Context, dbrpMap *DBRPMapping) error
// Delete removes a dbrp mapping.
// Deleting a mapping that does not exists is not an error.
Delete(ctx context.Context, cluster, db, rp string) error
}
// DBRPMapping represents a mapping of a cluster, database and retention policy to an organization ID and bucket ID.
type DBRPMapping struct {
Cluster string `json:"cluster"`
Database string `json:"database"`
RetentionPolicy string `json:"retention_policy"`
// Default indicates if this mapping is the default for the cluster and database.
Default bool `json:"default"`
OrganizationID ID `json:"organization_id"`
BucketID ID `json:"bucket_id"`
}
// Validate reports any validation errors for the mapping.
func (m DBRPMapping) Validate() error {
if !validName(m.Cluster) {
return errors.New("Cluster must contain at least one character and only be letters, numbers, '_', '-', and '.'")
}
if !validName(m.Database) {
return errors.New("Database must contain at least one character and only be letters, numbers, '_', '-', and '.'")
}
if !validName(m.RetentionPolicy) {
return errors.New("RetentionPolicy must contain at least one character and only be letters, numbers, '_', '-', and '.'")
}
2018-08-01 18:54:32 +00:00
if len(m.OrganizationID) == 0 {
return errors.New("OrganizationID is required")
}
2018-08-01 18:54:32 +00:00
if len(m.BucketID) == 0 {
return errors.New("BucketID is required")
}
return nil
}
// validName checks to see if the given name can would be valid for DB/RP name
func validName(name string) bool {
for _, r := range name {
if !unicode.IsPrint(r) {
return false
}
}
2018-08-01 18:54:32 +00:00
return name != "" &&
name != "." &&
name != ".." &&
!strings.ContainsAny(name, `/\`)
}
// Equal checks if the two mappings are identical.
func (m *DBRPMapping) Equal(o *DBRPMapping) bool {
if m == o {
return true
}
if m == nil || o == nil {
return false
}
return m.Cluster == o.Cluster &&
m.Database == o.Database &&
m.RetentionPolicy == o.RetentionPolicy &&
m.Default == o.Default &&
2018-08-01 18:54:32 +00:00
bytes.Equal(m.OrganizationID, o.OrganizationID) &&
bytes.Equal(m.BucketID, o.BucketID)
}
// DBRPMappingFilter represents a set of filters that restrict the returned results by cluster, database and retention policy.
type DBRPMappingFilter struct {
Cluster *string
Database *string
RetentionPolicy *string
Default *bool
}