Skip to main content

ncs-yang is the smartway to compile yang file/files along with it's dependencies from Makefile.

Project description

ncs-yang

License: Apache 2.0 Version: 1.2.3.1 Downloads Downloads

ncs-yang is a simple tool to compile specific yang file/s using ncsc and to create uml diagrams from it.

Introduction

We haven't found a simple way to compile single yang file or to create uml diagrams from it. We usuall run make or make all to compile the yang files. For uml diagrams we have to copy all the yang files from ncs and the project to an directory and generate uml diagram using pyang -f uml command.

Being a developer we wanted to trigger/generate with simple commands or single line commands. Which leaded to create this library.

Pre-requisites

  • ncsc, pyang commands must be reconginsed by the terminal.
  • ncs-yang supports both trains of python 2.7+ and 3.1+, the OS should not matter.

Installation and Downloads

The best way to get ncs-yang is with setuptools or pip. If you already have setuptools, you can install as usual:

python -m pip install ncs-yang
pip install ncs-yang

Otherwise download it from PyPi, extract it and run the setup.py script

python setup.py install

If you're Interested in the source, you can always pull from the github repo:

  • From github git clone https://github.com/kirankotari/ncs-yang.git

Help

⋊> ~/k/i/ncs-yang on master $ ncs-yang --help

ncs-yang 
    <YangFile or YangFiles> [--uml | --jtox | --dsdl] 
    --schema <yang>         [--json | --xml | --yml]
    --yang-sync <settings.yml>          to collect yang files from remote machine
    --payload <payload.json> 
        <YangFile or YangFiles>         will return payload.xml
    --payload <payload.xml>
        <YangFile or YangFiles>         will return payload.json
    --payload <payload.yml>             will return payload.json
        <YangFile or YangFiles>         will return payload.xml
    --log [info | debug]
    --path <dependency yang path>
    -h | --help
    -v | --version

Features

Compiling specific yang files

  • running single yang file
⋊> ~/k/i/cfs-package on sprint $ ncs-yang src/yang/cfs-mpls.yang
[ INFO ] :: [ ncs-yang ] :: compiling yang file: src/yang/cfs-mpls.yang
 /opt/ncs/ncs-5.2.1.2/bin/ncsc `ls cfs-mpls-ann.yang > /dev/null 2>&1 && echo "-a cfs-mpls-ann.yang"` --yangpath /opt/ncs/ncs-run/packages/cfs-package/src/../../common/src/yang --yangpath /opt/ncs/ncs-run/packages/cfs-package/src/../../resource-manager/src/yang -c -o /opt/ncs/ncs-run/packages/cfs-package/load-dir/cfs-mpls.fxs src/yang/cfs-mpls.yang
  • running multiple yang files
⋊> ~/k/i/cfs-package/src/yang on sprint $ ncs-yang cfs-mpls.yang cfs-asa.yang
[ INFO ] :: [ ncs-yang ] :: compiling yang file: cfs-mpls.yang
 /opt/ncs/ncs-5.2.1.2/bin/ncsc `ls cfs-mpls-ann.yang > /dev/null 2>&1 && echo "-a cfs-mpls-ann.yang"` --yangpath /opt/ncs/ncs-run/packages/cfs-package/src/../../common/src/yang --yangpath /opt/ncs/ncs-run/packages/cfs-package/src/../../resource-manager/src/yang -c -o /opt/ncs/ncs-run/packages/cfs-package/load-dir/cfs-mpls.fxs cfs-mpls.yang
[ INFO ] :: [ ncs-yang ] :: compiling yang file: cfs-asa.yang
 /opt/ncs/ncs-5.2.1.2/bin/ncsc `ls cfs-asa-ann.yang > /dev/null 2>&1 && echo "-a cfs-asa-ann.yang"` --yangpath /opt/ncs/ncs-run/packages/cfs-package/src/../../common/src/yang --yangpath /opt/ncs/ncs-run/packages/cfs-package/src/../../resource-manager/src/yang -c -o /opt/ncs/ncs-run/packages/cfs-package/load-dir/cfs-asa.fxs cfs-asa.yang

Creating uml diagrams from yang files

⋊> ~/k/i/c/s/yang on sprint $ ncs-yang cfs-mpls.yang --uml
[ INFO ] :: [ ncs-yang ] :: generated uml diagram: cfs-mpls.uml

FAQ

  • Question: I am seeing an error?
    Answer: Error might be related to yang file, we recommend to check again beforing opening a bug.

Change Log

New in 1.2.4

  • Feature Adding yang-sync
  • Feature Adding payload convertion
  • Feature Adding schema generator

New in 1.2.3

  • Fix: Import issues, logger corrections

New in 1.2

  • Feature: Adding UML Diagrams support
  • Feature: Adding Jtox support
  • Feature: Adding DSDL support

Bug Tracking and Support

  • Please report any suggestions, bug reports, or annoyances with ncs-yang through the Github bug tracker.

License and Copyright

Author and Thanks

ncs-yang was developed by Kiran Kumar Kotari, For any suggestions or comments contact kkotari@cisco.com or kirankotari@live.com. If you find any bugs please fix them and send me a pull request.

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

ncs-yang-1.2.4.3.tar.gz (18.7 kB view details)

Uploaded Source

Built Distribution

ncs_yang-1.2.4.3-py3-none-any.whl (17.6 kB view details)

Uploaded Python 3

File details

Details for the file ncs-yang-1.2.4.3.tar.gz.

File metadata

  • Download URL: ncs-yang-1.2.4.3.tar.gz
  • Upload date:
  • Size: 18.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.9.6

File hashes

Hashes for ncs-yang-1.2.4.3.tar.gz
Algorithm Hash digest
SHA256 32f51d64a16a76d251e4c5dfef7369036709b8b6b9bb687f33a53197a165274e
MD5 4b135ed09f6fb1ee642905f036f26f3e
BLAKE2b-256 21b7f48fde0051c9abd2d91473a07e71dc8dd04736bfbd4f6d512365c8377829

See more details on using hashes here.

File details

Details for the file ncs_yang-1.2.4.3-py3-none-any.whl.

File metadata

  • Download URL: ncs_yang-1.2.4.3-py3-none-any.whl
  • Upload date:
  • Size: 17.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.9.6

File hashes

Hashes for ncs_yang-1.2.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 a9ca63ccf4fe46af69b1073469573783206db7aaeb116c26ccf554bae143649e
MD5 60e9952e847520534f23b72e935007a5
BLAKE2b-256 f01da0f11ff29ddc6fa84955d3697f77acbfbf45f70ea369f68da81d77c7d974

See more details on using hashes here.

Supported by

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