Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Overview

AWS Web Application Firewall (WAF) lets you monitor the HTTP and HTTPS requests that are forwarded to your protected web application resources. You can protect the following resource types: Amazon CloudFront distribution, Amazon API Gateway REST API, Application Load Balancer, AWS AppSync GraphQL API, Amazon Cognito user pool and AWS App Runner service. AWS WAF will let you control access to your content based on the conditions that you set such as blocking requests that originate from IP addresses or the values of query strings.

Info

AWS WAF is a web application firewall that helps protect web applications or APIs against common web exploits that may affect availability, compromise security, or consume excessive resources. AWS WAF uses security rules that block common attack patterns, such as SQL injection, cross-site scripting, or items in the OWASP Top 10 security risks. These rules are regularly updated as new issues emerge.

Collection

AWS WAF service can be configured to enable logging and publish logs to Amazon CloudWatch Logs log group.

While AWS CloudWatch Logs log group can be configured to have a subscription filter and have it deliver the published event logs received to Amazon Kinesis Data Stream.

Then Snare Central can be configured to periodically call AWS API to pull and get the log data stored in AWS Kinesis Data Stream.

Sample Log Event

Expand
titleA rule that triggered on SQLi detection (terminating)
{
"timestamp": 1672905162070,
"formatVersion": 1,
"webaclId": "arn:aws:wafv2:ap-southeast-2:123456789012:regional/webacl/Test/1SAMPLE-2ARN-1234567890EXAMPLE",
"terminatingRuleId": "Test_SQLi",
"terminatingRuleType": "REGULAR",
"action": "BLOCK",
"terminatingRuleMatchDetails": [
{
"conditionType": "SQL_INJECTION",
"sensitivityLevel": "HIGH",
"location": "HEADER",
"matchedData": [
"15",
"AND",
"3"
]
}
],
"httpSourceName": "-",
"httpSourceId": "-",
"ruleGroupList": [],
"rateBasedRuleList": [],
"nonTerminatingMatchingRules": [],
"httpRequest": {
"clientIp": "202.3.11.17",
"country": "AU",
"headers": [
{
"name": "Host",
"value": "localhost:1985"
},
{
"name": "User-Agent",
"value": "curl/7.61.1"
},
{
"name": "Accept",
"value": "/"
},
{
"name": "test",
"value": "15 AND 3=3"
}
],
"uri": "/myUri/sample",
"args": "",
"httpVersion": "HTTP/1.1",
"httpMethod": "GET",
"requestId": "rid1234567890"
}
}

Table Fields

Field

Description

DATE

timestamp - The date extracted from converting the timestamp integer representing milliseconds in UTC since the epoch (1970-01-01 00:00:00 UTC) to "2006-01-02T15:04:05Z" in YYYY-MM-DD format.

TIME

timestamp - The time extracted from converting the timestamp integer representing milliseconds in UTC since the epoch (1970-01-01 00:00:00 UTC) to "2006-01-02T15:04:05Z" in HH:MM:SS format.

SYSTEM

Host - The host value extracted under httpRequest/headers/name=”Host","value":"localhost:1985", removing the port value if present.

TABLE

AWSWAFLog

COLLECTIONDATETIME

Snare Central’s local date and time of the actual log collection from AWS Kinesis Data Stream in RFC3339Nano format.

CWLDATETIME

AWS CloudWatch Log’s timestamp when it receives the event log from other AWS services in RFC3339Nano format.

DATETIME

timestamp - The date and time extracted from converting the timestamp integer representing milliseconds in UTC since the epoch (1970-01-01 00:00:00 UTC) to "2006-01-02T15:04:05Z" in RFC3339Nano format.

ACTION

action - The action that was applied to the request.

Allow and Block are terminating rule actions, Count is a non-terminating rule action while CAPTCHA and Challenge are non-terminating if the request includes a valid token and terminating if it doesn't.

ARGS

args - The query string.

CLIENTIP

clientIp - The IP address of the client sending the request.

COUNTRY

country - The source country of the request.

If AWS WAF is unable to determine the country of origin, it sets this field to "-".

HTTPMETHOD

httpMethod - The HTTP method in the request.

HTTPSOURCEID

httpSourceId - The ID of the associated resource.

HTTPSOURCENAME

httpSourceName - The source of the request.

Possible values are CF for Amazon CloudFront, APIGW for Amazon API Gateway, ALB for Application Load Balancer, APPSYNC for AWS AppSync, COGNITOIDP for Amazon Cognito, and APPRUNNER for App Runner.

NONTERMINATINGMATCHINGRULES

nonTerminatingMatchingRules - The list of non-terminating rules that match the request.

Contains:

action - The action that AWS WAF applied to the request.

overriddenAction - Used only for rule group rules that have a rule action override in place in the web ACL.

ruleId - The ID of the rule that matched the request and was non-terminating.

ruleMatchDetails - Detailed information about the rule that matched the request. This field is only populated for SQL injection and cross-site scripting (XSS) match rule statements. A matching rule might require a match for more than one inspection criteria, so these match details are provided as an array of match criteria.

PORT

X-Forwarded-Port - the X-Forwarded-Port value extracted under httpRequest/headers/name="X-Forwarded-Port","value":"1985" or extracted from host value httpRequest/headers/name="Host","value":"localhost:1985" port part.

RESPONSECODESENT

responseCodeSent - The response code sent with a custom response.

REQUESTID

requestId - The ID of the request, which is generated by the underlying host service.

For Application Load Balancer, this is the trace ID.

RULEGROUPLIST

ruleGroupList - The list of rule groups that acted on this request, with match information.

TERMINATINGRULEID

terminatingRuleId - The ID of the rule that terminated the request.

If nothing terminates the request, the value is Default_Action

TERMINATINGRULEMATCHDETAILS

terminatingRuleMatchDetails - Detailed information about the terminating rule that matched the request.

During the inspection of a web request, at the first rule that matches the request and that has a terminating action, AWS WAF stops the inspection and applies the action so the web request might contain other threats, in addition to the one that's reported in the log for the matching terminating rule.

TERMINATINGRULETYPE

terminatingRuleType - The type of rule that terminated the request.

Possible values: RATE_BASED, REGULAR, GROUP, and MANAGED_RULE_GROUP.

URI

uri - The URI of the request.

USERAGENT

User-Agent / user-agent - The agent through which the request was made.

WEBACLID

webaclId - The GUID of the web ACL.

SNAREDATAMAP

All unclassified field/s in the log will be pushed into the SNAREDATAMAP.

Notes

https://docs.aws.amazon.com/waf/latest/developerguide/what-is-aws-waf.html

https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html