/transintentlation

Translate an Intent config to the actual changes to make (IOS-like config)

Primary LanguagePythonMIT LicenseMIT

Transintentlation

Installation

git clone https://github.com/jpmondet/transintentlation
cd transintentlation
pip install .

Usage as CLI

By default, shows the commands to apply on a device to conform with the intended config :

transintentlation intent.cfg running.cfg

Example output :

!====================================================================================================
!COMMANDS TO APPLY TO BE IN SYNC WITH THE INTENT CONFIG:
!====================================================================================================
!!CLEANINGS AND MODIFICATIONS
!---------------------------
no banner motd
no hostname RUNNING_HOSTNAME
interface loopback0
 no ip address 172.18.0.6/23
 ip address 172.18.0.6/24
vlan 99
 no name VLAN_99
 name Production
vrf context management
 no ip route 0.0.0.0/0 10.10.20.254
 ip route 0.0.0.0/0 10.10.20.1
!---------------------------
!!NEW CONFIGS 
!---------------------------
banner motd ^
Hello Foreign passenger
^
hostname test_vars
interface Ethernet1/9
 ip address 11.22.33.44/24
!====================================================================================================

In addition, there are some options:

transintentlation --help

Usage: transintentlation [OPTIONS] INTENT_CONFIG RUNNING_CONFIG

  Show the commands to apply to be in sync with the intent config by
  default. Options can be used by passing --OPTION_NAME=True

Options:
  --missing BOOLEAN            Show only the missing config
  --additional BOOLEAN         Show only the additional config
  --apply_missing BOOLEAN      Show the commands to apply the missing config
  --delete_additional BOOLEAN  Show the commands to delete the additional
                               config
  --diff BOOLEAN               Show only the diff between the 2 configs
  --variables PATH             In case you provide a .j2 file as the
                               "intent_config", you can pass a variables YAML
                               file with this option
  --help                       Show this message and exit.

Usage in Python

Printing all changes in one call

from transintentlation import Translate

translate = Translate(intent_config, running_config)
translate.apply_all_configs()

Getting all changes as a list instead of printing them directly

from transintentlation import Translate

translate = Translate(intent_config, running_config)
cmds = translate.cmds_to_conform()

Print only the commands needed to apply missing config

from transintentlation import Translate

translate = Translate(intent_config, running_config)
translate.to_apply()

Print only the commands needed to delete the extra config

from transintentlation import Translate

translate = Translate(intent_config, running_config)
translate.to_delete()

Some other comparing options

from transintentlation import Comparing

diff = Comparing(intent_config, running_config)

diff.pprint_missing()
diff.pprint_additional()
diff.delta()