DNA Center-Inventory-Webex Integration

Updating Inventory using DNA-C with Chatbot Notification bot

Contacts

Solution Components

  • Python 3.8
  • DNA-Center
  • Webex
  • MySql Database 8.0

Installation/Configuration

Clone the repo :

$ git clone https://github.com/gve-sw/DNACenterInventoryWebexIntegration.git

(Optional) Create Virtual Environment :

Initialize a virtual environment

virtualenv venv

Activate the virtual env

Windows venv\Scripts\activate

Linux source venv/bin/activate

Now you have your virtual environment setup and ready

Install the libraries :

$ pip install requirements.txt

Setup:

Cisco DNA Center Connection

  1. Obtain the username, password and base url for your Cisco DNA Center environment.

  2. Export the following information as environment variables so it is possible to connect to the Cisco DNA Center API.

DNAC_URL = env_lab.DNA_CENTER["host"]
DNAC_USER = env_lab.DNA_CENTER["username"]
DNAC_PASS = env_lab.DNA_CENTER["password"]

Cisco Webex Bot

  1. Create a Webex Bot. Webex Bots can be created from the Cisco Developer website. https://developer.webex.com/docs/bots

  2. Add the access token for the Webex Bot.

ACCESS_TOKEN = "ACCESS_TOKEN"
  1. Fill the email address of a user or group to recieve the webex notification.
to = ' EMAIL_ADDRESSS'

Database Connection

  1. Download and Install MySQL.

  2. Create a table in MySQL database with the following script. You can run the script from MySQL Workbench.

CREATE TABLE `allDeviceDetails` (
  `hostname` varchar(255) DEFAULT NULL,
  `ip` varchar(255) DEFAULT NULL,
  `serial` varchar(255) NOT NULL,
  `platformId` varchar(255) DEFAULT NULL,
  `version` varchar(255) DEFAULT NULL,
  `role` varchar(255) DEFAULT NULL,
  `uptime` varchar(255) DEFAULT NULL,
  `createDate` varchar(255) DEFAULT NULL,
  `updateDate` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`serial`)
) 

Now you have completed the setup and are ready to run the script.

Usage:

Run the python script

    $ python inventory_update.py

The Webex Bot will send the list of Network devices which have been updated in the database:
Sample Database Update Message

LICENSE

Provided under Cisco Sample Code License, for details see LICENSE

CODE_OF_CONDUCT

Our code of conduct is available here

CONTRIBUTING

See our contributing guidelines here

DISCLAIMER:

Please note: This script is meant for demo purposes only. All tools/ scripts in this repo are released for use "AS IS" without any warranties of any kind, including, but not limited to their installation, use, or performance. Any use of these scripts and tools is at your own risk. There is no guarantee that they have been through thorough testing in a comparable environment and we are not responsible for any damage or data loss incurred with their use.
You are responsible for reviewing and testing any scripts you run thoroughly before use in any non-testing environment.

View code on GitHub

Code Exchange Community

Get help, share code, and collaborate with other developers in the Code Exchange community.View Community
Disclaimer:
Cisco provides Code Exchange for convenience and informational purposes only, with no support of any kind. This page contains information and links from third-party websites that are governed by their own separate terms. Reference to a project or contributor on this page does not imply any affiliation with or endorsement by Cisco.