ZTPServer provides a bootstrap environment for Arista EOS based products. ZTPserver interacts with the ZeroTouch Provisioning (ZTP) mode of Arista EOS. The default ZTP start up mode triggers an unprovisioned Arista EOS nodes to enter a bootstrap readdy state if a valid configuration file is not already present on the internal flash storage.
ZTPServer provides a number of configurable bootstrap operation workflows that extend beyond simply loading an configuration and boot image. It provides the ability to define the target node through the introduction of definitions and templates that call pre-built actions and statically defined or dynamically generated attributes. The attributes and actions can also be extended to provide custom functionality that are specific to a given implementation. ZTPServer also provides a topology validation engine with a simple syntax to express LLDP neighbor adjacencies. It is written mostly in Python and leverages standard protocols like DHCP and DHCP options for boot functions, HTTP for bi-directional transport, and syslog for logging. Most of the files that the user interacts with are YAML based.
- Automated configuration file generation and application
- Image and file system validation and standardization
- Connectivity validation and topology based auto-provisioning
- Config and device templates with resource allocation for dynamic deployments
- Zero touch replacement and upgrade capabilities
- User extensible actions
- Syslog based logging and accounting of all processes
ZTPServer official documentation is built and hosted at (http://ReadTheDocs.org/).
Please see the CONTRIBUTING.md file for additional information.
- Mailing List
- eosplus-dev@arista.com
- IRC: irc.freenode.net#arista
- Python 3.6 or later (https://www.python.org/downloads)
- routes 2.5 or later (https://pypi.python.org/pypi/Routes)
- webob 1.8 or later (http://webob.org/)
- PyYaml 6.0 or later (http://pyyaml.org/)
- Arista EOS 4.12.0 or later
BSD-3, See LICENSE file