-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
Co-authored-by: raj <[email protected]>
- Loading branch information
1 parent
776d371
commit 4e88332
Showing
19 changed files
with
202 additions
and
1 deletion.
There are no files selected for viewing
Binary file added
BIN
+233 KB
.../troubleshooting/fix-calc-policy-evaluation-errors/calc-policy-builder-page.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+167 KB
...oubleshooting/fix-calc-policy-evaluation-errors/guardrails-control-ok-state.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+260 KB
...shooting/fix-calc-policy-evaluation-errors/guardrails-launch-policy-builder.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+253 KB
...roubleshooting/fix-calc-policy-evaluation-errors/guardrails-policy-value-ok.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+273 KB
...bleshooting/fix-calc-policy-evaluation-errors/guardrails-resolve-cal-policy.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+93.3 KB
...ng/fix-calc-policy-evaluation-errors/guardrails-select-calc-policy-in-error.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+218 KB
...ls/troubleshooting/fix-calc-policy-evaluation-errors/guardrails-select-edit.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+276 KB
...g/fix-calc-policy-evaluation-errors/guardrails-select-effective-calc-policy.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+112 KB
...roubleshooting/fix-calc-policy-evaluation-errors/guardrails-select-policies.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+259 KB
.../troubleshooting/fix-calc-policy-evaluation-errors/guardrails-update-policy.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
80 changes: 80 additions & 0 deletions
80
...des/using-guardrails/troubleshooting/fix-calc-policy-evaluation-errors/index.md
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,80 @@ | ||
--- | ||
title: Resolve Calculated Policy Errors | ||
sidebar_label: Resolve Calculated Policy Errors | ||
--- | ||
|
||
# Resolve Calculated Policy Evaluation Errors | ||
|
||
In this guide, you will: | ||
- Use Guardrails console to identify and resolve calculated policy evaluation errors. | ||
|
||
A [Calculated Policy](/guardrails/docs/reference/glossary#calculated-policy) dynamically determines policy settings by sourcing CMDB data, executing a GraphQL query, and applying a [Nunjucks](/guardrails/docs/guides/using-guardrails/nunjucks) template to generate a resource-specific policy value. Any policy setting can be calculated, making policies more context-aware and adaptable. | ||
|
||
However, calculated policies can sometimes encounter errors due to misconfigurations or data inconsistencies, leading to controls entering an error state. Ensuring these policies are properly configured and promptly fixed is crucial for maintaining compliance and system stability. | ||
|
||
## Prerequisites | ||
|
||
- **Turbot/Admin** permissions at the Turbot resource level. | ||
- Familiarity with the Guardrails console. | ||
- Knowledge of the [Jinja2/Nunjucks](https://jinja.palletsprojects.com/en/stable/templates/) template language. | ||
|
||
## Step 1: Navigate to Policies | ||
|
||
Log into the Guardrails console with provided local credentials or by using any SAML based login and Select **Policies** from the top navigation menu. | ||
|
||
data:image/s3,"s3://crabby-images/00152/00152e96e98520a223d5ef8563cf9a40fdd66136" alt="Navigate to Reports" | ||
|
||
## Step 2: Select Policy Value | ||
|
||
Select the calculated policy in an error state that needs to be resolved. This redirects to the Policy Value page, where the error message is displayed. | ||
|
||
Here, the error occurs due to `TypeError: Cannot read properties of undefined (reading 'toString')`, indicating that the referenced property is undefined and cannot be converted to a string. | ||
|
||
data:image/s3,"s3://crabby-images/ee14a/ee14a336cba2c2eff815f90ef8776034d3cd6ac6" alt="Select Calculated Policy" | ||
|
||
## Step 3: Select Calculated Policy | ||
|
||
Select the **Calculated** policy, with an ✅ `EFFECTIVE SETTING`. | ||
|
||
data:image/s3,"s3://crabby-images/d337a/d337a13da0bceff6ddb882a2e2e8e4824f589d1a" alt="Effective Setting" | ||
|
||
## Step 4: Edit Policy Setting | ||
|
||
Select **Edit** from the top right corner. | ||
|
||
data:image/s3,"s3://crabby-images/9812d/9812db6b5471728a50b657e6edcea7e34ffb0f20" alt="Select Edit" | ||
|
||
Choose **Launch calculated policy builder**. | ||
|
||
data:image/s3,"s3://crabby-images/9ed98/9ed98a9e4d5520005e35c3ade87676a46fd5b9c9" alt="Launch Calculated Policy Builder" | ||
|
||
This displays the `GraphQL` query and `Jinja2/Nunjucks` template used in the calculated policy, providing insight into how the policy value is generated. | ||
|
||
data:image/s3,"s3://crabby-images/2937d/2937d88949d03cad8b030f78eafe30b4c717847b" alt="Calculated Policy Builder Page" | ||
|
||
## Step 5: Resolve Calculated Policy | ||
|
||
Select the `Test Resource`, update the corrected Jinja2/Nunjucks template, and view the real-time output to verify if the fix is successful. Choose **Update**. | ||
|
||
data:image/s3,"s3://crabby-images/ad3ba/ad3bab7cfc6b2bb2fd534e51d75f9546f4969d8f" alt="Resolve Error" | ||
|
||
Select **Update** from the Update Policy Setting page. | ||
|
||
data:image/s3,"s3://crabby-images/e6733/e67331b95f5da0c7cc77c809c3833fd9480f9f88" alt="Select Update" | ||
|
||
## Step 6: Review | ||
|
||
- [ ] Verify that the policy value transitions to an `OK` state, confirming the issue has been resolved successfully. | ||
|
||
data:image/s3,"s3://crabby-images/0a4b6/0a4b6a231cf7dea58844758f5d8ad059e757f661" alt="Policy Value State" | ||
|
||
- [ ] Verify that the affected control transitions to an `OK` state. | ||
|
||
data:image/s3,"s3://crabby-images/a7d4e/a7d4ee3f0ec1c96c7ab1322bfe4fd80452acc8b3" alt="Control State" | ||
|
||
## Troubleshooting | ||
|
||
| Issue | Description | Guide | | ||
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | ||
| Common errors. | Any common errors preventing controls to run. |Refer [Common Troubleshooting](/guardrails/docs/guides/troubleshooting) for more information. | ||
| Further Assistance | If you encounter further issues with Calculated Policies, please open a ticket with us and attach the relevant information to assist you more efficiently. | [Open Support Ticket](https://support.turbot.com) | |
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
Binary file added
BIN
+259 KB
...s/troubleshooting/run-controls-using-scripts/github-guardrails-samples-repo.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+127 KB
.../troubleshooting/run-controls-using-scripts/guardrails-navigate-to-controls.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+112 KB
.../troubleshooting/run-controls-using-scripts/guardrails-retrieve-control-uri.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+159 KB
...troubleshooting/run-controls-using-scripts/guardrails-verify-control-status.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+227 KB
...rdrails/troubleshooting/run-controls-using-scripts/identify-controls-errors.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
118 changes: 118 additions & 0 deletions
118
docs/guides/using-guardrails/troubleshooting/run-controls-using-scripts/index.md
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,118 @@ | ||
--- | ||
title: Run Controls Using Scripts | ||
sidebar_label: Run Controls Using Scripts | ||
--- | ||
|
||
# Run Controls Using Scripts | ||
|
||
In this guide, you will: | ||
- Use the Guardrails Console to identify controls in an error state and resolve them using scripts. | ||
|
||
[Controls](/guardrails/docs/reference/glossary#control) enforce [policies](/guardrails/docs/reference/glossary#policy) to ensure cloud resources remain compliant and Guardrails operates effectively. However, a large number of controls may encounter errors due to factors like network outages. To efficiently resolve these errors, use the script available in the [guardrails-samples](https://github.com/turbot/guardrails-samples/tree/main/guardrails_utilities/shell_utils/run-controls) GitHub repository to rerun the affected controls. Regularly addressing controls in an Error state helps maintain system stability and compliance. | ||
|
||
## Prerequisites | ||
|
||
- **Turbot/Operator** permissions at the Turbot resource level. | ||
- Familiarity with Github and the Guardrails console. | ||
|
||
## Step 1: Navigate to Controls | ||
|
||
Log into the Guardrails console with provided local credentials or by using any SAML based login and Select **Controls** from the top navigation menu. | ||
|
||
data:image/s3,"s3://crabby-images/0b2a2/0b2a2755ec84accd56e2d6c844c5e38a35aa4dd0" alt="Navigate to Controls" | ||
|
||
## Step 2: Identify Control Errors | ||
|
||
In the Controls section, filter and select the controls in an `Error` state that need to be re-run. | ||
|
||
data:image/s3,"s3://crabby-images/97e40/97e406c47cc89908e5d1c2cf853b9712c54621f5" alt="Identify Control Errors" | ||
|
||
## Step 3: Retrieve Control Type URI | ||
|
||
Open the control details, navigate to the **Developers** tab, and copy the `Control Type URI` for use in later steps. | ||
|
||
data:image/s3,"s3://crabby-images/02bd4/02bd48fc0602fdcee07332ee6b6366ae02d435bd" alt="Control Type URI" | ||
|
||
## Step 4: Clone Guardrails Samples Repository | ||
|
||
Go to [guardrails-samples](https://github.com/turbot/guardrails-samples) and clone the repository. | ||
|
||
data:image/s3,"s3://crabby-images/79a3e/79a3e2737ad6eb9d543ceef8342fe4794aca0c10" alt="Guardrails Samples" | ||
|
||
## Step 5: Navigate to Run-Controls Directory | ||
|
||
In the cloned repository, navigate to the following folder: | ||
|
||
`guardrails_utilities/shell_utils/run-controls` | ||
|
||
## Step 6: Set Environment Variables | ||
|
||
Set the necessary environment variables using the command below: | ||
|
||
``` | ||
export TURBOT_WORKSPACE="https://<environment-name>.cloud.turbot.com/" | ||
export TURBOT_ACCESS_KEY_ID=ac61d2e4-730c-4b54-8c3c-6ef172390814 | ||
export TURBOT_SECRET_ACCESS_KEY=151b296b-0694-4a28-94c4-4b67fa82ab2c | ||
``` | ||
|
||
## Step 7: Run Controls via Script | ||
|
||
Execute this script using the Control Type URI from [Step 3](#step-3-retrieve-control-type-uri). The batch size is set to 25 to minimize database load. | ||
|
||
``` | ||
./run-controls.sh --filter 'state:error controlTypeId:tmod:@turbot/turbot#/control/types/controlInstalled' --batch-size 25 | ||
``` | ||
The script should start running and output results similar to below: | ||
|
||
``` | ||
[INFO] Control 1 of 22 | ||
[INFO] Type: "Type Installed" | ||
[INFO] Resource: "Turbot > @turbot/aws-rds > Update Performance Configuration" | ||
[INFO] State: "error" | ||
[INFO] Reason: "Error running trusted inline" | ||
[INFO] ID: "311522861481171" | ||
[INFO] Control 2 of 22 | ||
[INFO] Type: "Type Installed" | ||
[INFO] Resource: "Turbot > @turbot/aws-rds > Set Tags" | ||
[INFO] State: "error" | ||
[INFO] Reason: "Error running trusted inline" | ||
[INFO] ID: "293907562769114" | ||
[INFO] Control 3 of 22 | ||
[INFO] Type: "Type Installed" | ||
[INFO] Resource: "Turbot > @turbot/aws-rds > Delete from AWS" | ||
[INFO] State: "error" | ||
[INFO] Reason: "Error running trusted inline" | ||
[INFO] ID: "293907548601779" | ||
[INFO] Control 4 of 22 | ||
[INFO] Type: "Type Installed" | ||
[INFO] Resource: "Turbot > @turbot/aws-rds > Delete from AWS" | ||
[INFO] State: "error" | ||
[INFO] Reason: "Error running trusted inline" | ||
[INFO] ID: "293907547759782" | ||
[INFO] Control 22 of 22 | ||
[INFO] Type: "Type Installed" | ||
[INFO] Resource: "Turbot > @turbot/aws-rds > Update Access Logging" | ||
[INFO] State: "error" | ||
[INFO] Reason: "Error running trusted inline" | ||
[INFO] ID: "195756668765883" | ||
[INFO] Total amount of controls re-run: 22 | ||
[INFO] Total time taken 7 second(s) | ||
``` | ||
|
||
The command stops once all controls have successfully run. | ||
|
||
## Step 8: Verify Control Status | ||
|
||
Confirm that all controls have moved to an `OK` state. | ||
|
||
data:image/s3,"s3://crabby-images/6123e/6123e5a1f6ce1d383751504c77d6c5a06282e455" alt="Navigate to Reports" | ||
|
||
**Additional Execution for Policies** | ||
|
||
To resolve policies in an Error state, execute the run-policies script using the same approach. | ||
|
||
## Troubleshooting | ||
|
||
| Issue | Description | Guide | | ||
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | ||
| Further Assistance | If you encounter further issues with Calculated Policies, please open a ticket with us and attach the relevant information to assist you more efficiently. | [Open Support Ticket](https://support.turbot.com) | |
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