Skip to main content

Utility to parse a full SROS Configuration.

Project description

codecov

TTP SrosParser

A library to parse a Nokia SROS 7750 full hierarchical configuration text file into structured data. Show commands are also able to be parsed, if included in the file alongside the configuration. This library is still under development, but a lot of parsers are readily available (see below for supported features). Configurations used for testing have all been on release version higher than TiMOS 16. At the moment, there is no capability to specify release version to accommodate different parsing templates.

What TTP SrosParser is not

A library that connects and extracts information from a remote device. You, as the end-user must obtain a text file of the configuration. This file will be passed into the SrosParser class and you are able to convert a flat text configuration file into structure data using the built-in TTP parser templates. At this point, it's recommended to use a new instance of the srosparser with an individual show command as the text to parse to get the best results when parsing a show commands.

Example

"""SrosParser - Example."""
from ttp_sros_parser.srosparser import SrosParser

EXAMPLE_CONFIG = "some/dir/path/to/7750-config.txt"

# Instantiate class
router = SrosParser(EXAMPLE_CONFIG)

# Call `get_system_cards` method
router.get_system_cards()

Results:

[
   {
      "configure":{
         "card":{
            "card-type":{
               "card-type":"iom-1",
               "subscription-level":"cr"
            },
            "fail-on-error":true,
            "mda":{
               "admin-state":true,
               "egress-xpl":{
                  "window":"10"
               },
               "fail-on-error":true,
               "ingress-xpl":{
                  "window":"10"
               },
               "mda-slot":"1",
               "mda-type":"me6-100gb-qsfp28"
            },
            "slot-number":"1"
         }
      }
   }
]

Available Methods (Parsers)

Current methods available (Automatically updated at build):

Methods

Full Config

SrosParser allows you to parse the full configuration with a single method call, get_full_config() and receive the full JSON output of the device.

Custom Templates

SrosParser allows you to simply specify a custom template after you initialize a new class object.

router = SrosParser("path/to/config.txt")

cool_ttp_template = router.get_custom_template("path/to/template")

print(cool_ttp_template)

Contributing

Any contribution to the project must include unit tests and pass all linting.

Simply run:

  • docker-compose build
  • docker-compose run test

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

ttp_sros_parser-0.1.6.tar.gz (19.2 kB view details)

Uploaded Source

Built Distribution

ttp_sros_parser-0.1.6-py3-none-any.whl (29.3 kB view details)

Uploaded Python 3

File details

Details for the file ttp_sros_parser-0.1.6.tar.gz.

File metadata

  • Download URL: ttp_sros_parser-0.1.6.tar.gz
  • Upload date:
  • Size: 19.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.13

File hashes

Hashes for ttp_sros_parser-0.1.6.tar.gz
Algorithm Hash digest
SHA256 d8d1facc7073a25cbdfb343204d56b0106ae14d7f2f0be7e7a85d74d009ded2b
MD5 175f0743d9da9b7340b8ac18136d56bc
BLAKE2b-256 16dbe7635d559c151f594022eab096634bd9fb234a9be3d240e31ce095ea9491

See more details on using hashes here.

File details

Details for the file ttp_sros_parser-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for ttp_sros_parser-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 4cccb34db774f7d5c6d492bf2a6a488294b4ffb9ba6902ffc6e786af5c1f30ec
MD5 887d3a497adc8b14e68a4c5f8bbfb903
BLAKE2b-256 2716c6619f217395af63c0f3ccf51f8c11c5b731ff5fea7312b0d03b9164929f

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