Table: yml_file - Query Config YML Files using SQL
Config is a service that allows you to assess and evaluate the configurations of your config resources. It helps in managing, monitoring, and auditing resource configurations over time. An important part of this service is the YML Files, which contain the configuration details of various resources.
Table Usage Guide
The yml_file
table provides insights into YML Files within Config. As a Cloud Architect or DevOps engineer, explore file-specific details through this table, including content, file size, and associated metadata. Utilize it to uncover information about files, such as those with specific configurations, the relationships between different configurations, and the verification of file content.
Examples
Query a simple file
This query is useful for gaining insights into customer purchase history from a specific file. It allows you to understand when and how many purchases a customer has made, which can help in analyzing customer behavior and trends.
Given the file invoice.yml
with the following configuration:
---receipt: Oz-Ware Purchase Invoicedate: 2012-08-06customer: first_name: Dorothy family_name: Galeitems: - part_no: A4786 description: Water Bucket (Filled) price: 1.47 quantity: 4
- part_no: E1628 description: High Heeled "Ruby" Slippers size: 8 price: 133.7 quantity: 1bill-to: &id001street: | 123 Tornado Alley Suite 16city: East Centervillestate: KSship-to: *id001
You can query the customer details and the number of items ordered:
select content ->> 'date' as order_date, concat( content -> 'customer' ->> 'first_name', ' ', content -> 'customer' ->> 'family_name' ) as customer_name, jsonb_array_length(content -> 'items') as order_countfrom yml_filewhere path = '/Users/myuser/invoice.yml';
select json_extract(content, '$.date') as order_date, ( json_extract(content, '$.customer.first_name') || ' ' || json_extract(content, '$.customer.family_name') ) as customer_name, json_array_length(json_extract(content, '$.items')) as order_countfrom yml_filewhere path = '/Users/myuser/invoice.yml';
+----------------------+---------------+-------------+| order_date | customer_name | order_count |+----------------------+---------------+-------------+| 2012-08-06T00:00:00Z | Dorothy Gale | 2 |+----------------------+---------------+-------------+
Casting column data for analysis
Explore which items a customer has purchased and how much they've spent in total. This is useful for understanding individual customer behavior and identifying your best-selling products. Text columns can be easily cast to other types:
select (content ->> 'date') :: timestamp as order_date, concat( content -> 'customer' ->> 'first_name', ' ', content -> 'customer' ->> 'family_name' ) as customer_name, item ->> 'description' as description, (item ->> 'price') :: float as price, (item ->> 'quantity') :: integer as quantity, (item ->> 'price') :: float * (item ->> 'quantity') :: integer as totalfrom yml_file, jsonb_array_elements(content -> 'items') as itemwhere path = '/Users/myuser/invoice.yml';
select json_extract(content, '$.date') as order_date, ( json_extract(content, '$.customer.first_name') || ' ' || json_extract(content, '$.customer.family_name') ) as customer_name, json_extract(item.value, '$.description') as description, cast(json_extract(item.value, '$.price') as float) as price, cast(json_extract(item.value, '$.quantity') as integer) as quantity, cast(json_extract(item.value, '$.price') as float) * cast(json_extract(item.value, '$.quantity') as integer) as totalfrom yml_file, json_each(json_extract(content, '$.items')) as itemwhere path = '/Users/myuser/invoice.yml';
+---------------------+---------------+-----------------------------+-------+----------+-------+| order_date | customer_name | description | price | quantity | total |+---------------------+---------------+-----------------------------+-------+----------+-------+| 2012-08-06 00:00:00 | Dorothy Gale | Water Bucket (Filled) | 1.47 | 4 | 5.88 || 2012-08-06 00:00:00 | Dorothy Gale | High Heeled "Ruby" Slippers | 133.7 | 1 | 133.7 |+---------------------+---------------+-----------------------------+-------+----------+-------+
Schema for yml_file
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form. | |
content | jsonb | Specifies the file content in JSON format. | |
path | text | = | Specifies the path of the YML file. |
sp_connection_name | text | =, !=, ~~, ~~*, !~~, !~~* | Steampipe connection name. |
sp_ctx | jsonb | Steampipe context in JSON form. |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- config
You can pass the configuration to the command with the --config
argument:
steampipe_export_config --config '<your_config>' yml_file