e37a780e14
* init
* autogens AM route
* POST dashboards/db spec
* POST alert-notifications spec
* fix description
* re inits vendor, updates grafana to master
* go mod updates
* alerting routes
* renames to receivers
* prometheus endpoints
* align config endpoint with cortex, include templates
* Change grafana receiver type
* Update receivers.go
* rename struct to stop swagger thrashing
* add rules API
* index html
* standalone swagger ui html page
* Update README.md
* Expose GrafanaManagedAlert properties
* Some fixes
- /api/v1/rules/{Namespace} should return a map
- update ExtendedUpsertAlertDefinitionCommand properties
* am alerts routes
* rename prom swagger section for clarity, remove example endpoints
* Add missing json and yaml tags
* folder perms
* make folders POST again
* fix grafana receiver type
* rename fodler->namespace for perms
* make ruler json again
* PR fixes
* silences
* fix Ok -> Ack
* Add id to POST /api/v1/silences (#9)
Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>
* Add POST /api/v1/alerts (#10)
Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>
* fix silences
* Add testing endpoints
* removes grpc replace directives
* [wip] starts validation
* pkg cleanup
* go mod tidy
* ignores vendor dir
* Change response type for Cortex/Loki alerts
* receiver unmarshaling tests
* ability to split routes between AM & Grafana
* api marshaling & validation
* begins work on routing lib
* [hack] ignores embedded field in generation
* path specific datasource for alerting
* align endpoint names with cloud
* single route per Alerting config
* removes unused routing pkg
* regens spec
* adds datasource param to ruler/prom route paths
* Modifications for supporting migration
* Apply suggestions from code review
* hack for cleaning circular refs in swagger definition
* generates files
* minor fixes for prom endpoints
* decorate prom apis with required: true where applicable
* Revert "generates files"
This reverts commit ef7e975584.
* removes server autogen
* Update imported structs from ngalert
* Fix listing rules response
* Update github.com/prometheus/common dependency
* Update get silence response
* Update get silences response
* adds ruler validation & backend switching
* Fix GET /alertmanager/{DatasourceId}/config/api/v1/alerts response
* Distinct gettable and postable grafana receivers
* Remove permissions routes
* Latest JSON specs
* Fix testing routes
* inline yaml annotation on apirulenode
* yaml test & yamlv3 + comments
* Fix yaml annotations for embedded type
* Rename DatasourceId path parameter
* Implement Backend.String()
* backend zero value is a real backend
* exports DiscoveryBase
* Fix GO initialisms
* Silences: Use PostableSilence as the base struct for creating silences
* Use type alias instead of struct embedding
* More fixes to alertmanager silencing routes
* post and spec JSONs
* Split rule config to postable/gettable
* Fix empty POST /silences payload
Recreating the generated JSON specs fixes the issue
without further modifications
* better yaml unmarshaling for nested yaml docs in cortex-am configs
* regens spec
* re-adds config.receivers
* omitempty to align with prometheus API behavior
* Prefix routes with /api
* Update Alertmanager models
* Make adjustments to follow the Alertmanager API
* ruler: add for and annotations to grafana alert (#45)
* Modify testing API routes
* Fix grafana rule for field type
* Move PostableUserConfig validation to this library
* Fix PostableUserConfig YAML encoding/decoding
* Use common fields for grafana and lotex rules
* Add namespace id in GettableGrafanaRule
* Apply suggestions from code review
* fixup
* more changes
* Apply suggestions from code review
* aligns structure pre merge
* fix new imports & tests
* updates tooling readme
* goimports
* lint
* more linting!!
* revive lint
Co-authored-by: Sofia Papagiannaki <papagian@gmail.com>
Co-authored-by: Domas <domasx2@gmail.com>
Co-authored-by: Sofia Papagiannaki <papagian@users.noreply.github.com>
Co-authored-by: Ganesh Vernekar <15064823+codesome@users.noreply.github.com>
Co-authored-by: gotjosh <josue@grafana.com>
Co-authored-by: David Parrott <stomp.box.yo@gmail.com>
Co-authored-by: Kyle Brandt <kyle@grafana.com>
132 lines
3.8 KiB
Go
132 lines
3.8 KiB
Go
package api
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
|
|
"github.com/grafana/grafana/pkg/services/ngalert/models"
|
|
"github.com/prometheus/alertmanager/config"
|
|
"github.com/prometheus/prometheus/promql"
|
|
)
|
|
|
|
// swagger:route Post /api/v1/receiver/test/{Recipient} testing RouteTestReceiverConfig
|
|
//
|
|
// Test receiver
|
|
//
|
|
// Consumes:
|
|
// - application/json
|
|
//
|
|
// Produces:
|
|
// - application/json
|
|
//
|
|
// Responses:
|
|
// 200: Success
|
|
// 412: SmtpNotEnabled
|
|
// 500: Failure
|
|
|
|
// swagger:route Post /api/v1/rule/test/{Recipient} testing RouteTestRuleConfig
|
|
//
|
|
// Test rule
|
|
//
|
|
// Consumes:
|
|
// - application/json
|
|
//
|
|
// Produces:
|
|
// - application/json
|
|
//
|
|
// Responses:
|
|
// 200: TestRuleResponse
|
|
|
|
// swagger:parameters RouteTestReceiverConfig
|
|
type TestReceiverRequest struct {
|
|
// in:body
|
|
Body ExtendedReceiver
|
|
}
|
|
|
|
// swagger:parameters RouteTestRuleConfig
|
|
type TestRuleRequest struct {
|
|
// in:body
|
|
Body TestRulePayload
|
|
}
|
|
|
|
// swagger:model
|
|
type TestRulePayload struct {
|
|
// Example: (node_filesystem_avail_bytes{fstype!="",job="integrations/node_exporter"} node_filesystem_size_bytes{fstype!="",job="integrations/node_exporter"} * 100 < 5 and node_filesystem_readonly{fstype!="",job="integrations/node_exporter"} == 0)
|
|
Expr string `json:"expr,omitempty"`
|
|
// GrafanaManagedCondition for grafana alerts
|
|
GrafanaManagedCondition *models.EvalAlertConditionCommand `json:"grafana_condition,omitempty"`
|
|
}
|
|
|
|
func (p *TestRulePayload) UnmarshalJSON(b []byte) error {
|
|
type plain TestRulePayload
|
|
if err := json.Unmarshal(b, (*plain)(p)); err != nil {
|
|
return err
|
|
}
|
|
|
|
return p.validate()
|
|
}
|
|
|
|
func (p *TestRulePayload) validate() error {
|
|
if p.Expr != "" && p.GrafanaManagedCondition != nil {
|
|
return fmt.Errorf("cannot mix Grafana & Prometheus style expressions")
|
|
}
|
|
|
|
if p.Expr == "" && p.GrafanaManagedCondition == nil {
|
|
return fmt.Errorf("missing either Grafana or Prometheus style expressions")
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (p *TestRulePayload) Type() (backend Backend) {
|
|
if p.Expr != "" {
|
|
return LoTexRulerBackend
|
|
}
|
|
|
|
if p.GrafanaManagedCondition != nil {
|
|
return GrafanaBackend
|
|
}
|
|
|
|
return
|
|
}
|
|
|
|
// swagger:model
|
|
type TestRuleResponse struct {
|
|
Alerts promql.Vector `json:"alerts"`
|
|
GrafanaAlertInstances AlertInstancesResponse `json:"grafana_alert_instances"`
|
|
}
|
|
|
|
// swagger:model
|
|
type AlertInstancesResponse struct {
|
|
// Instances is an array of arrow encoded dataframes
|
|
// each frame has a single row, and a column for each instance (alert identified by unique labels) with a boolean value (firing/not firing)
|
|
Instances [][]byte `json:"instances"`
|
|
}
|
|
|
|
// swagger:model
|
|
type ExtendedReceiver struct {
|
|
EmailConfigs config.EmailConfig `yaml:"email_configs,omitempty" json:"email_configs,omitempty"`
|
|
PagerdutyConfigs config.PagerdutyConfig `yaml:"pagerduty_configs,omitempty" json:"pagerduty_configs,omitempty"`
|
|
SlackConfigs config.SlackConfig `yaml:"slack_configs,omitempty" json:"slack_configs,omitempty"`
|
|
WebhookConfigs config.WebhookConfig `yaml:"webhook_configs,omitempty" json:"webhook_configs,omitempty"`
|
|
OpsGenieConfigs config.OpsGenieConfig `yaml:"opsgenie_configs,omitempty" json:"opsgenie_configs,omitempty"`
|
|
WechatConfigs config.WechatConfig `yaml:"wechat_configs,omitempty" json:"wechat_configs,omitempty"`
|
|
PushoverConfigs config.PushoverConfig `yaml:"pushover_configs,omitempty" json:"pushover_configs,omitempty"`
|
|
VictorOpsConfigs config.VictorOpsConfig `yaml:"victorops_configs,omitempty" json:"victorops_configs,omitempty"`
|
|
GrafanaReceiver PostableGrafanaReceiver `yaml:"grafana_managed_receiver,omitempty" json:"grafana_managed_receiver,omitempty"`
|
|
}
|
|
|
|
// swagger:model
|
|
type Success ResponseDetails
|
|
|
|
// swagger:model
|
|
type SmtpNotEnabled ResponseDetails
|
|
|
|
// swagger:model
|
|
type Failure ResponseDetails
|
|
|
|
// swagger:model
|
|
type ResponseDetails struct {
|
|
Msg string `json:"msg"`
|
|
}
|