GraphIaC
Project description
GraphIaC
Early Alpha — Experimental Software GraphIaC is in early alpha. APIs will change, features are incomplete, and it has not been tested in production. Use at your own risk.
A graph-based Infrastructure-as-Code framework for AWS. Model your cloud infrastructure as a directed graph — nodes are AWS resources, edges are the connections and permissions between them.
The Problem
Tools like Terraform and Pulumi make it easy to define individual resources. The hard part is wiring them together: IAM policies, invoke permissions, service integrations. That boilerplate is repetitive, error-prone, and the main source of permission debugging in real projects. Most IaC tools treat it as an afterthought, burying it inside resource definitions in ways that make the code hard to read and impossible to reuse.
The Approach
GraphIaC promotes connections to first-class citizens. When you add a LambdaToDynamoEdge, the edge already knows what IAM policies are required. It queries the graph for the relevant ARNs and provisions everything itself. You declare the connection; the edge handles the boilerplate.
Because AWS permission patterns are stable, that knowledge gets written once into the edge class and reused everywhere. Nodes stay clean and self-contained, which means they're also easy to copy across projects.
A secondary benefit: because the infrastructure is a graph, you can render it as a diagram at any time — always up to date, no manual documentation required.
Key Concepts
- Nodes — AWS resources (Lambda, DynamoDB table, IAM role, API Gateway, etc.), each a Pydantic model with
read,create,update, anddeletemethods - Edges — the connections between resources; each edge knows what it takes to wire two nodes together (IAM policies, invoke permissions, etc.)
- State reconciliation — on every
plan(), GraphIaC diffs live AWS state against a local SQLite DB and produces a list ofCREATE,UPDATE,DELETE, orIMPORToperations run()— executes the plan in the correct order
Install
pip install -e ".[dev]"
GraphIaC can export infrastructure diagrams via Graphviz. To enable that, install pygraphviz:
pip install --config-settings="--global-option=build_ext" \
--config-settings="--global-option=-I$(brew --prefix graphviz)/include/" \
--config-settings="--global-option=-L$(brew --prefix graphviz)/lib/" \
pygraphviz
Usage
import sqlite3
import boto3
import GraphIaC
from GraphIaC.aws.dynamodb import DynamoTable, DynamoKey
from GraphIaC.aws.lambda_func import LambdaFunction
session = boto3.Session(profile_name="my-profile")
db_conn = sqlite3.connect("my-infra.db")
state = GraphIaC.init(session, db_conn)
table = DynamoTable(g_id="users_table", table_name="users", partition_key=DynamoKey(name="pk", attr_type="S"))
GraphIaC.add_node(state, table)
# plan() shows what will change; run() applies it
GraphIaC.plan(state)
GraphIaC.run(state)
CLI
GraphIaC ships a command-line interface so you can run infra operations without writing a script.
python -m GraphIaC <aws-profile> --infra_file <path/to/infra.py> <command>
Commands
| Command | What it does |
|---|---|
plan |
Diffs live AWS state against the local DB and prints the changes that would be applied |
run |
Applies the plan — creates, updates, and deletes resources |
diagram |
Renders the infrastructure graph as a Graphviz PNG |
import |
Imports existing AWS resources into local state |
Examples
# Preview changes for a profile named fndtn_web_deploy
python -m GraphIaC fndtn_web_deploy --infra_file infra.py plan
# Apply changes
python -m GraphIaC fndtn_web_deploy --infra_file infra.py run
# Render a diagram
python -m GraphIaC fndtn_web_deploy --infra_file infra.py diagram
The SQLite state DB is created automatically next to the infra file (e.g. infra.py → infra.db). Your infra file must expose an infra(state) function that builds the graph:
# infra.py
def infra(state):
table = DynamoTable(g_id="users_table", ...)
GraphIaC.add_node(state, table)
# add more nodes and edges...
Running Tests
Tests mirror the source tree (tests/aws/ covers src/GraphIaC/aws/, and so on for future providers).
AWS integration tests hit real AWS and require credentials. Set AWS_PROFILE to the profile you want to use, then run:
AWS_PROFILE=your-profile pytest tests/aws/
Tests generate randomized resource names on every run and clean up after themselves, including on failure. Resources are created in us-east-2 by default.
Run a specific test file:
AWS_PROFILE=your-profile pytest tests/aws/test_dynamodb.py -v
Skip AWS tests (e.g. in CI without credentials) — omit AWS_PROFILE or unset it. Any test that needs AWS will be skipped automatically.
License
MIT — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file graphiac-0.0.1.tar.gz.
File metadata
- Download URL: graphiac-0.0.1.tar.gz
- Upload date:
- Size: 34.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1cf8e32eb810d7133bbb9fbb35944cc52aeec05e2b884fc9ab9e0b6e9ccf94bc
|
|
| MD5 |
5f8e35bd1c50a420813cb04744d13085
|
|
| BLAKE2b-256 |
1ddaceac927d6b6c7c795467a48baeaedc1800a1e95c04410d1c7c25892c3fa1
|
File details
Details for the file graphiac-0.0.1-py3-none-any.whl.
File metadata
- Download URL: graphiac-0.0.1-py3-none-any.whl
- Upload date:
- Size: 41.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
049e151a501df41d3d6a3a123011474aa55a372883e5eb966809dc35d035ca21
|
|
| MD5 |
082b6880b3c65cacfb5929c305351417
|
|
| BLAKE2b-256 |
ba85d52acc47d04af49eb6e60a6c4ca57af3c6dc779bfd1f68c5ccd81c950885
|