Skip to main content

Nokia SROS, Cisco IOS style (parent/child with space indent) config edit (add/delete/replace) with regex

Project description

Edit4Config

Nokia SROS, Cisco IOS style (parent/child with space indentation) config edit module with add, delete, replace and search function with regex supported. Every line in config text converted to path (parent) and value (line) based on space indent. After this converting process (Config with Parents or CwP) every config line is unique with own parents and editing can be done easily.


Requirements

Python >= 3.9

For Windows, select the Add Python 3.x to PATH checkbox during installation.


Installation

pip install edit4config

CwP (Config with Parents) Example

Config Text:

configure
    ...
    card 1
        card-type iom-e
        ...
        mda 1
            mda-type me10-10gb-sfp+
            ...
            no shutdown
            ...
        mda 2
            ...
        ...
    ...
...

CwP List:

[
...
['configure', '    card 1'],
['configure,card 1', '        card-type iom-e'],
['configure,card 1', '        mda 1'],
['configure,card 1,mda 1', '            mda-type me10-10gb-sfp+'],
...
['configure,card 1,mda 1', '            no shutdown'],
...
['configure,card 1', '        mda 2'],
...
]

CwP Text:

...
configure,card 1
configure,card 1,card-type iom-e
configure,card 1,mda 1
configure,card 1,mda 1,mda-type me10-10gb-sfp+
...
configure,card 1,mda 1,no shutdown
...
configure,card 1,mda 2
...

Usage

EditConfig Simple Usage

After CwP converting EditConfig add, delete, replace, search and other methods can be used as below.

Add-Delete-Replace methods supported regex, multiple match.

Add-Delete methods supported serial CwP Text lines with newline.

# import EditConfig module
from edit4config import EditConfig

# read config file and get config_text
with open('CONFIG_FILE.txt') as file:
    config_text = file.read()

# define EditConfig object with options e.g. comments, step_space
# comments for Nokia is ('#', 'echo') and for Cisco is ('!')
# step_space for Nokia is 4 and for Cisco is 1
device_cwp = EditConfig(config_text, 4, ('#', 'echo'))

# add "sync-e" before "no shutdown" under configure,card 1,mda 1
device_cwp.add_before_lines(
                            'configure,card 1,mda 1,sync-e',
                            'configure,card 1,mda 1,no shutdown'
                        )

# delete "no shutdown" under configure,card 1,mda 1
device_cwp.delete_serial_lines('configure,card 1,mda 1,no shutdown')

# replace "no shutdown" with "shutdown" under configure,card 1,mda 1
device_cwp.replace_line(
                        'configure,card 1,mda 1,no shutdown',
                        'configure,card 1,mda 1,shutdown'
                    )

# delete "no shutdown" for all card and all mda with regex
device_cwp.delete_serial_lines(
                            'configure,card \d+,mda \d+,no shutdown',
                            regex_match=True, 
                            multiple_match=True
                            )

# after editing done, convert device_cwp object to text file
new_config_text = device_cwp.cwp_to_text()

with open('CONFIG_FILE_NEW.txt', 'w') as file:
    file.write(new_config_text)

Another example below for getting CwP and making custom jobs.

# import EditConfig module
from edit4config import EditConfig

# read config file and get config_text
with open('CONFIG_FILE.txt') as file:
    config_text = file.read()

# define EditConfig object with options e.g. comments, step_space
# comments for Nokia is ('#', 'echo') and for Cisco is ('!')
# step_space for Nokia is 4 and for Cisco is 1
device_cwp = EditConfig(config_text, 4, ('#', 'echo'))

# get full cwp-list from EditConfig object with <cwp> variable
device_cwp_list = device_cwp.cwp

# get ntp config from cwp-list and print
for line_path, line_value in device_cwp.cwp:
    if line_path.startswith('configure,system,time,ntp'):
        print(line_value.strip())

Besides simple usage check other EditConfig methods e.g. cwp_search, cwp_serial_check.

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

edit4config-2024.1.1.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

edit4config-2024.1.1-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file edit4config-2024.1.1.tar.gz.

File metadata

  • Download URL: edit4config-2024.1.1.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for edit4config-2024.1.1.tar.gz
Algorithm Hash digest
SHA256 76bf5f25bd9a10a23045488e9a1548135fe304f68a4a59782810b8d38edad167
MD5 65a6c08f4cecdaf2c8e56f4629fd4083
BLAKE2b-256 f2d393a62cfd071ba4aa67c4056780c129f53a95bc5ec5c09e40715575600fce

See more details on using hashes here.

File details

Details for the file edit4config-2024.1.1-py3-none-any.whl.

File metadata

  • Download URL: edit4config-2024.1.1-py3-none-any.whl
  • Upload date:
  • Size: 7.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for edit4config-2024.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 eb0b3cb21bf03d401347332a8570b41f00572cfafecaa11606f83192728e26ca
MD5 16c2b49e63a49274ca5d4b20012ebffb
BLAKE2b-256 481ceee3927b6a54b70c20158f909ffe03798d88eded7ef33be48f0b73eb54d3

See more details on using hashes here.

Supported by

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