From 73208fff8c51234814758e8aafed114751daeff9 Mon Sep 17 00:00:00 2001 From: Todd Campbell Date: Wed, 27 Jan 2021 09:03:01 -0500 Subject: [PATCH] * Changed tags from hard-coded list to templates settable via argument * Moved test files into tests directory to clean up top level directory * Updated all modules with 'go get -u' and 'go mod tidy' * README updates and cleanup * Lint GitHub Action Signed-off-by: Todd Campbell --- .github/workflows/lint.yml | 16 ++ CHANGELOG.md | 9 + README.md | 45 ++--- go.mod | 27 +-- go.sum | 81 ++++++--- main.go | 156 ++++++++++-------- main_test.go | 22 +-- test.all.events.sh | 29 ---- event.json => tests/event.json | 0 .../event.resolved.json | 0 .../event.withAnnotations.json | 0 .../event.withAnnotations.resolved.json | 0 .../event_from_proxy.json | 0 .../event_from_proxy.resolved.json | 0 event_new.json => tests/event_new.json | 0 .../event_new.resolved.json | 0 .../event_with_opsgenie_priority.check.json | 0 ...with_opsgenie_priority.check.resolved.json | 0 .../event_with_opsgenie_priority.json | 0 ...event_with_opsgenie_priority.resolved.json | 0 tests/test.all.events.sh | 29 ++++ 21 files changed, 252 insertions(+), 162 deletions(-) create mode 100644 .github/workflows/lint.yml delete mode 100644 test.all.events.sh rename event.json => tests/event.json (100%) rename event.resolved.json => tests/event.resolved.json (100%) rename event.withAnnotations.json => tests/event.withAnnotations.json (100%) rename event.withAnnotations.resolved.json => tests/event.withAnnotations.resolved.json (100%) rename event_from_proxy.json => tests/event_from_proxy.json (100%) rename event_from_proxy.resolved.json => tests/event_from_proxy.resolved.json (100%) rename event_new.json => tests/event_new.json (100%) rename event_new.resolved.json => tests/event_new.resolved.json (100%) rename event_with_opsgenie_priority.check.json => tests/event_with_opsgenie_priority.check.json (100%) rename event_with_opsgenie_priority.check.resolved.json => tests/event_with_opsgenie_priority.check.resolved.json (100%) rename event_with_opsgenie_priority.json => tests/event_with_opsgenie_priority.json (100%) rename event_with_opsgenie_priority.resolved.json => tests/event_with_opsgenie_priority.resolved.json (100%) create mode 100644 tests/test.all.events.sh diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml new file mode 100644 index 0000000..0891e1f --- /dev/null +++ b/.github/workflows/lint.yml @@ -0,0 +1,16 @@ +name: Go Lint + +on: [push, pull_request] + +jobs: + test: + name: Lint + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [ubuntu-latest] + steps: + - name: Checkout code + uses: actions/checkout@v2 + - name: Run golangci-lint + uses: actions-contrib/golangci-lint@v1 diff --git a/CHANGELOG.md b/CHANGELOG.md index de5448c..a454b33 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,15 @@ Versioning](http://semver.org/spec/v2.0.0.html). ## Unreleased +### Changed +- Changed tags from hard-coded list to templates settable via argument +- Moved test files into tests directory to clean up top level directory +- Updated all modules with 'go get -u' and 'go mod tidy' +- README updates and cleanup + +### Added +- Lint GitHub Action + ## [0.8.0] - 2020-12-01 ### Changed diff --git a/README.md b/README.md index 3003466..20db7ab 100644 --- a/README.md +++ b/README.md @@ -7,13 +7,16 @@ ## Table of Contents - [Overview](#overview) -- [Files](#files) - [Usage examples](#usage-examples) + - [Help output](#help-output) + - [Templates](#templates) + - [To use Opsgenie Priority](#to-use-opsgenie-priority) + - [To use alert actions](#to-use-alert-actions) - [Configuration](#configuration) - [Asset registration](#asset-registration) - [Handler definition](#handler-definition) - - [Environment Variables](#environment-variables) - - [Argument Annotations](#argument-annotations) + - [Environment variables](#environment-variables) + - [Argument annotations](#argument-annotations) - [Proxy support](#proxy-support) - [Installation from source](#installation-from-source) - [Contributing](#contributing) @@ -24,13 +27,13 @@ The Sensu Go OpsGenie Handler is a [Sensu Event Handler][3] which manages [OpsGenie][2] incidents, for alerting operators. With this handler, [Sensu][1] can trigger OpsGenie incidents. -This handler was inspired by [pagerduty plugin][6]. +To configure OpsGenie Sensu Integration follow these first part in [OpsGenie Docs][5]. -## Files +This handler was inspired by [pagerduty plugin][6]. -N/A +## Usage examples -## Usage Examples +### Help output Help: ``` @@ -58,6 +61,7 @@ Flags: -F, --fullDetails Include the more details to send to OpsGenie like proxy_entity_name, occurrences and agent details arch and os -w, --withAnnotations Include the event.metadata.Annotations in details to send to OpsGenie -W, --withLabels Include the event.metadata.Labels in details to send to OpsGenie + -T, --tagTemplate strings The template to assign for the incident in OpsGenie (default [{{.Entity.Name}},{{.Check.Name}},{{.Entity.Namespace}},{{.Entity.EntityClass}}]) -s, --sensuDashboard string The OpsGenie Handler will use it to create a source Sensu Dashboard URL. Use OPSGENIE_SENSU_DASHBOARD. Example: http://sensu-dashboard.example.local/c/~/n -h, --help help for sensu-opsgenie-handler @@ -65,15 +69,20 @@ Use "sensu-opsgenie-handler [command] --help" for more information about a comma ``` -To configure OpsGenie Sensu Integration follow these first part in [OpsGenie Docs][5]. +### Templates -#### To use Opsgenie Priority +This handler provides options for using templates to populate various fields in the OpsGenie +alert with values provided in the Sensu event. More information on template syntax and format +can be found in [the documentation][12] + + +### To use Opsgenie Priority Use the `--priority` command-line option to specify a default priority and then use check and/or entity annotations to override the default on a per-check or per-entity basis. See [Argument Annotations](#argument-annotations) for more information. -#### To use alert actions +### To use alert actions Use the `--actions` command-line option to specify alert actions to be triggered by an event. The argument for this option is a comma separated list of actions. Use check and/or entity annotations @@ -81,8 +90,7 @@ to set this option on a per-check or per-entity basis. See [Argument Annotation for more information. ## Configuration -### Sensu Go -#### Asset registration +### Asset registration [Sensu Assets][7] are the best way to make use of this plugin. If you're not using an asset, please consider doing so! If you're using sensuctl 5.13 with Sensu Backend 5.13 or later, you can use the @@ -95,7 +103,7 @@ sensuctl asset add nixwiz/sensu-opsgenie-handler If you're using an earlier version of sensuctl, you can find the asset on the [Bonsai Asset Index][8]. -#### Handler definition +### Handler definition ```yml type: Handler @@ -119,7 +127,7 @@ spec: secret: opgsgenie_authtoken ``` -### Environment Variables +### Environment variables Most arguments for this handler are available to be set via environment variables. However, any arguments specified directly on the command line override the corresponding environment variable. @@ -154,7 +162,7 @@ spec: id: OPSGENIE_AUTHTOKEN ``` -### Argument Annotations +### Argument annotations All arguments for this handler are tunable on a per entity or check basis based on annotations. The annotations keyspace for this handler is `sensu.io/plugins/sensu-opsgenie-handler/config`. @@ -172,17 +180,13 @@ metadata: [...] ``` -### Proxy Support +### Proxy support This handler supports the use of the environment variables HTTP_PROXY, HTTPS_PROXY, and NO_PROXY (or the lowercase versions thereof). HTTPS_PROXY takes precedence over HTTP_PROXY for https requests. The environment values may be either a complete URL or a "host[:port]", in which case the "http" scheme is assumed. -### Sensu Core - -See [this plugin][9] - ## Installation from source Download the latest version of the sensu-opsgenie-handler from [releases][4], @@ -208,3 +212,4 @@ See https://github.com/sensu/sensu-go/blob/master/CONTRIBUTING.md [9]: https://github.com/sensu-plugins/sensu-plugins-opsgenie [10]: https://docs.sensu.io/sensu-go/latest/guides/secrets-management/ [11]: https://docs.sensu.io/sensu-go/latest/guides/secrets-management/#use-env-for-secrets-management +[12]: https://docs.sensu.io/sensu-go/latest/observability-pipeline/observe-process/handler-templates/ diff --git a/go.mod b/go.mod index be475cf..9c510a6 100644 --- a/go.mod +++ b/go.mod @@ -5,27 +5,32 @@ go 1.14 require ( github.com/coreos/etcd v3.3.25+incompatible // indirect github.com/fsnotify/fsnotify v1.4.9 // indirect + github.com/gogo/protobuf v1.3.2 // indirect github.com/golang/protobuf v1.4.3 // indirect + github.com/google/uuid v1.2.0 // indirect + github.com/hashicorp/go-retryablehttp v0.6.8 // indirect github.com/json-iterator/go v1.1.10 // indirect github.com/magiconair/properties v1.8.4 // indirect - github.com/mitchellh/mapstructure v1.3.3 // indirect - github.com/opsgenie/opsgenie-go-sdk v0.0.0-20181102130742-d57b8391ca90 - github.com/opsgenie/opsgenie-go-sdk-v2 v1.2.2 + github.com/mitchellh/mapstructure v1.4.1 // indirect + github.com/opsgenie/opsgenie-go-sdk-v2 v1.2.6 github.com/pelletier/go-toml v1.8.1 // indirect + github.com/pkg/errors v0.9.1 // indirect github.com/robertkrimen/otto v0.0.0-20200922221731-ef014fd054ac // indirect github.com/sensu-community/sensu-plugin-sdk v0.11.0 - github.com/sensu/sensu-go/types v0.3.0 + github.com/sensu/sensu-go/api/core/v2 v2.6.0 // indirect + github.com/sensu/sensu-go/types v0.4.0 github.com/sirupsen/logrus v1.7.0 // indirect - github.com/spf13/afero v1.4.1 // indirect + github.com/spf13/afero v1.5.1 // indirect github.com/spf13/cast v1.3.1 // indirect - github.com/spf13/cobra v1.1.0 // indirect + github.com/spf13/cobra v1.1.1 // indirect github.com/spf13/jwalterweatherman v1.1.0 // indirect github.com/spf13/viper v1.7.1 // indirect github.com/stretchr/testify v1.6.0 - golang.org/x/net v0.0.0-20201010224723-4f7140c49acb // indirect - golang.org/x/sys v0.0.0-20201015000850-e3ed0017c211 // indirect - google.golang.org/genproto v0.0.0-20201015140912-32ed001d685c // indirect - google.golang.org/grpc v1.33.0 // indirect - google.golang.org/protobuf v1.25.0 // indirect + golang.org/x/net v0.0.0-20210119194325-5f4716e94777 // indirect + golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c // indirect + golang.org/x/text v0.3.5 // indirect + google.golang.org/genproto v0.0.0-20210126160654-44e461bb6506 // indirect + google.golang.org/grpc v1.35.0 // indirect gopkg.in/ini.v1 v1.62.0 // indirect + gopkg.in/yaml.v2 v2.4.0 // indirect ) diff --git a/go.sum b/go.sum index 710c807..462b9d9 100644 --- a/go.sum +++ b/go.sum @@ -28,7 +28,7 @@ github.com/bketelsen/crypt v0.0.3-0.20200106085610-5cbc8cc4026c/go.mod h1:MKsuJm github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc= github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= -github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= +github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk= github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= github.com/coreos/etcd v3.3.13+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= @@ -56,7 +56,7 @@ github.com/echlebek/timeproxy v1.0.0 h1:V41/v8tmmMDNMA2GrBPI45nlXb3F7+OY+nJz1BqK github.com/echlebek/timeproxy v1.0.0/go.mod h1:0dg2Lnb8no/jFwoMQKMTU6iAivgoMptGqSTprhnrRtk= github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= -github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= +github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= github.com/fsnotify/fsnotify v1.4.7 h1:IXs+QLmnXW2CcXuY+8Mzv/fWEsPGWxqefPtCP5CnV9I= @@ -73,6 +73,8 @@ github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7a github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4= github.com/gogo/protobuf v1.3.1 h1:DqDEcV5aeaTmdFBePNpYsp3FlcVH/2ISVVM9Qf8PSls= github.com/gogo/protobuf v1.3.1/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXPKa29o= +github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= +github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b h1:VKtxabqXZkF25pY9ekfRL6a582T4P37/31XEstQ5p58= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= github.com/golang/groupcache v0.0.0-20190129154638-5b532d6fd5ef/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= @@ -83,13 +85,13 @@ github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5y github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= github.com/golang/protobuf v1.3.2 h1:6nsPYzhq5kReh6QImI3k5qWzO4PEbvbIW2cwSfR/6xs= github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= -github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA= github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs= github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w= github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0= github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8= +github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= github.com/golang/protobuf v1.4.3 h1:JjCZWpVbqXDqFVmTfYWEVTMIYrL/NPdPSCHPJ0T/raM= github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= @@ -110,6 +112,8 @@ github.com/google/uuid v1.1.1 h1:Gkbcsh/GbpXz7lPftLA3P6TYMwjCLYm83jiFQZF/3gY= github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.1.2 h1:EVhdT+1Kseyi1/pUmXKaFxYsDNy9RQYkMWRH68J/W7Y= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.2.0 h1:qJYtXnJRWmpe7m/3XlyhrsLrEURqHRM2kxzoxXqyUDs= +github.com/google/uuid v1.2.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1 h1:EGx4pi6eqNxGaHF6qqu48+N2wcFQ5qg5FXgOdqsJ5d8= @@ -125,11 +129,15 @@ github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brv github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= github.com/hashicorp/go-cleanhttp v0.5.1 h1:dH3aiDG9Jvb5r5+bYHsikaOUIpcM0xvgMXVoDkXMzJM= github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= +github.com/hashicorp/go-hclog v0.9.2 h1:CG6TE5H9/JXsFWJCfoIVpKFIkFe6ysEuHirp4DxCsHI= +github.com/hashicorp/go-hclog v0.9.2/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ= github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM= github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk= github.com/hashicorp/go-retryablehttp v0.5.1 h1:Vsx5XKPqPs3M6sM4U4GWyUqFS8aBiL9U5gkgvpkg4SE= github.com/hashicorp/go-retryablehttp v0.5.1/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs= +github.com/hashicorp/go-retryablehttp v0.6.8 h1:92lWxgpa+fF3FozM4B3UZtHZMJX8T5XT+TFdCxsPyWs= +github.com/hashicorp/go-retryablehttp v0.6.8/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY= github.com/hashicorp/go-rootcerts v1.0.0/go.mod h1:K6zTfqpRlCUIjkwsN4Z+hiSfzSTQa6eBIzfwKfwNnHU= github.com/hashicorp/go-sockaddr v1.0.0/go.mod h1:7Xibr9yA9JjQq1JpNB2Vw7kxv8xerXegt+ozgdvDeDU= github.com/hashicorp/go-syslog v1.0.0/go.mod h1:qPfqrKkXGihmCqbJM2mZgkZGvKG1dFdvsLplgctolz4= @@ -158,6 +166,7 @@ github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfV github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q= github.com/kisielk/errcheck v1.2.0/go.mod h1:/BMXB+zMLi60iA8Vv6Ksmxu/1UDYcXs4uQLJ+jE2L00= +github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.3 h1:CE8S1cTafDpPvMhIxNJKvHsGVBgn1xWYf1NbHQhywc8= @@ -187,8 +196,8 @@ github.com/mitchellh/iochan v1.0.0/go.mod h1:JwYml1nuB7xOzsp52dPpHFffvOCDupsG0Qu github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/mitchellh/mapstructure v1.1.2 h1:fmNYVwqnSfB9mZU6OS2O6GsXM+wcskZDuKQzvN1EDeE= github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= -github.com/mitchellh/mapstructure v1.3.3 h1:SzB1nHZ2Xi+17FP0zVQBHIZqvwRN9408fJO8h+eeNA8= -github.com/mitchellh/mapstructure v1.3.3/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= +github.com/mitchellh/mapstructure v1.4.1 h1:CpVNEelQCZBooIPDn+AR3NpivK/TIKU8bDxdASFVQag= +github.com/mitchellh/mapstructure v1.4.1/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -197,10 +206,8 @@ github.com/modern-go/reflect2 v1.0.1 h1:9f412s+6RmYXLWZSEzVVgPGK7C2PphHj5RJrvfx9 github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U= -github.com/opsgenie/opsgenie-go-sdk v0.0.0-20181102130742-d57b8391ca90 h1:3YFIoZxerB7VHdIZ3mFoQ/rnT7AIORbdCIZ/LkFZ3QA= -github.com/opsgenie/opsgenie-go-sdk v0.0.0-20181102130742-d57b8391ca90/go.mod h1:dNDIBlBIGnkrpaLz1o4idoRV9L27SRBGd7p8PL5YDpM= -github.com/opsgenie/opsgenie-go-sdk-v2 v1.2.2 h1:ekujeeMApjt7mieNcIGL4w0hrh+SIILXKIoi6al/4V8= -github.com/opsgenie/opsgenie-go-sdk-v2 v1.2.2/go.mod h1:VOkJ7STzYj+nXRhMcBTcmt8uZZ17KZKJdZtJpgHLbT8= +github.com/opsgenie/opsgenie-go-sdk-v2 v1.2.6 h1:C3p45LH9szkt8/pbI4CXwBPkLj3pFLlCzbzm6FgG57c= +github.com/opsgenie/opsgenie-go-sdk-v2 v1.2.6/go.mod h1:4OjcxgwdXzezqytxN534MooNmrxRD50geWZxTD7845s= github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= github.com/pelletier/go-toml v1.8.1 h1:1Nf83orprkJyknT6h7zbuEGUEjcyVlCxSUGTENmNCRM= @@ -208,6 +215,8 @@ github.com/pelletier/go-toml v1.8.1/go.mod h1:T2/BmBdy8dvIRq1a/8aqjN41wvWlN4lrap github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/errors v0.8.1 h1:iURUrRGxPUNPdy5/HRSm+Yj6okJ6UtLINN0Q9M4+h3I= github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= +github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= +github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= @@ -238,9 +247,14 @@ github.com/sensu-community/sensu-plugin-sdk v0.11.0/go.mod h1:OMS/JgUcJRBbrojqJH github.com/sensu/sensu-go/api/core/v2 v2.0.0/go.mod h1:L+ZZ+QzsGTrNldiAdVrrQI/WIo31cq43YnEFt9T/6Pg= github.com/sensu/sensu-go/api/core/v2 v2.3.0 h1:7RrVfN4dvOMFsEOLotpvYD061s/fhicZQf4JaVoLgaI= github.com/sensu/sensu-go/api/core/v2 v2.3.0/go.mod h1:97IK4ZQuvVjWvvoLkp+NgrD6ot30WDRz3LEbFUc/N34= +github.com/sensu/sensu-go/api/core/v2 v2.4.0/go.mod h1:97IK4ZQuvVjWvvoLkp+NgrD6ot30WDRz3LEbFUc/N34= +github.com/sensu/sensu-go/api/core/v2 v2.6.0 h1:hEKPHFZZNDuWTlKr7Kgm2yog65ZdkBUqNesE5qaWEGo= +github.com/sensu/sensu-go/api/core/v2 v2.6.0/go.mod h1:97IK4ZQuvVjWvvoLkp+NgrD6ot30WDRz3LEbFUc/N34= github.com/sensu/sensu-go/types v0.1.0/go.mod h1:o3tBPy2BUWb3jPvMQ+pBs0CgCyN1vC1/loN4anURxvs= github.com/sensu/sensu-go/types v0.3.0 h1:nVplWvduq9ArIu2rz3jMrzdVBFAlkm6T9l45UyhrP1s= github.com/sensu/sensu-go/types v0.3.0/go.mod h1:TyeO3h/82XE1KppZRFg+jKB4QYwY2hE5hbCzjnnGdRo= +github.com/sensu/sensu-go/types v0.4.0 h1:sg3MgRL0Q5dW5P/kMbfohAE9flW6WwUzr6KEH2dx0Zc= +github.com/sensu/sensu-go/types v0.4.0/go.mod h1:3B68p1lbYoZkiQReo4gADKYb+ApDNcBBw2jf8xXJlM4= github.com/sensu/sensu-licensing v0.1.2 h1:EEZxvbj/pmCCfD4ePAzs9mb6k6IPRDbUJcwAOfSvuUc= github.com/sensu/sensu-licensing v0.1.2/go.mod h1:Xfs4do2c3U+VvuNCjthUH7QJOZ9o6NfbQSb7rrvSXGc= github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= @@ -257,15 +271,15 @@ github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9 github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM= github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA= github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ= -github.com/spf13/afero v1.4.1 h1:asw9sl74539yqavKaglDM5hFpdJVK0Y5Dr/JOgQ89nQ= -github.com/spf13/afero v1.4.1/go.mod h1:Ai8FlHk4v/PARR026UzYexafAt9roJ7LcLMAmO6Z93I= +github.com/spf13/afero v1.5.1 h1:VHu76Lk0LSP1x254maIu2bplkWpfBWI+B+6fdoZprcg= +github.com/spf13/afero v1.5.1/go.mod h1:Ai8FlHk4v/PARR026UzYexafAt9roJ7LcLMAmO6Z93I= github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= github.com/spf13/cast v1.3.1 h1:nFm6S0SMdyzrzcmThSipiEubIDy8WEXKNZ0UOgiRpng= github.com/spf13/cast v1.3.1/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= github.com/spf13/cobra v1.0.0 h1:6m/oheQuQ13N9ks4hubMG6BnvwOeaJrqSPLahSnczz8= github.com/spf13/cobra v1.0.0/go.mod h1:/6GTrnGXV9HjY+aR4k0oJ5tcvakLuG6EuKReYlHNrgE= -github.com/spf13/cobra v1.1.0 h1:aq3wCKjTPmzcNWLVGnsFVN4rflK7Uzn10F8/aw8MhdQ= -github.com/spf13/cobra v1.1.0/go.mod h1:yk5b0mALVusDL5fMM6Rd1wgnoO5jUPhwsQ6LQAJTidQ= +github.com/spf13/cobra v1.1.1 h1:KfztREH0tPxJJ+geloSLaAkaPkr4ki2Er5quFV1TDo4= +github.com/spf13/cobra v1.1.1/go.mod h1:WnodtKOvamDL/PwE2M4iKs8aMDBZ5Q5klgD3qfVJQMI= github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo= github.com/spf13/jwalterweatherman v1.1.0 h1:ue6voC5bR5F8YxI5S67j9i582FU4Qvo2bmqnqMYADFk= github.com/spf13/jwalterweatherman v1.1.0/go.mod h1:aNWZUN0dPAAO/Ljvb5BEdw96iTZ0EXowPYD95IqWIGo= @@ -283,6 +297,7 @@ github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+ github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= +github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA= github.com/stretchr/testify v1.6.0 h1:jlIyCplCJFULU/01vCkhKuTyc3OorI3bJFuw6obfgho= github.com/stretchr/testify v1.6.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/subosito/gotenv v1.2.0 h1:Slr1R9HxAlEKefgq5jn9U+DnETlIUa6HfgEzj0g5d7s= @@ -291,6 +306,8 @@ github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1 github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q= +github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= go.etcd.io/bbolt v1.3.2/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8= @@ -303,6 +320,7 @@ golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACk golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190820162420-60c769a6c586/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= @@ -322,6 +340,8 @@ golang.org/x/mobile v0.0.0-20190312151609-d3739f865fa6/go.mod h1:z+o9i4GpDbdi3rU golang.org/x/mobile v0.0.0-20190719004257-d2bd2a29d028/go.mod h1:E/iHnbuqvinMTCcRqshq8CkpyQDoeVncDDYHnLhea+o= golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKGUJ2LatrhH/nqhxcFungHvyanc= golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= +golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20181023162649-9b4f9f5ad519/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= @@ -336,10 +356,12 @@ golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn golang.org/x/net v0.0.0-20190503192946-f4e77d36d62c/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190522155817-f3200d17e092/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= -golang.org/x/net v0.0.0-20190607181551-461777fb6f67/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20201010224723-4f7140c49acb h1:mUVeFHoDKis5nxCAzoAi7E8Ghb86EXh/RK6wtvJIqRY= -golang.org/x/net v0.0.0-20201010224723-4f7140c49acb/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20201224014010-6772e930b67b/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210119194325-5f4716e94777 h1:003p0dJM77cxMSyCPFphvZf/Y5/NXf5fzg6ufd1/Oew= +golang.org/x/net v0.0.0-20210119194325-5f4716e94777/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= @@ -348,6 +370,8 @@ golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJ golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -365,14 +389,18 @@ golang.org/x/sys v0.0.0-20190624142023-c5567b49c5d0/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20201015000850-e3ed0017c211 h1:9UQO31fZ+0aKQOFldThf7BKPMJTiBfWycGh/u3UoO88= -golang.org/x/sys v0.0.0-20201015000850-e3ed0017c211/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c h1:VwygUrnw9jn88c4u8GD3rZQbqrP/tgas88tPUbBxQrk= +golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.2 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= golang.org/x/text v0.3.3 h1:cokOdA+Jmi5PJGXLlLllQSgYigAEfHXJAERHVMaCc2k= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.5 h1:i6eZZ+zk0SOf0xgBpEpPD18qWcJda6q1sxt3S0kzyUQ= +golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= @@ -394,9 +422,15 @@ golang.org/x/tools v0.0.0-20190816200558-6889da9d5479/go.mod h1:b+2E5dAYhXwXZwtn golang.org/x/tools v0.0.0-20190911174233-4f2ddba30aff/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191012152004-8de300cfc20a/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191112195655-aa38f8e97acc/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= +golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE= google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M= google.golang.org/api v0.8.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= @@ -417,8 +451,8 @@ google.golang.org/genproto v0.0.0-20190911173649-1774047e7e51/go.mod h1:IbNlFCBr google.golang.org/genproto v0.0.0-20191108220845-16a3f7862a1a h1:Ob5/580gVHBJZgXnff1cZDbG+xLtMVE5mDRTe+nIsX4= google.golang.org/genproto v0.0.0-20191108220845-16a3f7862a1a/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= -google.golang.org/genproto v0.0.0-20201015140912-32ed001d685c h1:FM0/YezufKHjM3Y9gndHmhytJuCHW0bExs92Pu3LTQ0= -google.golang.org/genproto v0.0.0-20201015140912-32ed001d685c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210126160654-44e461bb6506 h1:uLBY0yHDCj2PMQ98KWDSIDFwn9zK2zh+tgWtbvPPBjI= +google.golang.org/genproto v0.0.0-20210126160654-44e461bb6506/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= google.golang.org/grpc v1.20.1/go.mod h1:10oTOabMzJvdu6/UiuZezV6QK5dSlG84ov/aaiqXj38= google.golang.org/grpc v1.21.0/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= @@ -428,8 +462,8 @@ google.golang.org/grpc v1.24.0 h1:vb/1TCsVn3DcJlQ0Gs1yB1pKI6Do2/QNwxdKqmc/b0s= google.golang.org/grpc v1.24.0/go.mod h1:XDChyiUovWa60DnaeDeZmSW86xtLtjtZbwvSiRnRtcA= google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= -google.golang.org/grpc v1.33.0 h1:IBKSUNL2uBS2DkJBncPP+TwT0sp9tgA8A75NjHt6umg= -google.golang.org/grpc v1.33.0/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0= +google.golang.org/grpc v1.35.0 h1:TwIQcH3es+MojMVojxxfQ3l3OF2KzlRxML2xZq0kRo8= +google.golang.org/grpc v1.35.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= @@ -458,8 +492,11 @@ gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.4 h1:/eiJrUcujPVeJ3xlSWaiNi3uSVmDGBK1pDHUHAnao1I= gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.3.0 h1:clyUAQHOM3G0M3f5vQj7LuJrETvjVot3Z5el9nffUtU= gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= +gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= diff --git a/main.go b/main.go index cf63245..aadf59d 100644 --- a/main.go +++ b/main.go @@ -36,6 +36,7 @@ type Config struct { MessageTemplate string DescriptionTemplate string Actions []string + TagsTemplates []string } var ( @@ -149,32 +150,41 @@ var ( Value: &plugin.Actions, }, { - Path: "withAnnotations", - Env: "", - Argument: "withAnnotations", - Shorthand: "w", - Default: false, - Usage: "Include the event.metadata.Annotations in details to send to OpsGenie", - Value: &plugin.WithAnnotations, - }, - { - Path: "withLabels", - Env: "", - Argument: "withLabels", - Shorthand: "W", - Default: false, - Usage: "Include the event.metadata.Labels in details to send to OpsGenie", - Value: &plugin.WithLabels, - }, - { - Path: "fullDetails", - Env: "", - Argument: "fullDetails", - Shorthand: "F", - Default: false, - Usage: "Include the more details to send to OpsGenie like proxy_entity_name, occurrences and agent details arch and os", - Value: &plugin.FullDetails, - }, + Path: "withAnnotations", + Env: "", + Argument: "withAnnotations", + Shorthand: "w", + Default: false, + Usage: "Include the event.metadata.Annotations in details to send to OpsGenie", + Value: &plugin.WithAnnotations, + }, + { + Path: "withLabels", + Env: "", + Argument: "withLabels", + Shorthand: "W", + Default: false, + Usage: "Include the event.metadata.Labels in details to send to OpsGenie", + Value: &plugin.WithLabels, + }, + { + Path: "fullDetails", + Env: "", + Argument: "fullDetails", + Shorthand: "F", + Default: false, + Usage: "Include the more details to send to OpsGenie like proxy_entity_name, occurrences and agent details arch and os", + Value: &plugin.FullDetails, + }, + { + Path: "tagTemplate", + Env: "", + Argument: "tagTemplate", + Shorthand: "T", + Default: []string{"{{.Entity.Name}}", "{{.Check.Name}}", "{{.Entity.Namespace}}", "{{.Entity.EntityClass}}"}, + Usage: "The template to assign for the incident in OpsGenie", + Value: &plugin.TagsTemplates, + }, } ) @@ -194,7 +204,7 @@ func checkArgs(_ *types.Event) error { } // parseEventKeyTags func returns string, string, and []string with event data -// fist string contains custom templte string to use in message +// fist string contains custom template string to use in message // second string contains Entity.Name/Check.Name to use in alias // []string contains Entity.Name Check.Name Entity.Namespace, event.Entity.EntityClass to use as tags in Opsgenie func parseEventKeyTags(event *types.Event) (title string, alias string, tags []string) { @@ -203,7 +213,13 @@ func parseEventKeyTags(event *types.Event) (title string, alias string, tags []s if err != nil { return "", "", []string{} } - tags = append(tags, event.Entity.Name, event.Check.Name, event.Entity.Namespace, event.Entity.EntityClass) + for _, v := range plugin.TagsTemplates { + tag, err := templates.EvalTemplate("tags", v, event) + if err != nil { + return "", "", []string{} + } + tags = append(tags, tag) + } return trim(title, plugin.MessageLimit), alias, tags } @@ -235,51 +251,51 @@ func parseDetails(event *types.Event) map[string]string { details["handlers"] = fmt.Sprintf("%v", event.Check.Handlers) if event.Entity.EntityClass == "agent" { - details["arch"] = event.Entity.System.GetArch() - details["os"] = event.Entity.System.GetOS() - details["platform"] = event.Entity.System.GetPlatform() - details["platform_family"] = event.Entity.System.GetPlatformFamily() - details["platform_version"] = event.Entity.System.GetPlatformVersion() - } + details["arch"] = event.Entity.System.GetArch() + details["os"] = event.Entity.System.GetOS() + details["platform"] = event.Entity.System.GetPlatform() + details["platform_family"] = event.Entity.System.GetPlatformFamily() + details["platform_version"] = event.Entity.System.GetPlatformVersion() + } } - if plugin.WithAnnotations { - if event.Check.Annotations != nil { - for key, value := range event.Check.Annotations { - if !strings.Contains(key, plugin.PluginConfig.Keyspace) { - checkKey := fmt.Sprintf("%s_annotation_%s", "check", key) - details[checkKey] = value - } - } - } - if event.Entity.Annotations != nil { - for key, value := range event.Entity.Annotations { - if !strings.Contains(key, plugin.PluginConfig.Keyspace) { - entityKey := fmt.Sprintf("%s_annotation_%s", "entity", key) - details[entityKey] = value - } - } - } - } - - if plugin.WithLabels { - if event.Check.Labels != nil { - for key, value := range event.Check.Labels { - checkKey := fmt.Sprintf("%s_label_%s", "check", key) - details[checkKey] = value - } - } - if event.Entity.Labels != nil { - for key, value := range event.Entity.Labels { - entityKey := fmt.Sprintf("%s_label_%s", "entity", key) - details[entityKey] = value - } - } - } + if plugin.WithAnnotations { + if event.Check.Annotations != nil { + for key, value := range event.Check.Annotations { + if !strings.Contains(key, plugin.PluginConfig.Keyspace) { + checkKey := fmt.Sprintf("%s_annotation_%s", "check", key) + details[checkKey] = value + } + } + } + if event.Entity.Annotations != nil { + for key, value := range event.Entity.Annotations { + if !strings.Contains(key, plugin.PluginConfig.Keyspace) { + entityKey := fmt.Sprintf("%s_annotation_%s", "entity", key) + details[entityKey] = value + } + } + } + } + + if plugin.WithLabels { + if event.Check.Labels != nil { + for key, value := range event.Check.Labels { + checkKey := fmt.Sprintf("%s_label_%s", "check", key) + details[checkKey] = value + } + } + if event.Entity.Labels != nil { + for key, value := range event.Entity.Labels { + entityKey := fmt.Sprintf("%s_label_%s", "entity", key) + details[entityKey] = value + } + } + } if len(plugin.SensuDashboard) > 0 { - details["sensuDashboard"] = fmt.Sprintf("source: %s/%s/events/%s/%s \n", plugin.SensuDashboard, event.Entity.Namespace, event.Entity.Name, event.Check.Name) - } + details["sensuDashboard"] = fmt.Sprintf("source: %s/%s/events/%s/%s \n", plugin.SensuDashboard, event.Entity.Namespace, event.Entity.Name, event.Check.Name) + } return details } @@ -395,6 +411,7 @@ func createIncident(alertClient *alert.Client, event *types.Event) error { if err != nil { fmt.Println(err.Error()) } else { + // FUTURE: send to AH fmt.Println("Create request ID: " + createResult.RequestId) } return nil @@ -431,6 +448,7 @@ func closeAlert(alertClient *alert.Client, event *types.Event, alertid string) e if err != nil { fmt.Printf("[ERROR] Not Closed: %s\n", err) } + // FUTURE: send to AH fmt.Printf("RequestID %s to Close %s\n", alertid, closeResult.RequestId) return nil diff --git a/main_test.go b/main_test.go index c83a6af..0cb4c9a 100644 --- a/main_test.go +++ b/main_test.go @@ -26,6 +26,7 @@ func TestParseEventKeyTags(t *testing.T) { assert.NoError(t, err) plugin.MessageTemplate = "{{.Entity.Name}}/{{.Check.Name}}" plugin.MessageLimit = 100 + plugin.TagsTemplates = []string{"{{.Entity.Name}}", "{{.Check.Name}}", "{{.Entity.Namespace}}", "{{.Entity.EntityClass}}"} title, alias, tags := parseEventKeyTags(event) assert.Contains(t, title, "foo") assert.Contains(t, alias, "foo") @@ -106,23 +107,22 @@ func TestTrim(t *testing.T) { } func TestSwitchOpsgenieRegion(t *testing.T) { - expectedValueUS := client.API_URL - expectedValueEU := client.API_URL_EU + expectedValueUS := client.API_URL + expectedValueEU := client.API_URL_EU - testUS := switchOpsgenieRegion() + testUS := switchOpsgenieRegion() - assert.Equal(t, testUS, expectedValueUS) + assert.Equal(t, testUS, expectedValueUS) - plugin.APIRegion = "eu" + plugin.APIRegion = "eu" - testEU := switchOpsgenieRegion() + testEU := switchOpsgenieRegion() - assert.Equal(t, testEU, expectedValueEU) + assert.Equal(t, testEU, expectedValueEU) - plugin.APIRegion = "EU" + plugin.APIRegion = "EU" - testEU2 := switchOpsgenieRegion() + testEU2 := switchOpsgenieRegion() - assert.Equal(t, testEU2, expectedValueEU) + assert.Equal(t, testEU2, expectedValueEU) } - diff --git a/test.all.events.sh b/test.all.events.sh deleted file mode 100644 index 8abcf24..0000000 --- a/test.all.events.sh +++ /dev/null @@ -1,29 +0,0 @@ -#!/usr/bin/env bash - -list="event -event_with_opsgenie_priority.check -event_with_opsgenie_priority" - -for event in $list ; -do - echo "${event} With URL https://api.opsgenie.com/" - cat ${event}.json | ./sensu-opsgenie-handler --url 'https://api.opsgenie.com/' - sleep 5 - cat ${event}.resolved.json | ./sensu-opsgenie-handler --url 'https://api.opsgenie.com/' -done - sleep 5 -for event in $list ; -do - echo "${event} With URL https://api.opsgenie.com" - cat ${event}.json | ./sensu-opsgenie-handler --url 'https://api.opsgenie.com' - sleep 5 - cat ${event}.resolved.json | ./sensu-opsgenie-handler --url 'https://api.opsgenie.com' -done - sleep 5 -for event in $list ; -do - echo "${event} Without URL" - cat ${event}.json | ./sensu-opsgenie-handler - sleep 5 - cat ${event}.resolved.json | ./sensu-opsgenie-handler -done diff --git a/event.json b/tests/event.json similarity index 100% rename from event.json rename to tests/event.json diff --git a/event.resolved.json b/tests/event.resolved.json similarity index 100% rename from event.resolved.json rename to tests/event.resolved.json diff --git a/event.withAnnotations.json b/tests/event.withAnnotations.json similarity index 100% rename from event.withAnnotations.json rename to tests/event.withAnnotations.json diff --git a/event.withAnnotations.resolved.json b/tests/event.withAnnotations.resolved.json similarity index 100% rename from event.withAnnotations.resolved.json rename to tests/event.withAnnotations.resolved.json diff --git a/event_from_proxy.json b/tests/event_from_proxy.json similarity index 100% rename from event_from_proxy.json rename to tests/event_from_proxy.json diff --git a/event_from_proxy.resolved.json b/tests/event_from_proxy.resolved.json similarity index 100% rename from event_from_proxy.resolved.json rename to tests/event_from_proxy.resolved.json diff --git a/event_new.json b/tests/event_new.json similarity index 100% rename from event_new.json rename to tests/event_new.json diff --git a/event_new.resolved.json b/tests/event_new.resolved.json similarity index 100% rename from event_new.resolved.json rename to tests/event_new.resolved.json diff --git a/event_with_opsgenie_priority.check.json b/tests/event_with_opsgenie_priority.check.json similarity index 100% rename from event_with_opsgenie_priority.check.json rename to tests/event_with_opsgenie_priority.check.json diff --git a/event_with_opsgenie_priority.check.resolved.json b/tests/event_with_opsgenie_priority.check.resolved.json similarity index 100% rename from event_with_opsgenie_priority.check.resolved.json rename to tests/event_with_opsgenie_priority.check.resolved.json diff --git a/event_with_opsgenie_priority.json b/tests/event_with_opsgenie_priority.json similarity index 100% rename from event_with_opsgenie_priority.json rename to tests/event_with_opsgenie_priority.json diff --git a/event_with_opsgenie_priority.resolved.json b/tests/event_with_opsgenie_priority.resolved.json similarity index 100% rename from event_with_opsgenie_priority.resolved.json rename to tests/event_with_opsgenie_priority.resolved.json diff --git a/tests/test.all.events.sh b/tests/test.all.events.sh new file mode 100644 index 0000000..b98261c --- /dev/null +++ b/tests/test.all.events.sh @@ -0,0 +1,29 @@ +#!/usr/bin/env bash + +list="event +event_with_opsgenie_priority.check +event_with_opsgenie_priority" + +for event in $list ; +do + echo "${event} With URL https://api.opsgenie.com/" + cat ${event}.json | ../sensu-opsgenie-handler --url 'https://api.opsgenie.com/' + sleep 5 + cat ${event}.resolved.json | ../sensu-opsgenie-handler --url 'https://api.opsgenie.com/' +done + sleep 5 +for event in $list ; +do + echo "${event} With URL https://api.opsgenie.com" + cat ${event}.json | ../sensu-opsgenie-handler --url 'https://api.opsgenie.com' + sleep 5 + cat ${event}.resolved.json | ../sensu-opsgenie-handler --url 'https://api.opsgenie.com' +done + sleep 5 +for event in $list ; +do + echo "${event} Without URL" + cat ${event}.json | ../sensu-opsgenie-handler + sleep 5 + cat ${event}.resolved.json | ../sensu-opsgenie-handler +done