Code Monkey home page Code Monkey logo

nautobot-plugin-chatops-aci's Introduction

Nautobot

Nautobot

Nautobot is a Network Source of Truth and Network Automation Platform built as a web application atop the Django Python framework with a PostgreSQL or MySQL database.

Key Use Cases

1. Flexible Source of Truth for Networking - Nautobot core data models are used to define the intended state of network infrastructure enabling it as a Source of Truth. While a baseline set of models are provided (such as IP networks and addresses, devices and racks, circuits and cable, etc.) it is Nautobot's goal to offer maximum data model flexibility. This is enabled through features such as user-defined relationships, custom fields on any model, and data validation that permits users to codify everything from naming standards to having automated tests run before data can be populated into Nautobot.

2. Extensible Data Platform for Automation - Nautobot has a rich feature set to seamlessly integrate with network automation solutions. Nautobot offers GraphQL and native Git integration along with REST APIs and webhooks. Git integration dynamically loads YAML data files as Nautobot config contexts. Nautobot also has an evolving plugin system that enables users to create custom models, APIs, and UI elements. The plugin system is also used to unify and aggregate disparate data sources creating a Single Source of Truth to streamline data management for network automation.

3. Platform for Network Automation Apps - The Nautobot plugin system enables users to create Network Automation Apps. Apps can be as lightweight or robust as needed based on user needs. Using Nautobot for creating custom applications saves up to 70% development time by re-using features such as authentication, permissions, webhooks, GraphQL, change logging, etc. all while having access to the data already stored in Nautobot. Some production ready applications include:

The complete documentation for Nautobot can be found at Read the Docs.

Questions? Comments? Start by perusing our GitHub discussions for the topic you have in mind, or join the #nautobot channel on Network to Code's Slack community!

Build Status

Branch Status
main Build Status
develop Build Status
next Build Status

Screenshots

Gif of main page


Gif of config contexts


Gif of prefix hierarchy


Gif of GraphQL


Gif of Modes

Installation

Please see the documentation for instructions on installing Nautobot.

Application Stack

Below is a simplified overview of the Nautobot application stack for reference:

Application stack diagram

Plugins and Extensibility

Nautobot offers the ability to customize your setup to better align with your direct business needs. It does so through the use of various plugins that have been developed for network automation, and are designed to be used in environments where needed.

There are many plugins available within the Nautobot Apps ecosystem. The below screenshots are an example of some popular ones that are currently available.

Plugin Screenshots

Golden Config Plugin

Gif of golden config

ChatOps Plugin

Gif of chatops

Device Lifecycle Management Plugin

Gif of DLM

Providing Feedback

The best platform for general feedback, assistance, and other discussion is our GitHub discussions. To report a bug or request a specific feature, please open a GitHub issue using the appropriate template.

If you are interested in contributing to the development of Nautobot, please read our contributing guide prior to beginning any work.

Related projects

Please check out the GitHub nautobot topic for a list of relevant community projects.

Notices

Nautobot was initially developed as a fork of NetBox (v2.10.4). NetBox was originally developed by Jeremy Stretch at DigitalOcean and the NetBox Community.

nautobot-plugin-chatops-aci's People

Contributors

smk4664 avatar ubajze avatar whitej6 avatar

Stargazers

 avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

nautobot-plugin-chatops-aci's Issues

EPG to Contract binding command

Proposed Functionality

List EPG to Contract relationship/binding

Use Case

List the EPG to Contract bindings so I can determine whether traffic should be allowed between two EPGs.

How to develop locally/offline ?

I have servers at home that can set up all of the components of nautobot, but I don't want to connect to slack over the internet just to develop features. Is there any guide on how to set up a local development environment? I am not very savvy with Slack chat.

Or is it required that I set up a Nautobot server that's open to the internet for receiving commands from slack ?

Fix broken tests in CI Pipeline

Unable to download nautobot-dev:1.0.3-py3.8. We should look into testing against newer versions of Nautobot.

#3 ERROR: failed to do request: Head "https://ghcr.io/v2/nautobot/nautobot-dev/manifests/1.0.3-py3.8": net/http: TLS handshake timeout
------
 > [internal] load metadata for ghcr.io/nautobot/nautobot-dev:1.0.3-py3.8:
------
Dockerfile:5
--------------------
   3 |     ARG PYTHON_VER=3.8
   4 |     
   5 | >>> FROM ghcr.io/nautobot/nautobot-dev:${NAUTOBOT_VER}-py${PYTHON_VER}
   6 |     
   7 |     ENV prometheus_multiproc_dir=/prom_cache
--------------------
ERROR: failed to solve: ghcr.io/nautobot/nautobot-dev:1.0.3-py3.8: failed to do request: Head "https://ghcr.io/v2/nautobot/nautobot-dev/manifests/1.0.3-py3.8": net/http: TLS handshake timeout
Error: buildx failed with: ERROR: failed to solve: ghcr.io/nautobot/nautobot-dev:1.0.3-py3.8: failed to do request: Head "https://ghcr.io/v2/nautobot/nautobot-dev/manifests/1.0.3-py3.8": net/http: TLS handshake timeout

README suggestions

Concerning the README:

  • I’d suggest the images in the README be larger; I’m not sure they’ll be readable unless the user explicitly clicks on them, which nullifies the case for putting them side by side and is more work for the reader

  • In the INSTALLATION section, I recommend specifying that you only need to configure the nautobot_chatops sections for the chat platforms you want to run on; I believe this is mostly obvious, but for someone new to all of this, it’s certainly helpful to have that clarity

  • As someone who is not very versed in systems and has to look stuff up all the time, I’d like to see an example of how to set an environment variable since they are heavily referenced in the README

Contract Filter List Command

Proposed Functionality

List EPG filters, ports

Use Case

List the Contract filters so I can determine what traffic the contract allows through.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.