alertmanager/provider/provider.go
2015-09-25 14:38:07 +02:00

62 lines
1.9 KiB
Go

// Copyright 2015 Prometheus Team
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package manager
import (
"github.com/prometheus/common/model"
"github.com/prometheus/alertmanager/config"
"github.com/prometheus/alertmanager/types"
)
// Alerts gives access to a set of alerts.
type Alerts interface {
// Iter returns a channel on which all active alerts from the
// beginning of time are sent. They are not guaranteed to be in
// chronological order.
IterActive() <-chan *types.Alert
// Get returns the alert for a given fingerprint.
Get(model.Fingerprint) (*types.Alert, error)
// Put adds the given alert to the set.
Put(*types.Alert) error
}
// Silences gives access to silences.
type Silences interface {
// The Silences provider must implement the Silencer interface
// for all its silences. The data provider may have access to an
// optimized view of the data to perform this evaluation.
Silencer
// All returns all existing silences.
All() []*Silence
// Set a new silence.
Set(*Silence) error
// Del removes a silence.
Del(model.Fingerprint) error
// Get a silence associated with a fingerprint.
Get(model.Fingerprint) (*Silence, error)
}
// Reloadable is a component that can change its state based
// on a new configuration.
type Reloadable interface {
ApplyConfig(*config.Config)
}
type Config interface {
// Reload initiates a configuration reload.
Reload(...Reloadable) error
}