Azure Firewall Logs
editAzure Firewall Logs
editVersion |
1.20.1 (View all) |
Compatible Kibana version(s) |
8.13.0 or higher |
Supported Serverless project types |
Security |
Subscription level |
Basic |
Azure Firewall Logs are records of events such as network and application rules that occur within your Azure Firewalls. They provide visibility and can be used to troubleshoot issues related to access, conectivity or performance.
Supported log categories:
Log Category | Description | Destination Table |
---|---|---|
AzureFirewallApplicationRule |
These logs capture information about the traffic that is allowed or denied by application rules configured in Azure Firewall. |
Azure diagnostics |
AzureFirewallNetworkRule |
These logs capture information about the traffic that is allowed or denied by network rules configured in Azure Firewall. |
Azure diagnostics |
AzureFirewallDnsProxy |
These logs capture information about DNS requests and responses that are processed by Azure Firewall’s DNS proxy. |
Azure diagnostics |
AZFWApplicationRule |
These logs capture resource specific information about the traffic that is allowed or denied by application rules configured in Azure Firewall. |
Resource specific |
AZFWNetworkRule |
These logs capture resource specific information about the traffic that is allowed or denied by network rules configured in Azure Firewall. |
Resource specific |
AZFWNatRule |
These logs capture resource specific information about all DNAT (Destination Network Address Translation) events log data. |
Resource specific |
AZFWDnsQuery |
These logs capture resource specific information about DNS requests and responses that are processed by Azure Firewall’s DNS proxy. |
Resource specific |
For detailed information and instructions on how to migrate to Resource-specific mode, please refer to the following Microsoft documentation: Azure Monitor Resource Logs.
All Azure services will eventually use the resource-specific mode. As part of this transition, some resources allow you to select a mode in the diagnostic setting. Specify resource-specific mode for any new diagnostic settings because this mode makes the data easier to manage.
Requirements and setup
editRefer to the Azure Logs page for more information about setting up and using this integration.
Settings
editeventhub
:
string
An Event Hub is a fully managed, real-time data ingestion service. Elastic recommends using only letters, numbers, and the hyphen (-) character for Event Hub names to maximize compatibility. You can use existing Event Hubs having underscores (_) in the Event Hub name; in this case, the integration will replace underscores with hyphens (-) when it uses the Event Hub name to create dependent Azure resources behind the scenes (e.g., the storage account container to store Event Hub consumer offsets). Elastic also recommends using a separate event hub for each log type as the field mappings of each log type differ.
Default value insights-operational-logs
.
consumer_group
:
string
The publish/subscribe mechanism of Event Hubs is enabled through consumer groups. A consumer group is a view (state, position, or offset) of an entire event hub. Consumer groups enable multiple consuming applications to each have a separate view of the event stream, and to read the stream independently at their own pace and with their own offsets.
Default value: $Default
connection_string
:
string
The connection string is required to communicate with Event Hubs, see steps here.
A Blob Storage account is required in order to store/retrieve/update the offset or state of the eventhub messages. This means that after stopping the Azure logs package it can start back up at the spot that it stopped processing messages.
storage_account
:
string
The name of the storage account where the state/offsets will be stored and updated.
storage_account_key
:
string
The storage account key, this key will be used to authorize access to data in your storage account.
storage_account_container
:
string
The storage account container where the integration stores the checkpoint data for the consumer group. It is an advanced option to use with extreme care. You MUST use a dedicated storage account container for each Azure log type (activity, sign-in, audit logs, and others). DO NOT REUSE the same container name for more than one Azure log type. See Container Names for details on naming rules from Microsoft. The integration generates a default container name if not specified.
resource_manager_endpoint
:
string
Optional, by default we are using the azure public environment, to override, users can provide a specific resource manager endpoint in order to use a different azure environment.
Resource manager endpoints:
# Azure ChinaCloud https://management.chinacloudapi.cn/ # Azure GermanCloud https://management.microsoftazure.de/ # Azure PublicCloud https://management.azure.com/ # Azure USGovernmentCloud https://management.usgovcloudapi.net/
Logs
editfirewall_logs
editThe firewall_logs
data stream of the Azure Logs package will collect any firewall log events that have been streamed through an Azure event hub.
Example
An example event for firewall
looks as following:
{ "@timestamp": "2022-06-08T16:54:58.849Z", "azure": { "firewall": { "action": "Deny", "category": "AzureFirewallNetworkRule", "icmp": { "request": { "code": "8" } }, "operation_name": "AzureFirewallNetworkRuleLog" }, "resource": { "group": "TEST-FW-RG", "id": "/SUBSCRIPTIONS/23103928-B2CF-472A-8CDB-0146E2849129/RESOURCEGROUPS/TEST-FW-RG/PROVIDERS/MICROSOFT.NETWORK/AZUREFIREWALLS/TEST-FW01", "name": "TEST-FW01", "provider": "MICROSOFT.NETWORK/AZUREFIREWALLS" }, "subscription_id": "23103928-B2CF-472A-8CDB-0146E2849129" }, "cloud": { "account": { "id": "23103928-B2CF-472A-8CDB-0146E2849129" }, "provider": "azure" }, "destination": { "address": "89.160.20.156", "as": { "number": 29518, "organization": { "name": "Bredband2 AB" } }, "geo": { "city_name": "Linköping", "continent_name": "Europe", "country_iso_code": "SE", "country_name": "Sweden", "location": { "lat": 58.4167, "lon": 15.6167 }, "region_iso_code": "SE-E", "region_name": "Östergötland County" }, "ip": "89.160.20.156" }, "ecs": { "version": "8.11.0" }, "event": { "category": [ "network" ], "kind": "event", "original": "{\"category\":\"AzureFirewallNetworkRule\",\"operationName\":\"AzureFirewallNetworkRuleLog\",\"properties\":{\"msg\":\"ICMP Type=8 request from 192.168.0.2 to 89.160.20.156. Action: Deny. \"},\"resourceId\":\"/SUBSCRIPTIONS/23103928-B2CF-472A-8CDB-0146E2849129/RESOURCEGROUPS/TEST-FW-RG/PROVIDERS/MICROSOFT.NETWORK/AZUREFIREWALLS/TEST-FW01\",\"time\":\"2022-06-08T16:54:58.8492560Z\"}", "type": [ "connection", "denied" ] }, "network": { "transport": "icmp" }, "observer": { "name": "TEST-FW01", "product": "Network Firewall", "type": "firewall", "vendor": "Azure" }, "related": { "ip": [ "192.168.0.2", "89.160.20.156" ] }, "source": { "address": "192.168.0.2", "ip": "192.168.0.2" }, "tags": [ "preserve_original_event" ] }
ECS Field Reference
Please refer to the following document for detailed information on ECS fields.
Exported fields
Field | Description | Type |
---|---|---|
@timestamp |
Event timestamp. |
date |
azure.correlation_id |
Correlation ID |
keyword |
azure.firewall.action |
Action taken by the firewall following the match with the network rule. |
keyword |
azure.firewall.action_reason |
Reason for the action performed by the firewall. |
keyword |
azure.firewall.category |
Category |
keyword |
azure.firewall.dnssec_bool_flag |
True if DNS request is using DNSSEC. |
boolean |
azure.firewall.dnssec_buffer_size |
Size of the DNSSEC buffer. |
long |
azure.firewall.dnssec_ok_bit |
A flag indicating that the resolver supports DNSSEC records. |
boolean |
azure.firewall.duration |
Duration of the firewall request. |
keyword |
azure.firewall.edns0_buffer_size |
Client’s EDNS0 buffer size. Specifies the maximum packet size allowed in responses in bytes. |
long |
azure.firewall.event_original_uid |
UID assigned to the logged event. |
keyword |
azure.firewall.fqdn |
Request target address in FQDN (Fully qualified Domain Name). |
keyword |
azure.firewall.icmp.request.code |
ICMP request code. |
keyword |
azure.firewall.identity_name |
Identity name. |
keyword |
azure.firewall.is_explicit_proxy_request |
True if the request is received on an explicit proxy port. |
boolean |
azure.firewall.is_tls_inspected |
True if the connection is TLS inspected. |
boolean |
azure.firewall.operation_name |
Operation name. |
keyword |
azure.firewall.policy |
Name of the policy in which the triggered rule resides. |
keyword |
azure.firewall.protocol |
Packet’s network protocol. For example: UDP, TCP. |
keyword |
azure.firewall.request_duration_secs |
Duration of the DNS request from the time it arrived to the firewall and until a response was sent to the client. |
double |
azure.firewall.request_size |
The size of the DNS request in bytes. |
long |
azure.firewall.response_code |
DNS reponse code. |
keyword |
azure.firewall.response_flags |
DNS reponse flags, comma separated. |
keyword |
azure.firewall.response_size |
DNS reponse size in bytes. |
long |
azure.firewall.rule |
Name of the triggered rule. |
keyword |
azure.firewall.rule_collection |
Name of the rule collection in which the triggered rule resides. |
keyword |
azure.firewall.rule_collection_group |
Name of the rule collection group in which the triggered rule resides. |
keyword |
azure.firewall.target_url |
Request’s target address URL. |
keyword |
azure.firewall.web_category |
Web Category identified for the requested FQDN (Azure Firewall Standard) or URL (Azure Firewall Premium). |
keyword |
azure.resource.authorization_rule |
Authorization rule |
keyword |
azure.resource.group |
Resource group |
keyword |
azure.resource.id |
Resource ID |
keyword |
azure.resource.name |
Name |
keyword |
azure.resource.namespace |
Resource type/namespace |
keyword |
azure.resource.provider |
Resource type/namespace |
keyword |
azure.subscription_id |
Azure subscription ID |
keyword |
azure.tenant_id |
tenant ID |
keyword |
data_stream.dataset |
Data stream dataset. |
constant_keyword |
data_stream.namespace |
Data stream namespace. |
constant_keyword |
data_stream.type |
Data stream type. |
constant_keyword |
dns.header_flags |
Array of 2 letter DNS header flags. |
keyword |
event.dataset |
Event dataset |
constant_keyword |
event.module |
Event module |
constant_keyword |
geo.city_name |
City name. |
keyword |
geo.continent_name |
Name of the continent. |
keyword |
geo.country_iso_code |
Country ISO code. |
keyword |
geo.country_name |
Country name. |
keyword |
geo.location |
Longitude and latitude. |
geo_point |
geo.name |
User-defined description of a location, at the level of granularity they care about. Could be the name of their data centers, the floor number, if this describes a local physical entity, city names. Not typically used in automated geolocation. |
keyword |
geo.region_iso_code |
Region ISO code. |
keyword |
geo.region_name |
Region name. |
keyword |
Changelog
editChangelog
Version | Details | Kibana version(s) |
---|---|---|
1.20.1 |
Bug fix (View pull request) |
8.13.0 or higher |
1.20.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.19.4 |
Bug fix (View pull request) |
8.13.0 or higher |
1.19.3 |
Bug fix (View pull request) |
8.13.0 or higher |
1.19.2 |
Bug fix (View pull request) |
8.13.0 or higher |
1.19.1 |
Bug fix (View pull request) |
8.13.0 or higher |
1.18.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.17.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.16.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.15.1 |
Bug fix (View pull request) |
8.13.0 or higher |
1.15.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.14.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.13.1 |
Enhancement (View pull request) |
8.13.0 or higher |
1.13.0 |
Enhancement (View pull request) |
8.13.0 or higher |
1.12.0 |
Enhancement (View pull request) Breaking change (View pull request) |
8.13.0 or higher |
1.11.4 |
Bug fix (View pull request) |
8.12.0 or higher |
1.11.3 |
Bug fix (View pull request) |
8.12.0 or higher |
1.11.2 |
Bug fix (View pull request) |
8.12.0 or higher |
1.11.1 |
Enhancement (View pull request) |
8.12.0 or higher |
1.11.0 |
Enhancement (View pull request) |
8.12.0 or higher |
1.10.0 |
Enhancement (View pull request) |
8.12.0 or higher |
1.9.2 |
Enhancement (View pull request) |
8.12.0 or higher |
1.9.1 |
Bug fix (View pull request) |
8.12.0 or higher |
1.9.0 |
Enhancement (View pull request) |
8.12.0 or higher |
1.8.3 |
Enhancement (View pull request) |
8.8.0 or higher |
1.8.2 |
Enhancement (View pull request) |
8.8.0 or higher |
1.8.1 |
Enhancement (View pull request) |
8.8.0 or higher |
1.8.0 |
Enhancement (View pull request) |
8.8.0 or higher |
1.7.0 |
Enhancement (View pull request) |
8.6.0 or higher |
1.6.0 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.33 |
Bug fix (View pull request) |
8.6.0 or higher |
1.5.32 |
Bug fix (View pull request) |
8.6.0 or higher |
1.5.31 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.30 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.29 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.28 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.27 |
Bug fix (View pull request) |
8.6.0 or higher |
1.5.26 |
Bug fix (View pull request) |
8.6.0 or higher |
1.5.25 |
Bug fix (View pull request) |
8.6.0 or higher |
1.5.24 |
Bug fix (View pull request) |
8.6.0 or higher |
1.5.23 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.22 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.21 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.20 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.17 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.16 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.15 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.14 |
Enhancement (View pull request) |
8.6.0 or higher |
1.5.13 |
Enhancement (View pull request) |
7.16.0 or higher |
1.5.12 |
Enhancement (View pull request) |
7.16.0 or higher |
1.5.11 |
Enhancement (View pull request) |
7.16.0 or higher |
1.5.10 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.9 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.8 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.7 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.6 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.5 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.4 |
Enhancement (View pull request) |
7.16.0 or higher |
1.5.3 |
Enhancement (View pull request) |
7.16.0 or higher |
1.5.2 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.1 |
Bug fix (View pull request) |
7.16.0 or higher |
1.5.0 |
Enhancement (View pull request) |
7.16.0 or higher |
1.4.1 |
Enhancement (View pull request) |
7.16.0 or higher |
1.4.0 |
Enhancement (View pull request) |
7.16.0 or higher |
1.3.0 |
Enhancement (View pull request) |
7.16.0 or higher |
1.2.3 |
Enhancement (View pull request) |
7.16.0 or higher |
1.2.2 |
Enhancement (View pull request) |
7.16.0 or higher |
1.2.1 |
Bug fix (View pull request) |
7.16.0 or higher |
1.2.0 |
Enhancement (View pull request) |
— |
1.1.11 |
Bug fix (View pull request) |
— |
1.1.10 |
Enhancement (View pull request) |
7.16.0 or higher |
1.1.9 |
Bug fix (View pull request) |
— |
1.1.8 |
Enhancement (View pull request) |
7.16.0 or higher |
1.1.7 |
Bug fix (View pull request) |
7.16.0 or higher |
1.1.6 |
Bug fix (View pull request) Bug fix (View pull request) |
7.16.0 or higher |
1.1.5 |
Enhancement (View pull request) |
— |
1.1.4 |
Bug fix (View pull request) |
— |
1.1.3 |
Enhancement (View pull request) |
— |
1.1.2 |
Bug fix (View pull request) Bug fix (View pull request) |
7.16.0 or higher |
1.1.1 |
Bug fix (View pull request) |
— |
1.1.0 |
Enhancement (View pull request) |
— |
1.0.1 |
Enhancement (View pull request) |
7.16.0 or higher |
1.0.0 |
Enhancement (View pull request) |
7.16.0 or higher |
0.12.3 |
Enhancement (View pull request) |
— |
0.12.2 |
Bug fix (View pull request) |
— |
0.12.1 |
Bug fix (View pull request) |
— |
0.12.0 |
Enhancement (View pull request) |
— |
0.11.0 |
Enhancement (View pull request) |
— |
0.10.1 |
Enhancement (View pull request) |
— |
0.10.0 |
Enhancement (View pull request) |
— |
0.9.2 |
Bug fix (View pull request) |
— |
0.9.1 |
Bug fix (View pull request) |
— |
0.9.0 |
Enhancement (View pull request) |
— |
0.8.6 |
Bug fix (View pull request) |
— |
0.8.5 |
Enhancement (View pull request) |
— |
0.8.4 |
Enhancement (View pull request) |
— |
0.8.3 |
Enhancement (View pull request) |
— |
0.8.2 |
Enhancement (View pull request) |
— |
0.8.1 |
Enhancement (View pull request) |
— |
0.8.0 |
Enhancement (View pull request) |
— |
0.7.0 |
Enhancement (View pull request) |
— |
0.6.2 |
Enhancement (View pull request) |
— |
0.6.1 |
Enhancement (View pull request) |
— |
0.6.0 |
Enhancement (View pull request) |
— |
0.5.1 |
Enhancement (View pull request) |
— |
0.5.0 |
Enhancement (View pull request) |
— |
0.4.0 |
Enhancement (View pull request) |
— |
0.3.1 |
Enhancement (View pull request) |
— |
0.3.0 |
Enhancement (View pull request) |
— |
0.2.3 |
Enhancement (View pull request) |
— |
0.2.2 |
Bug fix (View pull request) |
— |
0.2.1 |
Bug fix (View pull request) |
— |
0.2.0 |
Enhancement (View pull request) |
— |
0.0.1 |
Enhancement (View pull request) |
— |