data:image/s3,"s3://crabby-images/379c4/379c474c208740845ba17522e056f3065166366a" alt="Powerpipe Logo"
data:image/s3,"s3://crabby-images/93b6e/93b6ed4ffc8062a5bc1e4ca04205671df62a1ff3" alt="maintained by"
Powerpipe is dashboards and benchmarks as code. Use it to visualize any data source, and run compliance benchmarks and controls, for effective decision-making and ongoing compliance monitoring.
Dashboards. Powerpipe runs dashboards that present data in visual and interactive ways.
Benchmarks. Powerpipe can also run benchmarks, which are packages of controls to check your infrastructure against compliance standards.
Modularity and customization. Dashboards and benchmarks are built with HCL and SQL, and are available for remixing and reuse.
Demo Time!
Watch on YouTube →
data:image/s3,"s3://crabby-images/c1aa0/c1aa07f9219f3f4cd176b606fbbdd0a3f9af232f" alt="Powerpipe demo"
Install Powerpipe
The downloads page shows you how, but tl;dr:
Linux or WSL
sudo /bin/sh -c "$(curl -fsSL https://powerpipe.io/install/powerpipe.sh)"
MacOS
brew tap turbot/tap
brew install powerpipe
Run a dashboard
Dashboards use charts, tables, and interactive widgets to help you explore and visualize your resources. For example, the RNAcentrals mod visualizes a dataset of RNA types. To run the RNACentral dashboard:
-
git clone https://github.com/turbot/powerpipe-mod-rnacentral
-
cd powerpipe-mod-rnacentral
-
powerpipe server --database postgres://reader:NWDMCE5xdipIjRrp@hh-pgsql-public.ebi.ac.uk:5432/pfmegrnargs
-
open localhost:9033 in a browser
That's it! Here's the dashboard.
data:image/s3,"s3://crabby-images/8a495/8a4957da4f87ff81eb472217532627b1fc9a0748" alt="rnacentral"
Run a benchmark
Many Powerpipe mods includes benchmarks that check your cloud resources for compliance. The Net Insights mod provides configuration, compliance and security controls to validate security best practices for DNS records. To run the SSL/TLS Best Practices benchmark:
-
git clone https://github.com/turbot/powerpipe-mod-net-insights
-
cd powerpipe-mod-net-insights
-
powerpipe server
-
open localhost:9033 in a browser
``
Here's the dashboard.
data:image/s3,"s3://crabby-images/08522/085226319d7422783cc79bcb98831002634a5056" alt="net insights dashboard"
You can run benchmarks as dashboards too! Here's the console ouput.
powerpipe benchmark run benchmark.ssl_certificate_best_practices --output=brief
data:image/s3,"s3://crabby-images/d70a6/d70a61466a2a8d9f890663dddeb00af0d1dfa91c" alt="net insights console"
Developing
Developing Powerpipe
Prerequisites:
- Golang Version 1.21 or higher.
Clone github.com/powerpipe
and github.com/turbot/pipe-fittings
repositories:
git clone https://github.com/turbot/powerpipe
git clone https://github.com/turbot/pipe-fittings
cd powerpipe
The build lands in /usr/local/bin/
unless OUTPUT_DIR
is specified.
make
Check the version:
powerpipe --version
Powerpipe v0.1.0-local.1
Open Source & Contributing
This repository is published under the AGPL 3.0 license. Please see our code of conduct. Contributors must sign our Contributor License Agreement as part of their first pull request. We look forward to collaborating with you!
Powerpipe is a product produced from this open source software, exclusively by Turbot HQ, Inc. It is distributed under our commercial terms. Others are allowed to make their own distribution of the software, but cannot use any of the Turbot trademarks, cloud services, etc. You can learn more in our Open Source FAQ.
Get Involved
Join #powerpipe on Slack →
Want to help but don't know where to start? Pick up one of the help wanted
issues: