mirror of
https://github.com/prometheus/alertmanager
synced 2025-02-06 05:31:44 +00:00
Fix golint issues in config/
This commit is contained in:
parent
16bc5356aa
commit
3e685642c7
@ -161,27 +161,21 @@ func (c *Config) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
return checkOverflow(c.XXX, "config")
|
||||
}
|
||||
|
||||
// DefaultGlobalConfig provides global default values.
|
||||
var DefaultGlobalConfig = GlobalConfig{
|
||||
GroupWait: model.Duration(30 * time.Second),
|
||||
GroupInterval: model.Duration(5 * time.Minute),
|
||||
RepeatInterval: model.Duration(1 * time.Hour),
|
||||
SendResolved: true,
|
||||
|
||||
PagerdutyURL: "https://events.pagerduty.com/generic/2010-04-15/create_event.json",
|
||||
}
|
||||
|
||||
// GlobalConfig defines configuration parameters that are valid globally
|
||||
// unless overwritten.
|
||||
type GlobalConfig struct {
|
||||
GroupWait model.Duration `yaml:"group_wait"`
|
||||
GroupInterval model.Duration `yaml:"group_interval"`
|
||||
RepeatInterval model.Duration `yaml:"repeat_interval"`
|
||||
SendResolved bool `yaml:"send_resolved"`
|
||||
|
||||
SMTPSender string `yaml:"smtp_sender"`
|
||||
Smarthost string `yaml:"smarthost"`
|
||||
SlackURL string `yaml:"slack_url"`
|
||||
PagerdutyURL string `yaml:"pagerduty_url"`
|
||||
}
|
||||
|
||||
// UnmarshalYAML implements the yaml.Unmarshaler interface.
|
||||
func (c *GlobalConfig) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
*c = DefaultGlobalConfig
|
||||
type plain GlobalConfig
|
||||
@ -238,12 +232,25 @@ func (r *Route) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
return checkOverflow(r.XXX, "route")
|
||||
}
|
||||
|
||||
// InhibitRule defines an inhibition rule that mutes alerts that match the
|
||||
// target labels if an alert matching the source labels exists.
|
||||
// Both alerts have to have a set of labels being equal.
|
||||
type InhibitRule struct {
|
||||
SourceMatch map[string]string `yaml:"source_match"`
|
||||
// SourceMatch defines a set of labels that have to equal the given
|
||||
// value for source alerts.
|
||||
SourceMatch map[string]string `yaml:"source_match"`
|
||||
// SourceMatchRE defines pairs like SourceMatch but does regular expression
|
||||
// matching.
|
||||
SourceMatchRE map[string]Regexp `yaml:"source_match_re"`
|
||||
TargetMatch map[string]string `yaml:"target_match"`
|
||||
// TargetMatch defines a set of labels that have to equal the given
|
||||
// value for target alerts.
|
||||
TargetMatch map[string]string `yaml:"target_match"`
|
||||
// TargetMatchRE defines pairs like TargetMatch but does regular expression
|
||||
// matching.
|
||||
TargetMatchRE map[string]Regexp `yaml:"target_match_re"`
|
||||
Equal model.LabelNames `yaml:"equal"`
|
||||
// A set of labels that must be equal between the source and target alert
|
||||
// for them to be a match.
|
||||
Equal model.LabelNames `yaml:"equal"`
|
||||
|
||||
// Catches all undefined fields and must be empty after parsing.
|
||||
XXX map[string]interface{} `yaml:",inline"`
|
||||
@ -283,9 +290,9 @@ func (r *InhibitRule) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
return checkOverflow(r.XXX, "inhibit rule")
|
||||
}
|
||||
|
||||
// Receiver configuration provides configuration on how to contact
|
||||
// a receiver.
|
||||
// Receiver configuration provides configuration on how to contact a receiver.
|
||||
type Receiver struct {
|
||||
// A unique identifier for this receiver.
|
||||
Name string `yaml:"name"`
|
||||
|
||||
PagerdutyConfigs []*PagerdutyConfig `yaml:"pagerduty_configs"`
|
||||
|
@ -18,12 +18,14 @@ import (
|
||||
)
|
||||
|
||||
var (
|
||||
// DefaultHipchatConfig defines default values for Hipchat configurations.
|
||||
DefaultHipchatConfig = HipchatConfig{
|
||||
ColorFiring: "purple",
|
||||
ColorResolved: "green",
|
||||
MessageFormat: HipchatFormatHTML,
|
||||
}
|
||||
|
||||
// DefaultSlackConfig defines default values for Slack configurations.
|
||||
DefaultSlackConfig = SlackConfig{
|
||||
ColorFiring: "warning",
|
||||
ColorResolved: "good",
|
||||
@ -37,6 +39,7 @@ var (
|
||||
},
|
||||
}
|
||||
|
||||
// DefaultEmailConfig defines default values for Email configurations.
|
||||
DefaultEmailConfig = EmailConfig{
|
||||
Templates: EmailTemplates{
|
||||
Header: "email.default.header",
|
||||
@ -44,6 +47,7 @@ var (
|
||||
},
|
||||
}
|
||||
|
||||
// DefaultPagerdutyConfig defines default values for PagerDuty configurations.
|
||||
DefaultPagerdutyConfig = PagerdutyConfig{
|
||||
Templates: PagerdutyTemplates{
|
||||
Description: "pagerduty.default.description",
|
||||
@ -51,7 +55,7 @@ var (
|
||||
}
|
||||
)
|
||||
|
||||
// Configuration for notification via PagerDuty.
|
||||
// PagerdutyConfig configures notifications via PagerDuty.
|
||||
type PagerdutyConfig struct {
|
||||
ServiceKey string `yaml:"service_key"`
|
||||
URL string `yaml:"url"`
|
||||
@ -62,6 +66,7 @@ type PagerdutyConfig struct {
|
||||
XXX map[string]interface{} `yaml:",inline"`
|
||||
}
|
||||
|
||||
// PagerdutyTemplates references template names used for PagerDuty.
|
||||
type PagerdutyTemplates struct {
|
||||
Description string
|
||||
}
|
||||
@ -79,7 +84,7 @@ func (c *PagerdutyConfig) UnmarshalYAML(unmarshal func(interface{}) error) error
|
||||
return checkOverflow(c.XXX, "pagerduty config")
|
||||
}
|
||||
|
||||
// Configuration for notification via mail.
|
||||
// EmailConfig configures notifications via mail.
|
||||
type EmailConfig struct {
|
||||
// Email address to notify.
|
||||
Email string `yaml:"email"`
|
||||
@ -92,6 +97,7 @@ type EmailConfig struct {
|
||||
XXX map[string]interface{} `yaml:",inline"`
|
||||
}
|
||||
|
||||
// EmailTemplates references template names used for email.
|
||||
type EmailTemplates struct {
|
||||
Header string `yaml:"header"`
|
||||
HTML string `yaml:"html"`
|
||||
@ -110,7 +116,7 @@ func (c *EmailConfig) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
return checkOverflow(c.XXX, "email config")
|
||||
}
|
||||
|
||||
// Configuration for notification via pushover.net.
|
||||
// PushoverConfig configures notifications via PushOver.
|
||||
type PushoverConfig struct {
|
||||
// Pushover token.
|
||||
Token string `yaml:"token"`
|
||||
@ -137,6 +143,7 @@ func (c *PushoverConfig) UnmarshalYAML(unmarshal func(interface{}) error) error
|
||||
return checkOverflow(c.XXX, "pushover config")
|
||||
}
|
||||
|
||||
// HipchatFormat defines text formats for Hipchat.
|
||||
type HipchatFormat string
|
||||
|
||||
const (
|
||||
@ -144,7 +151,7 @@ const (
|
||||
HipchatFormatText HipchatFormat = "text"
|
||||
)
|
||||
|
||||
// Configuration for notification via HipChat.
|
||||
// HipchatConfig configures notifications via Hipchat.
|
||||
// https://www.hipchat.com/docs/apiv2/method/send_room_notification
|
||||
type HipchatConfig struct {
|
||||
// HipChat auth token, (https://www.hipchat.com/docs/api/auth).
|
||||
@ -186,7 +193,7 @@ func (c *HipchatConfig) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
return checkOverflow(c.XXX, "hipchat config")
|
||||
}
|
||||
|
||||
// Configuration for notification via Slack.
|
||||
// SlackConfig configures notifications via Slack.
|
||||
type SlackConfig struct {
|
||||
URL string `yaml:"url"`
|
||||
|
||||
@ -203,6 +210,7 @@ type SlackConfig struct {
|
||||
XXX map[string]interface{} `yaml:",inline"`
|
||||
}
|
||||
|
||||
// SlackTemplates references template names used for Slack.
|
||||
type SlackTemplates struct {
|
||||
Title string `yaml:"title"`
|
||||
TitleLink string `yaml:"title_link"`
|
||||
@ -224,7 +232,7 @@ func (c *SlackConfig) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
||||
return checkOverflow(c.XXX, "slack config")
|
||||
}
|
||||
|
||||
// Configuration for notification via Flowdock.
|
||||
// FlowdockConfig configures notifications via Flowdock.
|
||||
type FlowdockConfig struct {
|
||||
// Flowdock flow API token.
|
||||
APIToken string `yaml:"api_token"`
|
||||
@ -254,7 +262,7 @@ func (c *FlowdockConfig) UnmarshalYAML(unmarshal func(interface{}) error) error
|
||||
return checkOverflow(c.XXX, "flowdock config")
|
||||
}
|
||||
|
||||
// Configuration for notification via generic webhook.
|
||||
// WebhookConfig configures notifications via a generic webhook.
|
||||
type WebhookConfig struct {
|
||||
// URL to send POST request to.
|
||||
URL string `yaml:"url"`
|
||||
|
Loading…
Reference in New Issue
Block a user