ASIMTOTE
========
This package contains two main elements used to compare text-based
configuration files (or other files in simple text in a similar format) where
they are structured using indented blocks of directives/commands, typically for
network devices:
* a parser to read in configuration files and stored them in a dictionary --
the parser utilises the hierarchical nature of the configuration to
understand that the same command name might mean different things in
different contexts
* a comparator that takes two configuration dictionaries (typically produced by
the parser, above) - a source and a target configuration - and writes out
a configuration file (or update command set) to transform the source
configuration into the destination - this uses a series of 'converters' to
handle the difference for each configuration element (e.g. changing the
description assigned to an interface)
Each of these are written as abstract base classes that can be inherited from
to crete concrete classes for each platform, but the base processing of the
parsing and comparing should be consistent, requiring only the specific
commands to be handled.
Currently, Cisco IOS is the only concrete platform and only a subset so far
(the comparator is still being tweaked to handle this all relatively
straightforwardly, before all the commands are implemented). There are
currently some odd commands and edge cases which are awkward to handle without
some improvements to the core process.
The scripts also support a system whereby 'excludes' can be specified, to
exclude those elements of the configuration dictionary which should not be
compared, if a known difference exists that cannot be resolved, either as an
interim divergence, or a permanent exception.
THE NAME
--------
This package was formerly known as net-contextdiff but has been renamed as it
is expected to drop the indented configuration difference mechansim (still
using context, but not via indenting).
The new name 'asimtote' is a backronym for something like 'Autonomous System
Internetwork Management ...' but the rest has not yet been completed. It's
similarity to 'asymptote' is deliberate as it aims to get a configuration into
a desired state but will probably never ever get there.
FUTURE DEVELOPMENTS
-------------------
Longer term, this script may be made unnecessary by other tools but, if it
remains, will probably be parsing configurations via something like REST and
JSON, rather than by reading legacy text configuration files. It would also be
making changes using similar calls rather than generating legacy text
conversions. The problem of making changes in the correct order and committing
them may still remain, though.
It would also be desirable to separate the parser as this could be useful
elsewhere. At the moment, however, it's so intertwined with the converter this
would be tedious to maintain and keep in sync. It should probably be made
easily usable as a separate component, however.
Raw data
{
"_id": null,
"home_page": "https://gitlab.developers.cam.ac.uk/uis/netsys/udn/asimtote",
"name": "asimtote",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": null,
"author": "Robert Franklin",
"author_email": "rcf34@cam.ac.uk",
"download_url": "https://files.pythonhosted.org/packages/d1/dc/397a58353a1449e6ced99a28120e4a4049bed054f010d802503b4d5ae28c/asimtote-0.16.15.tar.gz",
"platform": null,
"description": "ASIMTOTE\n========\n\nThis package contains two main elements used to compare text-based\nconfiguration files (or other files in simple text in a similar format) where\nthey are structured using indented blocks of directives/commands, typically for\nnetwork devices:\n\n* a parser to read in configuration files and stored them in a dictionary --\n the parser utilises the hierarchical nature of the configuration to\n understand that the same command name might mean different things in\n different contexts\n\n* a comparator that takes two configuration dictionaries (typically produced by\n the parser, above) - a source and a target configuration - and writes out\n a configuration file (or update command set) to transform the source\n configuration into the destination - this uses a series of 'converters' to\n handle the difference for each configuration element (e.g. changing the\n description assigned to an interface)\n\nEach of these are written as abstract base classes that can be inherited from\nto crete concrete classes for each platform, but the base processing of the\nparsing and comparing should be consistent, requiring only the specific\ncommands to be handled.\n\nCurrently, Cisco IOS is the only concrete platform and only a subset so far\n(the comparator is still being tweaked to handle this all relatively\nstraightforwardly, before all the commands are implemented). There are\ncurrently some odd commands and edge cases which are awkward to handle without\nsome improvements to the core process.\n\nThe scripts also support a system whereby 'excludes' can be specified, to\nexclude those elements of the configuration dictionary which should not be\ncompared, if a known difference exists that cannot be resolved, either as an\ninterim divergence, or a permanent exception.\n\n\nTHE NAME\n--------\n\nThis package was formerly known as net-contextdiff but has been renamed as it\nis expected to drop the indented configuration difference mechansim (still\nusing context, but not via indenting).\n\nThe new name 'asimtote' is a backronym for something like 'Autonomous System\nInternetwork Management ...' but the rest has not yet been completed. It's\nsimilarity to 'asymptote' is deliberate as it aims to get a configuration into\na desired state but will probably never ever get there.\n\n\nFUTURE DEVELOPMENTS\n-------------------\n\nLonger term, this script may be made unnecessary by other tools but, if it\nremains, will probably be parsing configurations via something like REST and\nJSON, rather than by reading legacy text configuration files. It would also be\nmaking changes using similar calls rather than generating legacy text\nconversions. The problem of making changes in the correct order and committing\nthem may still remain, though.\n\nIt would also be desirable to separate the parser as this could be useful\nelsewhere. At the moment, however, it's so intertwined with the converter this\nwould be tedious to maintain and keep in sync. It should probably be made\neasily usable as a separate component, however.\n\n\n",
"bugtrack_url": null,
"license": null,
"summary": "Compare network device configuration files using contextual structures",
"version": "0.16.15",
"project_urls": {
"Homepage": "https://gitlab.developers.cam.ac.uk/uis/netsys/udn/asimtote"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "bc4c4ccb906a4a6963b147c75d577ee4979c4f1322d86cae0a136de8912d32de",
"md5": "b4fedb8c4396ada6770ad7f96da8337e",
"sha256": "eae5ba14415885001a66f188bc5b32bcc6480afd49ea437e80dd33a491cdbc5b"
},
"downloads": -1,
"filename": "asimtote-0.16.15-py3-none-any.whl",
"has_sig": false,
"md5_digest": "b4fedb8c4396ada6770ad7f96da8337e",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 74515,
"upload_time": "2025-01-02T14:34:19",
"upload_time_iso_8601": "2025-01-02T14:34:19.044735Z",
"url": "https://files.pythonhosted.org/packages/bc/4c/4ccb906a4a6963b147c75d577ee4979c4f1322d86cae0a136de8912d32de/asimtote-0.16.15-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d1dc397a58353a1449e6ced99a28120e4a4049bed054f010d802503b4d5ae28c",
"md5": "c0fc62492f1af039b993b5923f6b7518",
"sha256": "eaf1583ede347dca0d10d1e7cec83e614f9d3a3680eea35cbf2c1b1d2479d816"
},
"downloads": -1,
"filename": "asimtote-0.16.15.tar.gz",
"has_sig": false,
"md5_digest": "c0fc62492f1af039b993b5923f6b7518",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 66446,
"upload_time": "2025-01-02T14:34:20",
"upload_time_iso_8601": "2025-01-02T14:34:20.370443Z",
"url": "https://files.pythonhosted.org/packages/d1/dc/397a58353a1449e6ced99a28120e4a4049bed054f010d802503b4d5ae28c/asimtote-0.16.15.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-02 14:34:20",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "asimtote"
}