Palo Alto Network Firewall Logs
Palo Alto Firewall package can be used to parse incoming log events making it searchable in Falcon LogScale.
This package supports the following log types:
The parser normalizes data to a common schema based on CrowdStrike Parsing Standard (CPS) 1.0. This schema allows you to search the data without knowing the data specifically, and just knowing the common schema instead. It also allows you to combine the data more easily with other data sources which conform to the same schema.
Breaking Changes
This update includes parser changes, which means that data ingested after upgrade will not be backwards compatible with logs ingested with the previous version.
Updating to version 1.0.0 or newer will therefore result in issues with existing queries in for example dashboards or alerts created prior to this version.
See CrowdStrike Parsing Standard (CPS) 1.0 for more details on the new parser schema.
Follow the CPS Migration to update your queries to use the fields and tags that are available in data parsed with version 1.0.0.
Installing the Package in LogScale
Find the repository where you want to send the Palo Alto Network Firewall Logs events, or Creating a Repository or View.
Navigate to your repository in the LogScale interface, click Settings and then on the left.
Click Palo Alto Network Firewall Logs (i.e. paloalto/firewall).
and install the LogScale package forWhen the package has finished installing, click
on the left still under the .In the right panel, click paloalto-ngfw to the LogScale Collector Configuration as described in the documentation Sources & Examples.
to create a new token. Give the token an appropriate name (e.g. the name of the Event Hub it will collect logs from), and leave the parser unassigned, you can assign the parserBefore leaving this page, view the ingest token and copy it to your clipboard — to save it temporarily elsewhere.
Now that you have a repository set up in LogScale along with an ingest token you're ready to send logs to LogScale.
Configurations and Sending the Logs to LogScale
Follow the Palo Alto Documentation to configure syslogs to send to Falcon LogScale. You can find more information on the logs here: Syslog Field Descriptions.
Next, configure the Falcon LogScale Collector to ship the logs from your syslog server into LogScale. Follow LogScale Collector Install LogScale Collector and Configure LogScale Collector. LogScale Collector documentation also provides an example of how you can configure your syslog datasource, see Sources & Examples.
Verify Data is Arriving in LogScale
Once you have completed the above steps the Palo Alto Network Firewall Logs data should be arriving in your LogScale repository.
You can verify this by doing a simple search for the events:
#event.module = "ngfw" | #Vendor = "paloalto"
Package Contents Explained
This package parses incoming data, and normalizing the data as part of that parsing. The parser normalizes the data to CrowdStrike Parsing Standard (CPS) 1.0 schema based on OpenTelemetry standards, while still preserving the original data.
If you want to search using the original field names and values, you can access those in the fields whose names are prefixed with the word Vendor. Fields which are not prefixed with Vendor are standard fields which are either based on the schema (e.g. source.ip) or on LogScale conventions (e.g. @rawstring).
The fields which the parser currently maps the data to, are chosen based on what seems the most relevant, and will potentially be expanded in the future. But the parser won't necessarily normalize every field that has potential to be normalized.
Event Categorisation
As part of the schema, events are categorized by fields:
event.category is an array so needs to be searched using the following syntax:
array:contains("event.category[]", value="network")
For example, the following will find events where some
event.type[n] field contains the value
network
, regardless of what
n is.
Note that not all events will be categorized to this level of detail.
Normalized Fields
Here are some of the normalized fields which are being set by this parser:
destination.* (e.g destination.bytes, destination.domain, destination.ip, destination.mac, destination.nat.ip, destination.nat.port, destination.packets, destination.port, destination.user.domain, destination.user.email, destination.user.name)
ecs.* (e.g ecs.version)
event.* (e.g event severity, event.action, event.category, event.created, event.dataset, event.duration, event.kind, event.module, event.outcome, event.reason, event.start, event.type)
file.* (e.g file.type)
host.* (e.g host.id, host.mac, host.name, host.os.family, host.os.full)
http.* (e.g http.request.method)
log.* (e.g log.level, log.syslog, log.syslog.appname, log.syslog.hostname, log.syslog.msgid, log.syslog.priority, log.syslog.procid, log.syslog.structured_data)
message.* (e.g message)
network.* (e.g network.application, network.bytes, network.community_id, network.direction, network.forwarded_ip, network.packets, network.protocol, network.transport, network.type)
rule.* (e.g rule.name, rule.uuid)
source.* (e.g source ip, source.bytes, source.mac, source.nat.ip, source.nat.port, source.packets, source.port, source.user.domain, source.user.email, source.user.name)
threat.* (e.g threat.framework, threat.tactic.id, threat.tactic.name, threat.technique.id, threat.technique.name, threat.technique.reference, threat.technique.subtechnique.id)
tls.* (e.g tls.cipher, tls.client.hash.md5, tls.client.hash.sha1, tls.client.hash.sha256, tls.client.not_after, tls.client.not_before, tls.client.server_name, tls.client.x509.issuer.common_name, tls.client.x509.public_key_size, tls.client.x509.serial_number, tls.client.x509.subject.common_name, tls.client.x509.version_number, tls.curve, tls.version, tls.version_protocol)
user.* (e.g user.domain, user.email, user.name)