Allow filtering silences by createdBy author (#2718)

This commit adds a `--created-by` argument to the `amtool silence
query` command so that silences can be filtered by the author they
were created with in `amtool silence add --author=<name>`.

Signed-off-by: nre <nre@ableton.com>
This commit is contained in:
Nik Reiman 2021-11-09 13:10:19 +01:00 committed by GitHub
parent b7035556e8
commit 5b825e22a4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 10 additions and 4 deletions

View File

@ -28,10 +28,11 @@ import (
)
type silenceQueryCmd struct {
expired bool
quiet bool
matchers []string
within time.Duration
expired bool
quiet bool
createdBy string
matchers []string
within time.Duration
}
const querySilenceHelp = `Query Alertmanager silences.
@ -84,6 +85,7 @@ func configureSilenceQueryCmd(cc *kingpin.CmdClause) {
queryCmd.Flag("expired", "Show expired silences instead of active").BoolVar(&c.expired)
queryCmd.Flag("quiet", "Only show silence ids").Short('q').BoolVar(&c.quiet)
queryCmd.Flag("created-by", "Show silences that belong to this creator").StringVar(&c.createdBy)
queryCmd.Arg("matcher-groups", "Query filter").StringsVar(&c.matchers)
queryCmd.Flag("within", "Show silences that will expire or have expired within a duration").DurationVar(&c.within)
queryCmd.Action(execWithTimeout(c.query))
@ -127,6 +129,10 @@ func (c *silenceQueryCmd) query(ctx context.Context, _ *kingpin.ParseContext) er
if c.expired && int64(c.within) > 0 && time.Time(*silence.EndsAt).Before(time.Now().UTC().Add(-c.within)) {
continue
}
// Skip silences if the author doesn't match.
if c.createdBy != "" && *silence.CreatedBy != c.createdBy {
continue
}
displaySilences = append(displaySilences, *silence)
}