feat(alerting): custom alert support endpoint errors (#844)
* feat(alerting): add support for including endpoint errors in custom alerts - Updated `buildHTTPRequest` method in `AlertProvider` to accept a `result` parameter. - Added support for including `[ENDPOINT_ERRORS]` in both the request body and URL, which will be replaced by the errors from `Result.Errors[]`. - Adjusted `CreateExternalEndpointResult` to capture and store errors from query parameters. - This allows custom alerts to include detailed error information, enhancing the flexibility of alert notifications. * feat: add ENDPOINT_ERRORS example * feat: add tests * Refactor: code review feedback * delete unsed errors * Update README.md * Apply suggestions from code review --------- Co-authored-by: raojinlin <raojinlin302@gmail.com> Co-authored-by: TwiN <twin@linux.com>
This commit is contained in:
		| @ -50,7 +50,7 @@ func (provider *AlertProvider) GetAlertStatePlaceholderValue(resolved bool) stri | ||||
| 	return status | ||||
| } | ||||
|  | ||||
| func (provider *AlertProvider) buildHTTPRequest(ep *endpoint.Endpoint, alert *alert.Alert, resolved bool) *http.Request { | ||||
| func (provider *AlertProvider) buildHTTPRequest(ep *endpoint.Endpoint, alert *alert.Alert, result *endpoint.Result, resolved bool) *http.Request { | ||||
| 	body, url, method := provider.Body, provider.URL, provider.Method | ||||
| 	body = strings.ReplaceAll(body, "[ALERT_DESCRIPTION]", alert.GetDescription()) | ||||
| 	url = strings.ReplaceAll(url, "[ALERT_DESCRIPTION]", alert.GetDescription()) | ||||
| @ -60,6 +60,8 @@ func (provider *AlertProvider) buildHTTPRequest(ep *endpoint.Endpoint, alert *al | ||||
| 	url = strings.ReplaceAll(url, "[ENDPOINT_GROUP]", ep.Group) | ||||
| 	body = strings.ReplaceAll(body, "[ENDPOINT_URL]", ep.URL) | ||||
| 	url = strings.ReplaceAll(url, "[ENDPOINT_URL]", ep.URL) | ||||
| 	body = strings.ReplaceAll(body, "[RESULT_ERRORS]", strings.Join(result.Errors, ",")) | ||||
| 	url = strings.ReplaceAll(url, "[RESULT_ERRORS]", strings.Join(result.Errors, ",")) | ||||
| 	if resolved { | ||||
| 		body = strings.ReplaceAll(body, "[ALERT_TRIGGERED_OR_RESOLVED]", provider.GetAlertStatePlaceholderValue(true)) | ||||
| 		url = strings.ReplaceAll(url, "[ALERT_TRIGGERED_OR_RESOLVED]", provider.GetAlertStatePlaceholderValue(true)) | ||||
| @ -79,7 +81,7 @@ func (provider *AlertProvider) buildHTTPRequest(ep *endpoint.Endpoint, alert *al | ||||
| } | ||||
|  | ||||
| func (provider *AlertProvider) Send(ep *endpoint.Endpoint, alert *alert.Alert, result *endpoint.Result, resolved bool) error { | ||||
| 	request := provider.buildHTTPRequest(ep, alert, resolved) | ||||
| 	request := provider.buildHTTPRequest(ep, alert, result, resolved) | ||||
| 	response, err := client.GetHTTPClient(provider.ClientConfig).Do(request) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
|  | ||||
		Reference in New Issue
	
	Block a user