Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/rememberYou/gen-cisco

๐Ÿงจ Generates Cisco scripts based on YAML files
https://github.com/rememberYou/gen-cisco

basic cisco eigrp etherchannel generator glbp hsrp jinja2 nat ospf packet-tracer python rip router scripts serial spanning-tree ssh switch yaml

Last synced: about 2 months ago
JSON representation

๐Ÿงจ Generates Cisco scripts based on YAML files

Awesome Lists containing this project

README

        

# ![Cisco Logo](assets/cisco.png "Cisco logo") gen-cisco

![License](https://img.shields.io/badge/License-MIT-green.svg)
![Version](https://img.shields.io/badge/version-1.2.9-blue.svg)

`gen-cisco` is an API and CLI to facilitate the creation of your Cisco scripts
using a YAML file. This file groups a section for each protocol including the
values to be replaced in the appropriate Cisco template.

The creation of these templates has been done during the various _CCNA_ training
courses offered by Cisco, using [Packet
Tracer](https://www.netacad.com/courses/packet-tracer-download/), a network
simulation and visualization tool. Therefore, some commands may need to be
modified on real hardware.

---

### Installation

It's as simple as that:

```
pip install gen-cisco
```

---

### Usage

```
Usage: gen-cisco.py [OPTIONS]

Generates Cisco scripts based on YAML files

Examples:
python gen-cisco.py -i examples/router.yml
python gen-cisco.py -i examples/router.yml -o r1.txt
python gen-cisco.py -i examples/router.yml -o r1.txt -v
python gen-cisco.py -i examples/router.yml -o r1.txt --no-comments -v
python gen-cisco.py -i examples/router.yml -o r1.txt --no-comments --no-headers -v
python gen-cisco.py -i examples/router.yml -o r1.txt --no-override

Options:
-i, --src FILENAME The YAML file.
-o, --dest TEXT The name of the generated script file.
--override / --no-override Deletes the old file if it is overwritten.
--comments / --no-comments Deletes comments in the generated script.
--headers / --no-headers Deletes headers in the generated script.
-v, --verbose Outputs the final script to the console.
--version Show the version and exit.
--help Show this message and exit.
```

Alternatively you can run this tool using Docker:

```bash
# Build the image
docker build -t gen-cisco .

# Run the image
docker run -v $(pwd):/app gen-cisco python gen-cisco.py [OPTIONS]
```

---

### Supported Features

Here is a list of features configurable by the scripts:

```
basic โž” basic configuration for routers and switches
eigrp โž” advanced distance-vector routing protocol
etherchannel โž” port link aggregation technology used primarily on Cisco switches
hsrp โž” Cisco redundancy protocol for establishing a fault-tolerant default gateway
nat โž” method of remapping one IP address space into another
ospf โž” routing protocol for Internet Protocol networks
rip โž” one of the oldest distance-vector routing protocols
ssh โž” cryptographic network protocol for operating network services securely
stp โž” network protocol that builds a loop-free logical topology for Ethernet networks
vtp โž” protocol that propagates the definition of VLAN on the whole local area network
```

For a complete list sorted by device, please visit the [wiki](https://github.com/rememberYou/gen-cisco/wiki/Supported-Features).

---

### Contributions

Adding a new protocol to script as well as supporting a new device is easy. To
do that, first take a look at the [CONTRIBUTING](https://github.com/rememberYou/gen-cisco/blob/master/CONTRIBUTING.md)
file. Also, feel free to submit your bugs and suggestions by opening an issue in
the issue tracker, it would help us a lot.

---

### License

Code is under the [MIT License](https://github.com/rememberYou/gen-cisco/blob/master/LICENSE).