Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/marcin-kolda/gcp-iam-collector

Python script for collecting and visualising Google Cloud Platform IAM permissions
https://github.com/marcin-kolda/gcp-iam-collector

google-cloud security-audit security-tools

Last synced: about 2 months ago
JSON representation

Python script for collecting and visualising Google Cloud Platform IAM permissions

Awesome Lists containing this project

README

        

# gcp-iam-collector
Python scripts for collecting and visualising [Google Cloud Platform](https://cloud.google.com/) IAM permissions

GCP IAM graph is created using [vis.js](http://visjs.org/) and it's static HTML page, see [example interactive graph](https://storage.googleapis.com/gcp-iam-collector/iam_graph_example.html)

[![Example graph](https://raw.githubusercontent.com/marcin-kolda/gcp-iam-collector/master/example_graph.png)](https://storage.googleapis.com/gcp-iam-collector/iam_graph_example.html)

## Features

GCP IAM collector iterates over projects using [Google Cloud Resource Manager API](https://cloud.google.com/resource-manager/reference/rest/v1/projects/list) and dumps to CSV files:
* all available GCP projects,
* projects IAM permissions,
* projects service account and their keys,
* BigQuery dataset ACLs,
* Cloud Storage bucket ACLs

IAM graph currently supports:
* GCP projects and their permissions,
* Service accounts and their permissions

# Setup

1. Install dependencies:
```
pip install -r requirements.txt
```
2. Install [gcloud](https://cloud.google.com/sdk/gcloud/) CLI tool.
3. Setup [Google Application Default Credentials](https://developers.google.com/identity/protocols/application-default-credentials):
```
gcloud auth application-default login
```

# Run Instructions

Command below dumps all IAM to csv files
```
python collector.py
```

Creating interactive graph:
```
python create_iam_graph.py
```