mirror of
https://github.com/prometheus/alertmanager
synced 2025-01-28 17:23:06 +00:00
a6d10bd5bc
* Copy latest golangci-lint files from Prometheus Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Use grafana/regexp over stdlib regexp Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Fix typos in comments Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Fix goimports complains in import sorting Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * gofumpt all Go files Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Update naming to comply with revive linter Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * config: Fix error messages to be lower case Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * test/cli: Fix error messages to be lower case Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * .golangci.yaml: Remove obsolete space Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * config: Fix expected victorOps error Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Use stdlib regexp Signed-off-by: Matthias Loibl <mail@matthiasloibl.com> * Clean up Go modules Signed-off-by: Matthias Loibl <mail@matthiasloibl.com>
87 lines
2.8 KiB
Go
87 lines
2.8 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 provider
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/prometheus/common/model"
|
|
|
|
"github.com/prometheus/alertmanager/types"
|
|
)
|
|
|
|
// ErrNotFound is returned if a provider cannot find a requested item.
|
|
var ErrNotFound = fmt.Errorf("item not found")
|
|
|
|
// Iterator provides the functions common to all iterators. To be useful, a
|
|
// specific iterator interface (e.g. AlertIterator) has to be implemented that
|
|
// provides a Next method.
|
|
type Iterator interface {
|
|
// Err returns the current error. It is not safe to call it concurrently
|
|
// with other iterator methods or while reading from a channel returned
|
|
// by the iterator.
|
|
Err() error
|
|
// Close must be called to release resources once the iterator is not
|
|
// used anymore.
|
|
Close()
|
|
}
|
|
|
|
// AlertIterator is an Iterator for Alerts.
|
|
type AlertIterator interface {
|
|
Iterator
|
|
// Next returns a channel that will be closed once the iterator is
|
|
// exhausted. It is not necessary to exhaust the iterator but Close must
|
|
// be called in any case to release resources used by the iterator (even
|
|
// if the iterator is exhausted).
|
|
Next() <-chan *types.Alert
|
|
}
|
|
|
|
// NewAlertIterator returns a new AlertIterator based on the generic alertIterator type
|
|
func NewAlertIterator(ch <-chan *types.Alert, done chan struct{}, err error) AlertIterator {
|
|
return &alertIterator{
|
|
ch: ch,
|
|
done: done,
|
|
err: err,
|
|
}
|
|
}
|
|
|
|
// alertIterator implements AlertIterator. So far, this one fits all providers.
|
|
type alertIterator struct {
|
|
ch <-chan *types.Alert
|
|
done chan struct{}
|
|
err error
|
|
}
|
|
|
|
func (ai alertIterator) Next() <-chan *types.Alert {
|
|
return ai.ch
|
|
}
|
|
|
|
func (ai alertIterator) Err() error { return ai.err }
|
|
func (ai alertIterator) Close() { close(ai.done) }
|
|
|
|
// Alerts gives access to a set of alerts. All methods are goroutine-safe.
|
|
type Alerts interface {
|
|
// Subscribe returns an iterator over active alerts that have not been
|
|
// resolved and successfully notified about.
|
|
// They are not guaranteed to be in chronological order.
|
|
Subscribe() AlertIterator
|
|
// GetPending returns an iterator over all alerts that have
|
|
// pending notifications.
|
|
GetPending() AlertIterator
|
|
// Get returns the alert for a given fingerprint.
|
|
Get(model.Fingerprint) (*types.Alert, error)
|
|
// Put adds the given set of alerts to the set.
|
|
Put(...*types.Alert) error
|
|
}
|