Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/28mm/blast-radius
Interactive visualizations of Terraform dependency graphs using d3.js
https://github.com/28mm/blast-radius
diagram graphviz interactive-visualizations terraform
Last synced: 3 days ago
JSON representation
Interactive visualizations of Terraform dependency graphs using d3.js
- Host: GitHub
- URL: https://github.com/28mm/blast-radius
- Owner: 28mm
- License: mit
- Created: 2017-11-07T05:20:23.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-08-14T12:38:03.000Z (5 months ago)
- Last Synced: 2025-01-02T02:04:08.884Z (10 days ago)
- Topics: diagram, graphviz, interactive-visualizations, terraform
- Language: JavaScript
- Homepage: https://28mm.github.io/blast-radius-docs/
- Size: 993 KB
- Stars: 2,080
- Watchers: 33
- Forks: 258
- Open Issues: 47
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-modernization - Blast Radius - s is a tool for reasoning about Terraform dependency graphs with interactive visualizations. (Visual / Datbase to Struct)
- my-awesome - 28mm/blast-radius - visualizations,terraform pushed_at:2024-08 star:2.1k fork:0.3k Interactive visualizations of Terraform dependency graphs using d3.js (JavaScript)
- awesome-repositories - 28mm/blast-radius - Interactive visualizations of Terraform dependency graphs using d3.js (JavaScript)
- awesome-terraform - blast radius - Interactive visualizations of Terraform dependency graphs. (Tools / Miscellaneous)
- awesome-devops - blast-radius - Interactive visualizations of Terraform dependency graphs using d3.js - https://28mm.github.io/blast-radius-docs/ (Terraform / Kubernetes // Storage)
- awesome-tf - blast radius - Interactive visualizations of Terraform dependency graphs. :skull: (Tools / Community providers)
- awesome-starred - 28mm/blast-radius - Interactive visualizations of Terraform dependency graphs using d3.js (terraform)
README
# Blast Radius
[![CircleCI](https://circleci.com/gh/28mm/blast-radius/tree/master.svg?style=svg)](https://circleci.com/gh/28mm/blast-radius/tree/master)
[![PyPI version](https://badge.fury.io/py/BlastRadius.svg)](https://badge.fury.io/py/BlastRadius)[terraform]: https://www.terraform.io/
[examples]: https://28mm.github.io/blast-radius-docs/_Blast Radius_ is a tool for reasoning about [Terraform][] dependency graphs
with interactive visualizations.Use _Blast Radius_ to:
* __Learn__ about *Terraform* or one of its providers through real [examples][]
* __Document__ your infrastructure
* __Reason__ about relationships between resources and evaluate changes to them
* __Interact__ with the diagram below (and many others) [in the docs][examples]![screenshot](doc/blastradius-interactive.png)
## Prerequisites
* [Graphviz](https://www.graphviz.org/)
* [Python](https://www.python.org/) 3.7 or newer> __Note:__ For macOS you can `brew install graphviz`
## Quickstart
The fastest way to get up and running with *Blast Radius* is to install it with
`pip` to your pre-existing environment:```sh
pip install blastradius
```Once installed just point *Blast Radius* at any initialized *Terraform*
directory:```sh
blast-radius --serve /path/to/terraform/directory
```And you will shortly be rewarded with a browser link http://127.0.0.1:5000/.
## Docker
[privileges]: https://docs.docker.com/engine/reference/run/#runtime-privilege-and-linux-capabilities
[overlayfs]: https://wiki.archlinux.org/index.php/Overlay_filesystemTo launch *Blast Radius* for a local directory by manually running:
```sh
docker run --rm -it -p 5000:5000 \
-v $(pwd):/data:ro \
--security-opt apparmor:unconfined \
--cap-add=SYS_ADMIN \
28mm/blast-radius
```A slightly more customized variant of this is also available as an example
[docker-compose.yml](./examples/docker-compose.yml) usecase for Workspaces.### Docker configurations
*Terraform* module links are saved as _absolute_ paths in relative to the
project root (note `.terraform/modules/`). Given these paths will vary
betwen Docker and the host, we mount the volume as read-only, assuring we don't
ever interfere with your real environment.However, in order for *Blast Radius* to actually work with *Terraform*, it needs
to be initialized. To accomplish this, the container creates an [overlayfs][]
that exists within the container, overlaying your own, so that it can operate
independently. To do this, certain runtime privileges are required --
specifically `--cap-add=SYS_ADMIN`.For more information on how this works and what it means for your host, check
out the [runtime privileges][privileges] documentation.#### Docker & Subdirectories
If you organized your *Terraform* project using stacks and modules,
*Blast Radius* must be called from the project root and reference them as
subdirectories -- don't forget to prefix `--serve`!For example, let's create a Terraform `project` with the following:
```txt
$ tree -d
`-- project/
|-- modules/
| |-- foo
| |-- bar
| `-- dead
`-- stacks/
`-- beef/
`-- .terraform
```It consists of 3 modules `foo`, `bar` and `dead`, followed by one `beef` stack.
To apply *Blast Radius* to the `beef` stack, you would want to run the container
with the following:```sh
$ cd project
$ docker run --rm -it -p 5000:5000 \
-v $(pwd):/data:ro \
--security-opt apparmor:unconfined \
--cap-add=SYS_ADMIN \
28mm/blast-radius --serve stacks/beef
```## Embedded Figures
You may wish to embed figures produced with *Blast Radius* in other documents.
You will need the following:1. An `svg` file and `json` document representing the graph and its layout.
2. `javascript` and `css` found in `.../blastradius/server/static`
3. A uniquely identified DOM element, where the `` should appear.You can read more details in the [documentation](doc/embedded.md)
## Implementation Details
*Blast Radius* uses the [Graphviz][] package to layout graph diagrams,
[PyHCL](https://github.com/virtuald/pyhcl) to parse [Terraform][] configuration,
and [d3.js](https://d3js.org/) to implement interactive features and animations.## Further Reading
The development of *Blast Radius* is documented in a series of
[blog](https://28mm.github.io) posts:* [part 1](https://28mm.github.io/notes/d3-terraform-graphs): motivations, d3 force-directed layouts vs. vanilla graphviz.
* [part 2](https://28mm.github.io/notes/d3-terraform-graphs-2): d3-enhanced graphviz layouts, meaningful coloration, animations.
* [part 3](https://28mm.github.io/notes/terraform-graphs-3): limiting horizontal sprawl, supporting modules.
* [part 4](https://28mm.github.io/notes/d3-terraform-graphs-4): search, pan/zoom, prune-to-selection, docker.A catalog of example *Terraform* configurations, and their dependency graphs
can be found [here](https://28mm.github.io/blast-radius-docs/).* [AWS two-tier architecture](https://28mm.github.io/blast-radius-docs/examples/terraform-provider-aws/two-tier/)
* [AWS networking (featuring modules)](https://28mm.github.io/blast-radius-docs/examples/terraform-provider-aws/networking/)
* [Google two-tier architecture](https://28mm.github.io/blast-radius-docs/examples/terraform-provider-google/two-tier/)
* [Azure load-balancing with 2 vms](https://28mm.github.io/blast-radius-docs/examples/terraform-provider-azurem/2-vms-loadbalancer-lbrules/)These examples are drawn primarily from the `examples/` directory distributed
with various *Terraform* providers, and aren't necessarily ideal. Additional
examples, particularly demonstrations of best-practices, or of multi-cloud
configurations strongly desired.