AWS Web Application Firewall (WAF) should be integrated with API Gateway to protect your APIs from common web exploits such as SQLi attacks, XSS attacks and Cross-Site Request Forgery (CSRF) attacks.
In the navigation pane, choose the API Gateway that you want to inspect.
In the API Gateway dashboard, select the APIs section. This will display a list of all your APIs.
For each API, check the ‘Stage’ settings. If there is no Web Application Firewall (WAF) associated with the API, then the API Gateway is not integrated with WAF. This is a misconfiguration as it could potentially expose the API to various types of attacks.
Using CLI
List all API Gateways:
First, you need to list all the API Gateways in your AWS account. You can do this by using the get-rest-apis command in AWS CLI. The command is as follows:
aws apigateway get-rest-apis --region your-region
Replace ‘your-region’ with the region of your AWS account. This command will return a list of all the API Gateways in your account.
Get the details of each API Gateway:
For each API Gateway returned in the previous step, you need to get its details. You can do this by using the get-rest-api command in AWS CLI. The command is as follows:
Replace ‘your-rest-api-id’ with the ID of the API Gateway and ‘your-region’ with the region of your AWS account. This command will return the details of the API Gateway.
Check if the API Gateway is integrated with WAF:
In the details of the API Gateway returned in the previous step, look for the ‘webAclArn’ field. If this field is present and not empty, it means that the API Gateway is integrated with WAF.
Automate the process:
You can automate the above steps by writing a script in Python using the Boto3 library. The script will use the get_rest_apis and get_rest_api methods of the boto3.client('apigateway') object to get the list of API Gateways and their details respectively. It will then check if the ‘webAclArn’ field is present and not empty for each API Gateway.
Using Python
Install the necessary Python libraries: Before you start, make sure you have the AWS SDK for Python (Boto3) installed, which allows you to write software that makes use of services like Amazon S3, Amazon EC2, etc.
pip install boto3
Establish a session: You need to establish a session using your AWS credentials.
Check if WAF is integrated: For each API Gateway, check if it is integrated with WAF. You can do this by calling the get_web_acl_for_resource function from the WAF Regional client. If the API Gateway is not integrated with WAF, the function will throw an exception.
waf_client = session.client('waf-regional')for api in response['items']: try: waf_response = waf_client.get_web_acl_for_resource( ResourceArn=api['id'] ) print(f"API Gateway {api['name']} is integrated with WAF") except Exception as e: print(f"API Gateway {api['name']} is not integrated with WAF")
This script will print out the names of all API Gateways and whether they are integrated with WAF. If an API Gateway is not integrated with WAF, it may be a misconfiguration.
Sure, here are the step by step instructions on how to remediate this misconfiguration:
Open the AWS Management Console and navigate to the Amazon API Gateway service.
Select the API Gateway that you want to integrate with WAF.
Click on the “Settings” tab in the left-hand menu.
Under the “Security” section, click on the “Edit” button next to “Web Application Firewall”.
In the “Configure WAF” window, select “Create a new WAF web ACL” or “Use existing WAF web ACL” depending on your preference.
If you select “Create a new WAF web ACL”, you will be prompted to create a new web ACL. Follow the steps to create a new web ACL and click “Create”.
If you select “Use existing WAF web ACL”, select the web ACL that you want to use from the dropdown list.
Click “Save” to save the changes.
Once the integration is complete, you can test it by sending requests to your API Gateway and verifying that the WAF is blocking any malicious requests.
That’s it! Your API Gateway is now integrated with WAF and is protected from common web attacks.
This command should return the ARN of the API Gateway that was integrated with the WAF.
By following these steps, you can remediate the misconfiguration “API Gateway Should Be Integrated With WAF” for AWS using AWS CLI.
Using Python
To remediate the misconfiguration of API Gateway not being integrated with WAF in AWS using Python, you can follow these steps:
Import the necessary AWS SDKs and modules in your Python script. You will need to import the boto3 module to interact with AWS services.
Use the boto3 module to retrieve the ARN of the WAF web ACL that you want to associate with your API Gateway.
import boto3# Create a WAF clientwaf_client = boto3.client('waf')# Retrieve the ARN of the WAF web ACL that you want to associate with your API Gatewayweb_acl_arn = waf_client.get_web_acl(WebACLId='web_acl_id')['WebACL']['ARN']
Use the boto3 module to update the API Gateway to associate it with the WAF web ACL.
# Create an API Gateway clientapigateway_client = boto3.client('apigateway')# Update the API Gateway to associate it with the WAF web ACLapigateway_client.update_security_configuration( restApiId='rest_api_id', patchOperations=[ { 'op': 'replace', 'path': '/wafWebAclArn', 'value': web_acl_arn } ])
Note: Replace web_acl_id with the ID of the WAF web ACL that you want to associate with your API Gateway, and replace rest_api_id with the ID of your API Gateway.
Run the Python script to remediate the misconfiguration of API Gateway not being integrated with WAF in AWS.
After following these steps, your API Gateway will be integrated with WAF, which will help protect your API from common web exploits and attacks.