Git Product home page Git Product logo

handler-plugin-template's Introduction

{{- /* Ignore this text, until templating is ran via sensu-plugin-tool the below badge links wiill not render */ -}}

[Sensu Bonsai Asset](https://bonsai.sensu.io/assets/{{ .GithubUser }}/{{ .GithubProject }}) ![goreleaser](https://github.com/{{ .GithubUser }}/{{ .GithubProject }}/workflows/goreleaser/badge.svg) [![Go Test](https://github.com/{{ .GithubUser }}/{{ .GithubProject }}/workflows/Go%20Test/badge.svg)](https://github.com/{{ .GithubUser }}/{{ .GithubProject }}/actions?query=workflow%3A%22Go+Test%22) [![goreleaser](https://github.com/{{ .GithubUser }}/{{ .GithubProject }}/workflows/goreleaser/badge.svg)](https://github.com/{{ .GithubUser }}/{{ .GithubProject }}/actions?query=workflow%3Agoreleaser)

Handler Plugin Template

Overview

handler-plugin-template is a template repository which wraps the Sensu Plugin SDK. To use this project as a template, click the "Use this template" button from the main project page. Once the repository is created from this template, you can use the Sensu Plugin Tool to populate the templated fields with the proper values.

Functionality

After successfully creating a project from this template, update the Config struct with any configuration options for the plugin, map those values as plugin options in the variable options, and customize the checkArgs and executeHandler functions in main.go.

When writing or updating a plugin's README from this template, review the Sensu Community plugin README style guide for content suggestions and guidance. Remove everything prior to # {{ .Name }} from the generated README file, and add additional context about the plugin per the style guide.

Releases with Github Actions

To release a version of your project, simply tag the target sha with a semver release without a v prefix (ex. 1.0.0). This will trigger the GitHub action workflow to build and release the plugin with goreleaser. Register the asset with Bonsai to share it with the community!


{{ .Name }}

Table of Contents

Overview

The {{ .Name }} is a Sensu Handler that ...

Files

Usage examples

Configuration

Asset registration

Sensu Assets 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 following command to add the asset:

sensuctl asset add {{ .GithubUser }}/{{ .GithubProject }}

If you're using an earlier version of sensuctl, you can find the asset on the [Bonsai Asset Index][https://bonsai.sensu.io/assets/{{ .GithubUser }}/{{ .GithubProject }}].

Handler definition

---
type: Handler
api_version: core/v2
metadata:
  name: {{ .GithubProject }}
  namespace: default
spec:
  command: {{ .GithubProject }} --example example_arg
  type: pipe
  runtime_assets:
  - {{ .GithubUser}}/{{ .GithubProject }}

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.

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/{{ .GithubProject }}/config.

Examples

To change the example argument for a particular check, for that checks's metadata add the following:

type: CheckConfig
api_version: core/v2
metadata:
  annotations:
    sensu.io/plugins/{{ .GithubProject }}/config/example-argument: "Example change"
[...]

Installation from source

The preferred way of installing and deploying this plugin is to use it as an Asset. If you would like to compile and install the plugin from source or contribute to it, download the latest version or create an executable script from this source.

From the local path of the {{ .GithubProject }} repository:

go build

Additional notes

Contributing

For more information about contributing to this plugin, see Contributing.

handler-plugin-template's People

Contributors

amdprophet avatar echlebek avatar jspaleta avatar nixwiz avatar palourde avatar thoward avatar

Stargazers

 avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

handler-plugin-template's Issues

Document support for HTTP proxy environment variables

As the SDK provides an HTTP client built on net/http, handler plugins built with the SDK tend to honor HTTP proxy environment variables as documented in https://golang.org/pkg/net/http/#ProxyFromEnvironment โ€” Iโ€™ve tested this with the sensu-slack-handler and sensu-pagerduty-handler plugins.

If the README template included a section summarizing the environment variables which can be used to configure plugins to use an HTTP proxy, I think it would be helpful for end users of the projects generated from this template repo.

Update goreleaser ldflags

looks like we have the wrong ldflags set in the goreleaser.yml

version is not being set correctly.

Using corev2 breaks template with updated version

Updating go modules breaks current template:

# rename module name in go.mod
go get -u
go mod tidy
go test -v                                                
# github.com/test/test [github.com/test/test.test]
./main.go:40:63: cannot use checkArgs (value of type func(event *"github.com/sensu/sensu-go/api/core/v2".Event) error) as func(event *"github.com/sensu/core/v2".Event) error value in argument to sensu.NewGoHandler
./main.go:40:74: cannot use executeHandler (value of type func(event *"github.com/sensu/sensu-go/api/core/v2".Event) error) as func(event *"github.com/sensu/core/v2".Event) error value in argument to sensu.NewGoHandler
FAIL    github.com/test/test [build failed]

update version are:

github.com/sensu/sensu-go/api/core/v2 v2.16.0
github.com/sensu/sensu-plugin-sdk v0.18.0

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.