-
Notifications
You must be signed in to change notification settings - Fork 790
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
103 changed files
with
6,637 additions
and
5,163 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
--- | ||
title: "Alert Enrichment - Mapping" | ||
--- | ||
|
||
# Alert Mapping and Enrichment | ||
|
||
Keep's Alert Mapping and Enrichment feature provides a powerful mechanism for dynamically enhancing alert data by leveraging external data sources, such as CSV files. This feature allows for the matching of incoming alerts to specific records in a CSV file based on predefined attributes (matchers) and enriching those alerts with additional information from the matched records. | ||
|
||
## Introduction | ||
|
||
In complex monitoring environments, the need to enrich alert data with additional context is critical for effective alert analysis and response. Keep's Alert Mapping and Enrichment enables users to define rules that match alerts to rows in a CSV file, appending or modifying alert attributes with the values from matching rows. This process adds significant value to each alert, providing deeper insights and enabling more precise and informed decision-making. | ||
|
||
## How It Works | ||
|
||
1. **Rule Definition**: Users define mapping rules that specify which alert attributes (matchers) should be used for matching alerts to rows in a CSV file. | ||
2. **CSV File Specification**: A CSV file is associated with each mapping rule. This file contains additional data that should be added to alerts matching the rule. | ||
3. **Alert Matching**: When an alert is received, the system checks if it matches the conditions of any mapping rule based on the specified matchers. | ||
4. **Data Enrichment**: If a match is found, the alert is enriched with additional data from the corresponding row in the CSV file. | ||
|
||
## Core Concepts | ||
|
||
- **Matchers**: Attributes within the alert used to identify matching rows within the CSV file. Common matchers include identifiers like `service` or `region`. | ||
- **CSV File**: A structured file containing rows of data. Each column represents a potential attribute that can be added to an alert. | ||
- **Enrichment**: The process of adding new attributes or modifying existing ones in an alert based on the data from a matching CSV row. | ||
|
||
## Creating a Mapping Rule | ||
|
||
To create an alert mapping and enrichment rule: | ||
|
||
<Frame width="100" height="200"> | ||
<img height="10" src="/images/rule-creation.png" /> | ||
</Frame> | ||
|
||
1. **Define the Matchers**: Specify which alert attributes will be used to match rows in the CSV file. | ||
2. **Upload the CSV File**: Provide the CSV file containing the data for enrichment. | ||
3. **Configure the Rule**: Set additional parameters, such as whether the rule should override existing alert attributes. | ||
|
||
## Practical Example | ||
|
||
Imagine you have a CSV file with columns representing different aspects of your infrastructure, such as `region`, `responsible_team`, and `severity_override`. By creating a mapping rule that matches alerts based on `service` and `region`, you can automatically enrich alerts with the responsible team and adjust severity based on the matched row in the CSV file. | ||
|
||
## Best Practices | ||
|
||
- **Keep CSV Files Updated**: Regularly update the CSV files to reflect the current state of your infrastructure and operational data. | ||
- **Use Specific Matchers**: Define matchers that are unique and relevant to ensure accurate matching. | ||
- **Monitor Rule Performance**: Review the application of mapping rules to ensure they are working as expected and adjust them as necessary. | ||
|
||
<Frame width="100" height="200"> | ||
<img height="10" src="/images/rule-table.png" /> | ||
</Frame> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
workflow: | ||
id: Resend-Python-service | ||
description: Python Resend Mail | ||
triggers: | ||
- type: manual | ||
owners: [] | ||
services: [] | ||
steps: | ||
- name: run-script | ||
provider: | ||
config: '{{ providers.default-bash }}' | ||
type: bash | ||
with: | ||
command: python3 test.py | ||
timeout: 5 | ||
actions: | ||
- condition: | ||
- assert: '{{ steps.run-script.results.return_code }} == 0' | ||
name: assert-condition | ||
type: assert | ||
name: trigger-resend | ||
provider: | ||
type: resend | ||
config: "{{ providers.resend-test }}" | ||
with: | ||
_from: "[email protected]" | ||
to: "[email protected]" | ||
subject: "Python test is up!" | ||
html: <p>Python test is up!</p> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
import AlertsPage from "../alerts.client"; | ||
|
||
type PageProps = { | ||
params: { id: string }; | ||
searchParams: { [key: string]: string | string[] | undefined }; | ||
}; | ||
|
||
export default function Page({ params }: PageProps) { | ||
return <AlertsPage presetName={params.id} />; | ||
} | ||
|
||
export const metadata = { | ||
title: "Keep - Alerts", | ||
description: "Single pane of glass for all your alerts.", | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.