Taking Snapshots from the Command Line

To upload snapshots to Turbot Pipes, you must either log in via the powerpipe login command or create an API token and pass it via the --pipes-token argument or PIPES_TOKEN environment variable.

To take a snapshot and save it to Turbot Pipes, simply add the --snapshot flag to your run command.

You can take a snapshot of a dashboard:

powerpipe dashboard run aws_insights.dashboard.aws_account_report --snapshot

or a benchmark:

powerpipe benchmark run benchmark.cis_v140 --snapshot

or a control:

powerpipe control run cis_v140_2_1_1 --snapshot

or a query:

powerpipe query run "select * from aws_ec2_instance" --snapshot

including named queries:

powerpipe query aws_compliance.query.vpc_network_acl_unused --snapshot

Sharing Snapshots

The --snapshot flag will create a snapshot with workspace visibility in your user workspace. A snapshot with workspace visibility is visible only to users who have access to the workspace in which the snapshot resides -- A user must be authenticated to Turbot Pipes with permissions on the workspace.

If you want to create a snapshot that can be shared with anyone, use the --share flag instead. This will create the snapshot with anyone_with_link visibility:

powerpipe dashboard run aws_insights.dashboard.aws_account_report --share

You can set a snapshot title in Turbot Pipes with the --snapshot-title argument. This is especially useful for ad hoc queries:

powerpipe query run "select name from aws_s3_bucket where bucket_policy_is_public" \
--share \
--snapshot-title "Public Buckets"

If you wish to save the snapshot to a different workspace, such as an org workspace, you can use the --snapshot-location argument with --share or --snapshot:

powerpipe benchmark run benchmark.cis_v140 \
--snapshot \
--snapshot-location vandelay-industries/latex

Note that the previous command ran the benchmark against the local database, but saved the snapshot to the vandelay-industries/latex workspace. If you want to run the benchmark against the remote vandelay-industries/latex database AND store the snapshot there, you can use the--workspace flag instead - Powerpipe supports passing the cloud workspace implicitly:

powerpipe benchmark run benchmark.cis_v140 \
--snapshot \
--workspace vandelay-industries/latex

Passing Args

If your dashboard has inputs, you may specify them with one or more --arg arguments:

powerpipe dashboard run aws_insights.dashboard.aws_vpc_detail\
--snapshot \
--arg vpc_id=vpc-9d7ae1e7

Likewise, if you want to run a query that defines params, you can pass --arg to them as well:

powerpipe query run list_vpcs \
--snapshot \
--arg region='["us-east-1","us-east-2"]' \
--arg account_id='["123412341234", "111111111111"]'

Tagging Snapshots

You may want to tag your snapshots to make it easier to organize them. You can use the --snapshot-tag argument to add a tag:

powerpipe dashboard run aws_insights.dashboard.aws_account_report \
--snapshot \
--snapshot-tag env=local

Simply repeat the flag to add more than one tag:

powerpipe dashboard run aws_insights.dashboard.aws_account_report \
--snapshot \
--snapshot-tag env=local \
--snapshot-tag owner=george

Saving Snapshots to Local Files

Turbot Pipes makes it easy to save and share your snapshots but it is not strictly required; You can save and view snapshots using only the CLI.

You can specify a local path in the --snapshot-location argument or POWERPIPE_SNAPSHOT_LOCATION environment variable to save your snapshots to a directory in your filesystem:

powerpipe benchmark run benchmark.cis_v150 --snapshot --snapshot-location .

You can also set snapshot_location in a workspace if you wish to make it the default location.

Alternatively, you can use the --export argument to export a query, control, dashboard, or benchmark in the Powerpipe snapshot format. This will create a file with a .pps extension in the current directory:

powerpipe dashboard run dashboard.aws_account_report --export pps

The snapshot export/output type is an alias for pps:

powerpipe dashboard run dashboard.aws_account_report --export snapshot

To give the file a name, simply use {filename}.pps, for example:

powerpipe dashboard run dashboard.aws_account_report --export account_report.pps

Alternatively, you can write the Powerpipe snapshot to stdout with --output pps

powerpipe query run "select * from aws_account" --output pps > mysnap.pps

or --output snapshot

powerpipe query run "select * from aws_account" --output snapshot > mysnap.pps

Controlling Output

When using --share or --snapshot, the output will include the URL to view the snapshot that you created in addition to the usual output:

Snapshot uploaded to https://pipes.turbot.com/user/costanza/workspace/vandelay/snapshot/snap_abcdefghij0123456789_asdfghjklqwertyuiopzxcvbn

You can use the --progress=false argument to suppress displaying the URL and other progress data. This may be desirable when you are using an alternate output format, especially when piping the output to another command:

powerpipe query run "select * from aws_account" \
--snapshot \
--output json \
--progress=false | jq

You can use all the usual --export or --output formats with --snapshot and --share. Neither the --output nor the --export` flag affects the snapshot format though; the snapshot itself is always a JSON file that is saved to Turbot Pipes and viewable as HTML:

powerpipe benchmark run cis_v140 --snapshot --export cis.csv --export cis.json

In fact, all the usual arguments will work with snapshots:

powerpipe control run aws_compliance.control.cis_v140_1_1 --snapshot
powerpipe benchmark run aws_compliance.benchmark.cis_v140_ --snapshot --where "severity in ('critical', 'high')" all