duo-labs / cloudmapper
- четверг, 22 февраля 2018 г. в 03:15:40
CloudMapper creates network diagrams of AWS environments
CloudMapper generates network diagrams of Amazon Web Services (AWS) environments and display them via your browser. It helps you understand visually what exists in your accounts and identify possible network misconfigurations.
See demo https://duo-labs.github.io/cloudmapper/
There are three stages to using CloudMapper:
On macOS:
# clone the repo
git clone git@github.com:duo-labs/cloudmapper.git
# Install pre-reqs for pyjq
brew install autoconf automake libtool
virtualenv venv
source venv/bin/activate
pip install -r requirements.txt
On Linux:
# clone the repo
git clone git@github.com:duo-labs/cloudmapper.git
sudo yum install autoconf automake libtool python-dev
virtualenv venv
source venv/bin/activate
pip install -r requirements.txt
A small set of demo data is provided. This will display the same environment as the demo site https://duo-labs.github.io/cloudmapper/
python cloudmapper.py prepare --config config.json.demo --account demo
python cloudmapper.py serve
This will run a local webserver at http://127.0.0.1:8000/
This step uses the CLI to make describe
calls and records the json in the folder you specify (in this case, named my_account
). You must have AWS credentials configured that can be used by the CLI. You must have read-only permissions on the account. This can be granted via the SecurityAuditor
policy, or can be reduced to an even more minimal set of permissions if desired. The minimal policy needed is:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Resource": "*",
"Action": [
"ec2:DescribeRegions",
"ec2:DescribeAvailabilityZones",
"ec2:DescribeVpcs",
"ec2:DescribeSubnets",
"ec2:DescribeSecurityGroups",
"ec2:DescribeVpcPeeringConnections",
"ec2:DescribeInstances",
"ec2:DescribeNetworkInterfaces",
"rds:DescribeDBInstances",
"elasticloadbalancing:DescribeLoadBalancers"
]
}
]
}
Collect the AWS data with:
./collect_data.sh --account my_account
my_account
is just a name for your account (ex. "prod"). You should now have a directory with .json files describing your account.
Copy the config.json.demo
to config.json
and edit it to include your account ID and name (ex. "prod"), along with any external CIDR names.
This step converts the collected AWS data into a format that can be displayed in the browser by generating a web/data.json
file.
python cloudmapper.py prepare --account my_account
There are a number of filtering options that can be applied here to reduce the number of nodes and edges. This will help the diagram look better, by removing some of its complexity, and is also needed for large environments that will not render.
The two most useful filtering options:
--regions
: Restrict the diagram to a set regions, ex. us-east-1,us-east-2
--collapse-by-tag
: This is very useful to provide a tag name, and all nodes with that tag will be reduced to a single displayed node.The other filtering options are:
--internal-edges
(default) and --no-internal-edges
: When you only care about showing what is publicly accessible, use --no-internal-edges
.--inter-rds-edges
and --no-inter-rds-edges
(default): By default, any communication paths between RDS nodes are not shown, as this is unlikely to be of interest. To display them, use --inter-rds-edges
.--read-replicas
(default) and --no-read-replicas
: By default, RDS read replica nodes are shown. You can ignore them by using --no-read-replicas
.--azs
(default) and --no-azs
: Availibility zones are shown by default. To ignore them, use --no-azs
.You can host the web
directory with your webserver of choice, or just run:
python cloudmapper.py serve
Delete (d): Select a node and click the eye with a slash through it to delete (ie. hide) it. Click the eye to undelete (unhide) all deleted nodes. All nodes connected to a deleted node will get a black border. If you double-click on a node with a black border, its deleted neighbors will be undeleted.
Highlight (h): Select a node and click the symbol of the connected nodes to highlight the neighbors of a node. Click the inverse symbol to unhighlight the neighbors. Highlight neighbors makes it easier to see which nodes are connected.
Collapse all: Click the icon of the arrows pointed toward each other to collapse all nodes. Click the symbol of the arrows pointed away to uncollapse all collapsed node.
Collapse (c/e): The "minus" symbol will collapse a node, and the "plus" symbol will expand it.
Randomize layout (r): The hammer symbol will randomly layout the diagram in a new way.
Save image: The camera symbol will save a high resolution image of the diagram. This is helpful when your diagram has many nodes such that you must be zoomed out, so a screenshot would not get the same level of detail.
Import/Export: This will save the layout as a json file that you can then upload. This is helpful if you've moved nodes or made other changes and wish to "save" your work. Re-opening saved files does have some bugs.
When you first start, the initial layout is never ideal. We use what is believed to be the best layout algorithm for compound node diagrams, CoSE, but this will still require manual editing by moving nodes around.
Here is the layout you'll likely see initially when you view the demo: