This page explains how to use the bag_keys function in APL.
Use the bag_keys
function in APL to extract the keys of a dynamic (bag) object as an array of strings. This is useful when you want to inspect or manipulate the structure of a dynamic field—such as JSON-like nested objects—without needing to know its exact schema in advance.
Use bag_keys
when you’re working with semi-structured data and want to:
This function is especially helpful in log analytics, observability pipelines, and security auditing, where dynamic properties are often collected from various services or devices.
If you come from other query languages, this section explains how to adjust your existing queries to achieve the same results in APL.
Name | Type | Description |
---|---|---|
bag | dynamic | The dynamic object whose keys you want to extract. |
An array of type string[]
containing the names of the keys in the dynamic object. If the input is not a dynamic object, the function returns null
.
Use bag_keys
to audit dynamic metadata fields in HTTP logs where each record contains a nested object representing additional request attributes.
Query
Output
_time | uri | metadata | key_list |
---|---|---|---|
2025-05-26 12:01:23 | /login | {os: Windows, browser: Firefox, device: Desktop} | [‘os’, ‘browser’, ‘device’] |
This query inspects a simulated metadata object and returns the list of its keys, helping you debug inconsistencies or missing fields.
Use bag_keys
to audit dynamic metadata fields in HTTP logs where each record contains a nested object representing additional request attributes.
Query
Output
_time | uri | metadata | key_list |
---|---|---|---|
2025-05-26 12:01:23 | /login | {os: Windows, browser: Firefox, device: Desktop} | [‘os’, ‘browser’, ‘device’] |
This query inspects a simulated metadata object and returns the list of its keys, helping you debug inconsistencies or missing fields.
Use bag_keys
to examine custom span attributes encoded as dynamic fields within OpenTelemetry trace events.
Query
Output
_time | [‘service.name’] | kind | attributes | attribute_keys |
---|---|---|---|---|
2025-05-26 13:14:01 | frontend | client | {user_id: abc123, feature_flag: enabled} | [‘user_id’, ‘feature_flag’] |
This query inspects the custom span-level attributes and extracts their keys to verify attribute coverage or completeness.
Use bag_keys
to list all security-related fields captured dynamically during request monitoring for auditing or compliance.
Query
Output
_time | status | [‘geo.country’] | security_context | fields |
---|---|---|---|---|
2025-05-26 15:32:10 | 200 | US | {auth_status: success, role: admin, ip: 192.168.1.5} | [‘auth_status’, ‘role’, ‘ip’] |
This helps you audit security metadata in requests and ensure key fields are present across records.