Skip to content
This repository was archived by the owner on Nov 24, 2025. It is now read-only.

np-guard/vpc-network-config-synthesis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Warning

This repo is no longer being maintained

vpc-network-config-synthesis

About vpc-network-config-synthesis

Tool for automatic synthesis and optimization of VPC network configurations, namely Network ACLs and Security Groups.

Usage

Use the vpcgen CLI tool with one of the following commands:

  • vpcgen synth sg - generate Security Groups.
  • vpcgen synth acl - generate an nACL for each subnet separately.
  • vpcgen synth acl --single - generate a single nACL for all subnets in the same VPC.
  • vpcgen optimize sg - optimize SGs.
  • vpcgen optimize acl - optimize nACLs.

Synthesis

nACLs Generation

A required connection between NIFs/VSIs/VPEs implies connectivity will be allowed between the subnets they are contained in.

SGs Generation

A Security Group, generated for a specific VSI (or for one of its NIFs), will be applied to all the NIFs of the VSI. The same goes for Reserved IPs of a VPE.

Supported types

The input supports subnets, subnet segments, CIDR segments, NIFs, NIF segments, instances (VSIs), instance segments, VPEs, VPE segments and externals.
Note: Segments should be defined in the spec file.

Options

Flags: -s, --spec string JSON file containing spec file 

Optimization

SG optimization

SG optimizatin attempts to reduce the number of security group rules in a SG without changing the semantic. Specifying the -n flag results in optimizing only one given SG. Otherwise, all SGs will be optimized.

Flags: -n, --sg-name string which security group to optimize 

nACL optimization

nACL optimizatin attempts to reduce the number of nACL rules in an nACL without changing the semantic. Specifying the -n flag results in optimizing only one given nACL. Otherwise, all nACLs will be optimized.

Flags: -n, --acl-name string which nACL to optimize 

Global options

Flags: -c, --config string JSON file containing a configuration object of existing resources -f, --format string Output format; must be one of [tf, csv, md, json] -h, --help help for vpcgen -l, --locals whether to generate a locals.tf file (only possible when the output format is tf) -d, --output-dir string Write generated resources to files in the specified directory, one file per VPC. -o, --output-file string Write all generated resources to the specified file -p, --prefix string The prefix of the files that will be created. 

Note: The infrastructure configuration must always be provided using the --config flag.

Output

  1. If the output-dir flag is used, the specified folder will be created, containing one file per VPC. Each generated file will contain the network resources (Security Groups or Network ACLs) relevant to its VPC. File names are set as prefix_vpc, where prefix is ​​the value received in the prefix flag. If the prefix flag is omitted, file names will match VPC names.
  2. If the output-file flag is used, all generated resources will be written to the specified file.
  3. if both output-file and output-dir flags are not used, the collection will be written to stdout.

Build the project

Make sure you have golang 1.23+ on your platform.

git clone git@github.com:np-guard/vpc-network-config-synthesis.git cd vpc vpc-network-config-synthesis make mod make build 

Note: Windows environment users should run make build-windows instead of make build.

Run an example

bin/vpcgen synth acl -c test/data/acl_testing5/config_object.json -s test/data/acl_testing5/conn_spec.json bin/vpcgen synth sg -c test/data/sg_testing3/config_object.json -s test/data/sg_testing3/conn_spec.json bin/vpcgen optimize sg -c test/data/optimize_sg_redundant/config_object.json 

Note: Windows environment users should replace all / with \.

About

Tool for automatic synthesis of VPC network resources

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 5