Skip to main content

Cisco CatalystCenter Platform SDK

Project description

Work with the CatalystCenter APIs in native Python!


catalystcentersdk is a community developed Python library for working with the CatalystCenter APIs. Our goal is to make working with CatalystCenter in Python a native and natural experience!

from catalystcentersdk import api

# Create a CatalystCenterAPI connection object;
# it uses CatalystCenter sandbox URL, username and password, with CatalystCenter API version 2.3.5.3.
# and requests to verify the server's TLS certificate with verify=True.
catalyst = api.CatalystCenterAPI(username="devnetuser",
                        password="Cisco123!",
                        base_url="https://sandboxdnac.cisco.com:443",
                        version='2.3.7.9',
                        verify=True)

# Find all devices that have 'Switches and Hubs' in their family
devices = catalyst.devices.get_device_list(family='Switches and Hubs')

# Print all of demo devices
for device in devices.response:
    print('{:20s}{}'.format(device.hostname, device.upTime))

# Find all tags
all_tags = catalyst.tag.get_tag(sort_by='name', order='des')
demo_tags = [tag for tag in all_tags.response if 'Demo' in tag.name ]

#  Delete all of the demo tags
for tag in demo_tags:
    catalyst.tag.delete_tag(tag.id)

# Create a new demo tag
demo_tag = catalyst.tag.create_tag(name='catalyst Demo')
task_demo_tag = catalyst.task.get_task_by_id(task_id=demo_tag.response.taskId)

if not task_demo_tag.response.isError:
    # Retrieve created tag
    created_tag = catalyst.tag.get_tag(name='catalyst Demo')

    # Update tag
    update_tag = catalyst.tag.update_tag(id=created_tag.response[0].id,
                                     name='Updated ' + created_tag.response[0].name,
                                     description='Catalyst demo tag')

    print(catalyst.task.get_task_by_id(task_id=update_tag.response.taskId).response.progress)

    # Retrieved updated
    updated_tag = catalyst.tag.get_tag(name='Updated catalyst Demo')
    print(updated_tag)
else:
    # Get task error details
    print('Unfortunately ', task_demo_tag.response.progress)
    print('Reason: ', task_demo_tag.response.failureReason)

# Advance usage example using Custom Caller functions
# Define the get_global_credentials and create_netconf_credentials functions
# under the custom_caller wrapper.
# Call them with:
#     catalyst.custom_caller.get_global_credentials('NETCONF')
#     catalyst.custom_caller.create_netconf_credentials('65533')
def setup_custom():
    catalyst.custom_caller.add_api('get_global_credentials',
                            lambda credential_type:
                                catalyst.custom_caller.call_api(
                                    'GET',
                                    '/dna/intent/api/v1/global-credential',
                                    params={
                                        'credentialSubType': credential_type
                                    }).response
                            )
    catalyst.custom_caller.add_api('create_netconf_credentials',
                            lambda port:
                                catalyst.custom_caller.call_api(
                                    'POST',
                                    '/dna/intent/api/v1/global-credential/netconf',
                                    json=[{
                                        "netconfPort": port
                                    }])
                            )

# Add the custom API calls to the connection object under the custom_caller wrapper
setup_custom()
# Call the newly added functions
catalyst.custom_caller.create_netconf_credentials('65533')
print(catalyst.custom_caller.get_global_credentials('NETCONF'))

Introduction

Check out the complete Introduction

catalystcentersdk handles all of this for you:

  • Reads your CatalystCenter credentials from environment variables.

  • Reads your CatalystCenter API version from environment variable CATALYST_CENTER_VERSION.

  • Controls whether to verify the server’s TLS certificate or not according to the verify parameter.

  • Reads your CatalystCenter debug from environment variable CATALYST_CENTER_DEBUG. Boolean.

  • Wraps and represents all CatalystCenter API calls as a simple hierarchical tree of native-Python methods

  • If your Python IDE supports auto-completion (like PyCharm_), you can navigate the available methods and object attributes right within your IDE

  • Represents all returned JSON objects as native Python objects - you can access all of the object’s attributes using native dot.syntax

  • Automatic Rate-Limit Handling Sending a lot of requests to CatalystCenter? Don’t worry; we have you covered. CatalystCenter will respond with a rate-limit response, which will automatically be caught and “handled” for you.

  • Refresh token Each time the token becomes invalid, the SDK will generate a new valid token for you.

Installation

Installing and upgrading catalystcentersdk is easy:

Install via PIP

$ pip install catalystcentersdk

Upgrading to the latest Version

$ pip install catalystcentersdk --upgrade

Compatibility matrix

The following table shows the supported versions.

Cisco CatalystCenter version

Python “catalystcentersdk” version

2.3.7.6

2.3.7.6.x

2.3.7.9

2.3.7.9.x

If your SDK is older please consider updating it first.

Documentation

Excellent documentation is now available at: https://catalystcentersdk.readthedocs.io

Check out the Quickstart to dive in and begin using catalystcentersdk.

Release Notes

Please see the releases page for release notes on the incremental functionality and bug fixes incorporated into the published releases.

Questions, Support & Discussion

catalystcentersdk is a community developed and community supported project. If you experience any issues using this package, please report them using the issues page.

Contribution

catalystcentersdk is a community development projects. Feedback, thoughts, ideas, and code contributions are welcome! Please see the Contributing guide for more information.

Inspiration

This library is inspired by the webexteamssdk library

Changelog

All notable changes to this project will be documented in the CHANGELOG file.

The development team may make additional name changes as the library evolves with the Cisco CatalystCenter APIs.

Copyright (c) 2024 Cisco Systems.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

catalystcentersdk-2.3.7.9.3.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

catalystcentersdk-2.3.7.9.3-py3-none-any.whl (2.1 MB view details)

Uploaded Python 3

File details

Details for the file catalystcentersdk-2.3.7.9.3.tar.gz.

File metadata

  • Download URL: catalystcentersdk-2.3.7.9.3.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.6 Darwin/24.1.0

File hashes

Hashes for catalystcentersdk-2.3.7.9.3.tar.gz
Algorithm Hash digest
SHA256 e35e5e2b8df607b1ccdc263681111897e409b2665219b1ebe8ce1bee724788c1
MD5 6fa57247a1e0370df38b37aaad3ad3f4
BLAKE2b-256 2fbf6599987ec6bc558c994e4dc8cd78e36bb1682ca0ca063594e18aa07d9d62

See more details on using hashes here.

File details

Details for the file catalystcentersdk-2.3.7.9.3-py3-none-any.whl.

File metadata

File hashes

Hashes for catalystcentersdk-2.3.7.9.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d8048e9806dcb8641a807dd7509e8b142501e3efd81bd2a50aac7759a29484fe
MD5 f0687593de152752f3006b5f63afe654
BLAKE2b-256 1b377b7708c4ecff3c1142ae58ffc8a983f768510f7a5473a451d432aefb5fe8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page