content/flux/v0/stdlib/contrib/sranka/opsgenie/endpoint.md
opsgenie.endpoint() sends an alert message to Opsgenie using data from table rows.
opsgenie.endpoint is a factory function that outputs another function.
The output function requires a mapFn parameter.
A function that builds the record used to generate the POST request. Requires an r parameter.
mapFn accepts a table row (r) and returns a record that must include the following fields:
For more information, see opsgenie.sendAlert.
(
apiKey: string,
?entity: string,
?url: string,
) => (
mapFn: (
r: A,
) => {
B with
visibleTo: [string],
tags: E,
responders: [string],
priority: string,
message: string,
details: D,
description: string,
alias: string,
actions: C,
},
) => (<-tables: stream[A]) => stream[{A with _sent: string}] where D: Stringable
{{% caption %}} For more information, see Function type signatures. {{% /caption %}}
Opsgenie API URL. Defaults to https://api.opsgenie.com/v2/alerts.
({{< req >}}) (Required) Opsgenie API authorization key.
Alert entity used to specify the alert domain.
import "influxdata/influxdb/secrets"
import "contrib/sranka/opsgenie"
apiKey = secrets.get(key: "OPSGENIE_APIKEY")
endpoint = opsgenie.endpoint(apiKey: apiKey)
crit_statuses =
from(bucket: "example-bucket")
|> range(start: -1m)
|> filter(fn: (r) => r._measurement == "statuses" and status == "crit")
crit_statuses
|> endpoint(
mapFn: (r) =>
({
message: "Great Scott!- Disk usage is: ${r.status}.",
alias: "disk-usage-${r.status}",
description: "",
priority: "P3",
responders: ["user:[email protected]", "team:itcrowd"],
tags: [],
entity: "my-lab",
actions: [],
details: "{}",
visibleTo: [],
}),
)()