From 8ee5895ac90ee475dc168bd9b0fc4f66203fbb0f Mon Sep 17 00:00:00 2001 From: Aldo Ortega Date: Fri, 3 May 2024 05:37:12 -0400 Subject: [PATCH 1/2] Moved scripts --- .../2022.2.0/000_storehouse_to_mongo.py} | 0 scripts/db/2022.2.0/README.md | 67 +++++ .../2023.1.0/000_unset_active.py} | 0 scripts/{ => db/2023.1.0}/README.md | 232 +----------------- .../2023.2.0/000_vlan_pool.py} | 4 +- .../2023.2.0/001_special_vlan_allocation.py} | 0 scripts/db/2023.2.0/README.md | 149 +++++++++++ 7 files changed, 227 insertions(+), 225 deletions(-) rename scripts/{storehouse_to_mongo.py => db/2022.2.0/000_storehouse_to_mongo.py} (100%) create mode 100644 scripts/db/2022.2.0/README.md rename scripts/{unset_active.py => db/2023.1.0/000_unset_active.py} (100%) rename scripts/{ => db/2023.1.0}/README.md (50%) rename scripts/{vlan_pool.py => db/2023.2.0/000_vlan_pool.py} (97%) rename scripts/{special_vlan_allocation.py => db/2023.2.0/001_special_vlan_allocation.py} (100%) create mode 100644 scripts/db/2023.2.0/README.md diff --git a/scripts/storehouse_to_mongo.py b/scripts/db/2022.2.0/000_storehouse_to_mongo.py similarity index 100% rename from scripts/storehouse_to_mongo.py rename to scripts/db/2022.2.0/000_storehouse_to_mongo.py diff --git a/scripts/db/2022.2.0/README.md b/scripts/db/2022.2.0/README.md new file mode 100644 index 0000000..9de5ace --- /dev/null +++ b/scripts/db/2022.2.0/README.md @@ -0,0 +1,67 @@ +## `topology` scripts for Kytos version 2022.2.0 + +This folder contains Topology's related scripts: + +### Data migration from storehouse to MongoDB + +[`000_storehouse_to_mongo.py`](./000_storehouse_to_mongo.py) is a script to migrate the data entries from certain namespaces from `storehouse` to MongoDB. + +#### Pre-requisites + +- There's no additional Python libraries dependencies required, other than installing the existing `topology`'s, or if you're running in development locally then installing `requirements/dev.in` +- Make sure you don't have `kytosd` running with otherwise topology will start writing to MongoDB, and the application could overwrite the data you're trying to insert with this script. +- Make sure MongoDB replica set is up and running. +- Export MongoDB related variables that [db/client.py](../db/client.py) uses, make sure the hosts names can be resolved: + +``` +export MONGO_USERNAME= +export MONGO_PASSWORD= +export MONGO_DBNAME=napps +export MONGO_HOST_SEEDS="mongo1:27017,mongo2:27018,mongo3:27099" +``` + +#### How to use + +- Export these two environment variables, based on where storehouse and kytos are installed, if you're running `amlight/kytos:latest` docker image they should be: + +``` +export STOREHOUSE_NAMESPACES_DIR=/var/tmp/kytos/storehouse/ +export PYTHONPATH=/var/lib/kytos +``` + +- Parametrize the environment variable `CMD` command and execute `000_storehouse_to_mongo.py` script (the command is passed via an env var to avoid conflicts with `kytosd`, since depending how you set the `PYTHONPATH` it can interfere) + +- The following `CMD` commands are available: + +``` +insert_links_metadata +insert_switches_metadata +insert_interfaces_metadata +insert_topology +load_topology +load_switches_metadata +load_interfaces_metadata +load_links_metadata +``` + +The `load_*` commands are meant to be used to double check what would actually be loaded, so it's encouraged to try out the load command to confirm the data can be loaded properly, and if they are, feel free to use any of the `insert_*` commands, which will rely internally on the load functions to the either insert or update the documents. + +For example, to double check what would be loaded in the topology from storehouse namespace `kytos.topology.status`: + +``` +CMD=load_topology python3 scripts/db/2022.2.0/000_storehouse_to_mongo.py +``` + +And then, to insert (or update) the entire topology: + +``` +CMD=insert_topology python3 scripts/db/2022.2.0/000_storehouse_to_mongo.py +``` + +If the topology you're migrating has metadata saved on `kytos.topology.(switches|interfaces|links).metadata` namespaces, you'll also have to run these commands: + +``` +CMD=insert_links_metadata python3 scripts/db/2022.2.0/000_storehouse_to_mongo.py +CMD=insert_switches_metadata python3 scripts/db/2022.2.0/000_storehouse_to_mongo.py +CMD=insert_interfaces_metadata python3 scripts/db/2022.2.0/000_storehouse_to_mongo.py +``` diff --git a/scripts/unset_active.py b/scripts/db/2023.1.0/000_unset_active.py similarity index 100% rename from scripts/unset_active.py rename to scripts/db/2023.1.0/000_unset_active.py diff --git a/scripts/README.md b/scripts/db/2023.1.0/README.md similarity index 50% rename from scripts/README.md rename to scripts/db/2023.1.0/README.md index c2fd5bf..09d084b 100644 --- a/scripts/README.md +++ b/scripts/db/2023.1.0/README.md @@ -1,76 +1,10 @@ -## `topology` scripts +## `topology` scripts for Kytos version 2023.1.0 This folder contains Topology's related scripts: -

Data migration from storehouse to MongoDB

+### $unset active from DB switches and links collections -[`storehouse_to_mongo.py`](./storehouse_to_mongo.py) is a script to migrate the data entries from certain namespaces from `storehouse` to MongoDB. - -#### Pre-requisites - -- There's no additional Python libraries dependencies required, other than installing the existing `topology`'s, or if you're running in development locally then installing `requirements/dev.in` -- Make sure you don't have `kytosd` running with otherwise topology will start writing to MongoDB, and the application could overwrite the data you're trying to insert with this script. -- Make sure MongoDB replica set is up and running. -- Export MongoDB related variables that [db/client.py](../db/client.py) uses, make sure the hosts names can be resolved: - -``` -export MONGO_USERNAME= -export MONGO_PASSWORD= -export MONGO_DBNAME=napps -export MONGO_HOST_SEEDS="mongo1:27017,mongo2:27018,mongo3:27099" -``` - -#### How to use - -- Export these two environment variables, based on where storehouse and kytos are installed, if you're running `amlight/kytos:latest` docker image they should be: - -``` -export STOREHOUSE_NAMESPACES_DIR=/var/tmp/kytos/storehouse/ -export PYTHONPATH=/var/lib/kytos -``` - -- Parametrize the environment variable `CMD` command and execute `storehouse_to_mongo.py` script (the command is passed via an env var to avoid conflicts with `kytosd`, since depending how you set the `PYTHONPATH` it can interfere) - -- The following `CMD` commands are available: - -``` -insert_links_metadata -insert_switches_metadata -insert_interfaces_metadata -insert_topology -load_topology -load_switches_metadata -load_interfaces_metadata -load_links_metadata -``` - -The `load_*` commands are meant to be used to double check what would actually be loaded, so it's encouraged to try out the load command to confirm the data can be loaded properly, and if they are, feel free to use any of the `insert_*` commands, which will rely internally on the load functions to the either insert or update the documents. - -For example, to double check what would be loaded in the topology from storehouse namespace `kytos.topology.status`: - -``` -CMD=load_topology python3 scripts/storehouse_to_mongo.py -``` - -And then, to insert (or update) the entire topology: - -``` -CMD=insert_topology python3 scripts/storehouse_to_mongo.py -``` - -If the topology you're migrating has metadata saved on `kytos.topology.(switches|interfaces|links).metadata` namespaces, you'll also have to run these commands: - -``` -CMD=insert_links_metadata python3 scripts/storehouse_to_mongo.py -CMD=insert_switches_metadata python3 scripts/storehouse_to_mongo.py -CMD=insert_interfaces_metadata python3 scripts/storehouse_to_mongo.py -``` - -
- -

$unset active from DB switches and links collections

- -[`unset_active.py`](./unset_active.py) is a script to `$unset` `active` and certain metadata from `links` and `switches` collections. +[`000_unset_active.py`](./000_unset_active.py) is a script to `$unset` `active` and certain metadata from `links` and `switches` collections. #### Pre-requisites @@ -103,7 +37,7 @@ It's recommended that you run the `"aggregated_*"` commands first, just so you c - Previewing aggregated changes on `links` collection: ``` -❯ CMD=aggregate_unset_links python scripts/unset_active.py +❯ CMD=aggregate_unset_links python scripts/db/2023.1.0/000_unset_active.py Aggregating links $unset active and metadata[last_status_is_active|last_status_change|notified_up_at] {'_id': '4d42dc0852278accac7d9df15418f6d921db160b13d674029a87cef1b5f67f30', 'enabled': True, 'endpoints': [{'id': '00:00:00:00:00:00:00:02:3'}, {'id': '00:00:00:00:00:00:00:03:2'}], 'id': '4d42dc0852278accac7d9df15418f6d921db160b13d674029a87cef1b5f67f30', 'inserted_at': datetime.datetime(2023, 6, 20, 19, 54, 51, 726000), 'metadata': {}, 'updated_at': datetime.datetime(2023, 6, 20, 20, 13, 53, 696000)} {'_id': 'c8b55359990f89a5849813dc348d30e9e1f991bad1dcb7f82112bd35429d9b07', 'enabled': True, 'endpoints': [{'id': '00:00:00:00:00:00:00:01:4'}, {'id': '00:00:00:00:00:00:00:03:3'}], 'id': 'c8b55359990f89a5849813dc348d30e9e1f991bad1dcb7f82112bd35429d9b07', 'inserted_at': datetime.datetime(2023, 6, 20, 19, 54, 51, 730000), 'metadata': {}, 'updated_at': datetime.datetime(2023, 6, 20, 20, 13, 59, 707000)} @@ -113,7 +47,7 @@ Aggregating links $unset active and metadata[last_status_is_active|last_status_c - Running `$unset` to update many on `links` collection: ``` -❯ CMD=unset_links python scripts/unset_active.py +❯ CMD=unset_links python scripts/db/2023.1.0/000_unset_active.py Trying to $unset links 'active' and metadata[last_status_is_active|last_status_change|notified_up_at]... Modified 3 links objects ``` @@ -121,7 +55,7 @@ Modified 3 links objects - Running `$unset` to update many on `links` collection again, but expecting no changes: ``` -❯ CMD=unset_links python scripts/unset_active.py +❯ CMD=unset_links python scripts/db/2023.1.0/000_unset_active.py Trying to $unset links 'active' and metadata[last_status_is_active|last_status_change|notified_up_at]... Modified 0 links objects ``` @@ -129,7 +63,7 @@ Modified 0 links objects - Previewing aggregated changes on `switches` collection: ``` -❯ CMD=aggregate_unset_switches_and_intfs python scripts/unset_active.py +❯ CMD=aggregate_unset_switches_and_intfs python scripts/db/2023.1.0/000_unset_active.py Aggregating switches and interfaces $unset active {'_id': '00:00:00:00:00:00:00:03', 'connection': '127.0.0.1:53680', 'data_path': 's3', 'enabled': True, 'hardware': 'Open vSwitch', 'id': '00:00:00:00:00:00:00:03', 'inserted_at': datetime.datetime(2023, 6, 20, 19, 54, 50, 467000), 'interfaces': [{'id': '00:00:00:00:00:00:00:03:4294967294', 'enabled': True, 'mac': 'c2:9d:dd:f0:f1:4f', 'speed': 0.0, 'port_number': 4294967294, 'name': 's3', 'nni': False, 'lldp': True, 'switch': '00:00:00:00:00:00:00:03', 'link': '', 'link_side': None, 'metadata': {}, 'updated_at': None}, {'id': '00:00:00:00:00:00:00:03:1', 'enabled': True, 'mac': '6a:79:35:c4:9b:a3', 'speed': 1250000000.0, 'port_number': 1, 'name': 's3-eth1', 'nni': False, 'lldp': True, 'switch': '00:00:00:00:00:00:00:03', 'link': '', 'link_side': None, 'metadata': {}, 'updated_at': None}, {'id': '00:00:00:00:00:00:00:03:2', 'enabled': True, 'mac': '2a:db:cc:f6:40:a0', 'speed': 1250000000.0, 'port_number': 2, 'name': 's3-eth2', 'nni': True, 'lldp': True, 'switch': '00:00:00:00:00:00:00:03', 'link': '4d42dc0852278accac7d9df15418f6d921db160b13d674029a87cef1b5f67f30', 'link_side': None, 'metadata': {}, 'updated_at': None}, {'id': '00:00:00:00:00:00:00:03:3', 'enabled': True, 'mac': '86:62:23:d9:7e:06', 'speed': 1250000000.0, 'port_number': 3, 'name': 's3-eth3', 'nni': True, 'lldp': True, 'switch': '00:00:00:00:00:00:00:03', 'link': 'c8b55359990f89a5849813dc348d30e9e1f991bad1dcb7f82112bd35429d9b07', 'link_side': None, 'metadata': {}, 'updated_at': None}], 'manufacturer': 'Nicira, Inc.', 'metadata': {}, 'ofp_version': '0x04', 'serial': 'None', 'software': '3.1.1', 'updated_at': datetime.datetime(2023, 6, 20, 20, 14, 48, 360000)} {'_id': '00:00:00:00:00:00:00:02', 'connection': '127.0.0.1:53696', 'data_path': 's2', 'enabled': True, 'hardware': 'Open vSwitch', 'id': '00:00:00:00:00:00:00:02', 'inserted_at': datetime.datetime(2023, 6, 20, 19, 54, 50, 469000), 'interfaces': [{'id': '00:00:00:00:00:00:00:02:4294967294', 'enabled': True, 'mac': '7e:93:b8:64:eb:47', 'speed': 0.0, 'port_number': 4294967294, 'name': 's2', 'nni': False, 'lldp': True, 'switch': '00:00:00:00:00:00:00:02', 'link': '', 'link_side': None, 'metadata': {}, 'updated_at': None}, {'id': '00:00:00:00:00:00:00:02:1', 'enabled': True, 'mac': '5a:e7:1b:02:f3:c3', 'speed': 1250000000.0, 'port_number': 1, 'name': 's2-eth1', 'nni': False, 'lldp': True, 'switch': '00:00:00:00:00:00:00:02', 'link': '', 'link_side': None, 'metadata': {}, 'updated_at': None}, {'id': '00:00:00:00:00:00:00:02:2', 'enabled': True, 'mac': '32:75:61:02:93:a7', 'speed': 1250000000.0, 'port_number': 2, 'name': 's2-eth2', 'nni': True, 'lldp': True, 'switch': '00:00:00:00:00:00:00:02', 'link': '78282c4d5b579265f04ebadc4405ca1b49628eb1d684bb45e5d0607fa8b713d0', 'link_side': None, 'metadata': {}, 'updated_at': None}, {'id': '00:00:00:00:00:00:00:02:3', 'enabled': True, 'mac': 'ea:a0:51:8a:e5:70', 'speed': 1250000000.0, 'port_number': 3, 'name': 's2-eth3', 'nni': True, 'lldp': True, 'switch': '00:00:00:00:00:00:00:02', 'link': '4d42dc0852278accac7d9df15418f6d921db160b13d674029a87cef1b5f67f30', 'link_side': None, 'metadata': {}, 'updated_at': None}], 'manufacturer': 'Nicira, Inc.', 'metadata': {}, 'ofp_version': '0x04', 'serial': 'None', 'software': '3.1.1', 'updated_at': datetime.datetime(2023, 6, 20, 20, 14, 48, 362000)} @@ -139,7 +73,7 @@ Aggregating switches and interfaces $unset active - Running `$unset` to update many on `switches` collection: ``` -❯ CMD=unset_switches_and_intfs python scripts/unset_active.py +❯ CMD=unset_switches_and_intfs python scripts/db/2023.1.0/000_unset_active.py Trying to $unset switches and interfaces 'active' Modified 3 switches objects ``` @@ -147,155 +81,7 @@ Modified 3 switches objects - Running `$unset` to update many on `switches` collection again, but expecting no changes: ``` -❯ CMD=unset_switches_and_intfs python scripts/unset_active.py +❯ CMD=unset_switches_and_intfs python scripts/db/2023.1.0/000_unset_active.py Trying to $unset switches and interfaces 'active' Modified 0 switches objects ``` - -
- -

Change tag_type from integer to string type

- -[`vlan_pool.py`](./vlan_pool.py) is a script to change ``available_vlans`` to ``available_tags``. Also adding new field ``tag_ranges``. These new fields have the type ``dict[str, list[list[int]]]``. Example - -``` - available_tags = {"vlan": [[1, 299], [301, 4095]]} - tag_ranges = {"vlan": [[1, 4095]]} -``` - -This scripts takes into account UNIs TAG (only integers) values as well. - -#### Pre-requisites - -- There's no additional Python libraries dependencies required, other than installing the existing `topology`'s, or if you're running in development locally then installing `requirements/dev.in` -- Make sure you don't have `kytosd` running with otherwise topology will start writing to MongoDB, and the application could overwrite the data you're trying to insert with this script. -- Make sure MongoDB replica set is up and running. -- Export the following MongnoDB variables accordingly in case your running outside of a container - -``` -export MONGO_USERNAME= -export MONGO_PASSWORD= -export MONGO_DBNAME=napps -export MONGO_HOST_SEEDS="mongo1:27017,mongo2:27018,mongo3:27099" -``` - -#### How to use - -- The following `CMD` commands are available: - -``` -aggregate_outdated_interfaces -update_database -``` - -`aggregate_outdated_interfaces` option is to see how many documents are going to be modified and how many are going to be added. - -``` -CMD=aggregate_outdated_interfaces python3 scripts/vlan_pool.py -``` - -For the documents that are going to be modified, only the maximum and minimum value are going to be shown: - -``` -{'id': '00:00:00:00:00:00:00:01:3', 'max_number': 4095, 'min_number': 2} -``` - -For soon to be added documents, `avoid_tags` set is going to be shown representing the tags that are used and will need to be avoided in `available_tags`: - -``` -{'id': '00:00:00:00:00:00:00:01:1', 'avoid_tags': {200}} -``` - -A `WARNING` is going to be shown if a duplicated `TAG` is detected in different `EVC`s: - -``` -WARNING: Detected duplicated 200 TAG in EVCs 861a11d8fce148 and d74e18464d524b in interface 00:00:00:00:00:00:00:01:1 -``` - -`update_database` updates and adds the required documents for compatability - -``` -CMD=update_database python3 scripts/vlan_pool.py -``` - -The final messages will show how many documents have been modified and added - -``` -6 documents modified. 3 documents inserted -``` - -An `ERROR` can be shown if a duplicated `TAG` is detected in different `EVC`s. After this the pocess will exit without making any modification or adittion. - -``` -Error: Detected duplicated 200 TAG in EVCs 861a11d8fce148 and d74e18464d524b in interface 00:00:00:00:00:00:00:01:1 -``` - -
- -

Add special_available_tags and special_tags field to each Interface document in interface_details collection

- -[`special_vlan_allocation.py`](./special_vlan_allocation.py) is to add the new field ``special_available_tags`` and ``special_tags`` to each interface document. This new field will keep track of special vlan usage: - -``` -special_available_tags = {"vlan": ["untagged"]} -special_tags = {"vlan": ["untagged", "any"]} -``` - -This scripts takes into account UNIs TAG values (only string) as well. - -#### Pre-requisites - -- There's no additional Python libraries dependencies required, other than installing the existing `topology`'s, or if you're running in development locally then installing `requirements/dev.in` -- Make sure you don't have `kytosd` running with otherwise topology will start writing to MongoDB, and the application could overwrite the data you're trying to insert with this script. -- Make sure MongoDB replica set is up and running. -- Export the following MongnoDB variables accordingly in case your running outside of a container - -``` -export MONGO_USERNAME= -export MONGO_PASSWORD= -export MONGO_DBNAME=napps -export MONGO_HOST_SEEDS="mongo1:27017,mongo2:27018,mongo3:27099" -``` - -#### How to use - -- The following `CMD` commands are available: - -``` -aggregate_outdated_interfaces -update_database -``` - -`aggregate_outdated_interfaces` option is to see how many documents are going to be modified and how many are going to be added. - -``` -CMD=aggregate_outdated_interfaces python3 scripts/special_vlan_allocation.py -``` - -For the interfaces that are going to be modified, they are going to be listed: - -``` -There are 13 outdated interface documents which do not have 'special_available_tags' and/or 'special_tags' field: -00:00:00:00:00:00:00:02:3 -``` - -`update_database` updates and adds the required documents for compatability - -``` -CMD=update_database python3 scripts/special_vlan_allocation.py -``` - -The final messages will show how many interfaces have been modified: - -``` -1 interface was/were updated: -00:00:00:00:00:00:00:02:3 -``` - -An `ERROR` can be shown if a duplicated `TAG` is detected in different `EVC`s. After this the pocess will exit without making any modification or adittion. - -``` -Error: Detected duplicated vlan 'any' TAG in EVCs d68eb033688a48 and 861a11d8fce148 in interface 00:00:00:00:00:00:00:01:1 -``` - -
\ No newline at end of file diff --git a/scripts/vlan_pool.py b/scripts/db/2023.2.0/000_vlan_pool.py similarity index 97% rename from scripts/vlan_pool.py rename to scripts/db/2023.2.0/000_vlan_pool.py index c319489..3d1c178 100644 --- a/scripts/vlan_pool.py +++ b/scripts/db/2023.2.0/000_vlan_pool.py @@ -130,8 +130,8 @@ def aggregate_outdated_interfaces(mongo: Mongo): {"$project": { "_id": 0, "id": 1, - "max_number": {"$max": "$available_vlans"}, - "min_number": {"$min": "$available_vlans"}, + "max_number": {"$max": "$available_vlans"}, # MAX deleted in 6.0 + "min_number": {"$min": "$available_vlans"}, # MIN deleted in 6.0 "available_vlans": 1, }} ] diff --git a/scripts/special_vlan_allocation.py b/scripts/db/2023.2.0/001_special_vlan_allocation.py similarity index 100% rename from scripts/special_vlan_allocation.py rename to scripts/db/2023.2.0/001_special_vlan_allocation.py diff --git a/scripts/db/2023.2.0/README.md b/scripts/db/2023.2.0/README.md new file mode 100644 index 0000000..24b981e --- /dev/null +++ b/scripts/db/2023.2.0/README.md @@ -0,0 +1,149 @@ +## `topology` scripts for Kytos version 2023.2.0 + +This folder contains Topology's related scripts: + +

Change tag_type from integer to string type

+ +[`000_vlan_pool.py`](.000_vlan_pool.py) is a script to change ``available_vlans`` to ``available_tags``. Also adding new field ``tag_ranges``. These new fields have the type ``dict[str, list[list[int]]]``. Example + +``` + available_tags = {"vlan": [[1, 299], [301, 4095]]} + tag_ranges = {"vlan": [[1, 4095]]} +``` + +This scripts takes into account UNIs TAG (only integers) values as well. + +#### Pre-requisites + +- There's no additional Python libraries dependencies required, other than installing the existing `topology`'s, or if you're running in development locally then installing `requirements/dev.in` +- Make sure you don't have `kytosd` running with otherwise topology will start writing to MongoDB, and the application could overwrite the data you're trying to insert with this script. +- Make sure MongoDB replica set is up and running. +- Export the following MongnoDB variables accordingly in case your running outside of a container + +``` +export MONGO_USERNAME= +export MONGO_PASSWORD= +export MONGO_DBNAME=napps +export MONGO_HOST_SEEDS="mongo1:27017,mongo2:27018,mongo3:27099" +``` + +#### How to use + +- The following `CMD` commands are available: + +``` +aggregate_outdated_interfaces +update_database +``` + +`aggregate_outdated_interfaces` option is to see how many documents are going to be modified and how many are going to be added. + +``` +CMD=aggregate_outdated_interfaces python3 scripts/db/2023.2.0/000_vlan_pool.py +``` + +For the documents that are going to be modified, only the maximum and minimum value are going to be shown: + +``` +{'id': '00:00:00:00:00:00:00:01:3', 'max_number': 4095, 'min_number': 2} +``` + +For soon to be added documents, `avoid_tags` set is going to be shown representing the tags that are used and will need to be avoided in `available_tags`: + +``` +{'id': '00:00:00:00:00:00:00:01:1', 'avoid_tags': {200}} +``` + +A `WARNING` is going to be shown if a duplicated `TAG` is detected in different `EVC`s: + +``` +WARNING: Detected duplicated 200 TAG in EVCs 861a11d8fce148 and d74e18464d524b in interface 00:00:00:00:00:00:00:01:1 +``` + +`update_database` updates and adds the required documents for compatability + +``` +CMD=update_database python3 scripts/db/2023.2.0/000_vlan_pool.py +``` + +The final messages will show how many documents have been modified and added + +``` +6 documents modified. 3 documents inserted +``` + +An `ERROR` can be shown if a duplicated `TAG` is detected in different `EVC`s. After this the pocess will exit without making any modification or adittion. + +``` +Error: Detected duplicated 200 TAG in EVCs 861a11d8fce148 and d74e18464d524b in interface 00:00:00:00:00:00:00:01:1 +``` + +
+ +

Add special_available_tags and special_tags field to each Interface document in interface_details collection

+ +[`001_special_vlan_allocation.py`](./001_special_vlan_allocation.py) is to add the new field ``special_available_tags`` and ``special_tags`` to each interface document. This new field will keep track of special vlan usage: + +``` +special_available_tags = {"vlan": ["untagged"]} +special_tags = {"vlan": ["untagged", "any"]} +``` + +This scripts takes into account UNIs TAG values (only string) as well. + +#### Pre-requisites + +- There's no additional Python libraries dependencies required, other than installing the existing `topology`'s, or if you're running in development locally then installing `requirements/dev.in` +- Make sure you don't have `kytosd` running with otherwise topology will start writing to MongoDB, and the application could overwrite the data you're trying to insert with this script. +- Make sure MongoDB replica set is up and running. +- Export the following MongnoDB variables accordingly in case your running outside of a container + +``` +export MONGO_USERNAME= +export MONGO_PASSWORD= +export MONGO_DBNAME=napps +export MONGO_HOST_SEEDS="mongo1:27017,mongo2:27018,mongo3:27099" +``` + +#### How to use + +- The following `CMD` commands are available: + +``` +aggregate_outdated_interfaces +update_database +``` + +`aggregate_outdated_interfaces` option is to see how many documents are going to be modified and how many are going to be added. + +``` +CMD=aggregate_outdated_interfaces python3 scripts/db/2023.2.0/001_special_vlan_allocation.py +``` + +For the interfaces that are going to be modified, they are going to be listed: + +``` +There are 13 outdated interface documents which do not have 'special_available_tags' and/or 'special_tags' field: +00:00:00:00:00:00:00:02:3 +``` + +`update_database` updates and adds the required documents for compatability + +``` +CMD=update_database python3 scripts/db/2023.2.0/001_special_vlan_allocation.py +``` + +The final messages will show how many interfaces have been modified: + +``` +1 interface was/were updated: +00:00:00:00:00:00:00:02:3 +``` + +An `ERROR` can be shown if a duplicated `TAG` is detected in different `EVC`s. After this the pocess will exit without making any modification or adittion. + +``` +Error: Detected duplicated vlan 'any' TAG in EVCs d68eb033688a48 and 861a11d8fce148 in interface 00:00:00:00:00:00:00:01:1 +``` + +
\ No newline at end of file From 4fe2497962d7fddb95d00533d50f0c8a2fc415da Mon Sep 17 00:00:00 2001 From: Vinicius Arcanjo Date: Mon, 6 May 2024 12:14:40 -0300 Subject: [PATCH 2/2] Update scripts/db/2023.2.0/README.md --- scripts/db/2023.2.0/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scripts/db/2023.2.0/README.md b/scripts/db/2023.2.0/README.md index 24b981e..16f0791 100644 --- a/scripts/db/2023.2.0/README.md +++ b/scripts/db/2023.2.0/README.md @@ -4,7 +4,7 @@ This folder contains Topology's related scripts:

Change tag_type from integer to string type

-[`000_vlan_pool.py`](.000_vlan_pool.py) is a script to change ``available_vlans`` to ``available_tags``. Also adding new field ``tag_ranges``. These new fields have the type ``dict[str, list[list[int]]]``. Example +[`000_vlan_pool.py`](./000_vlan_pool.py) is a script to change ``available_vlans`` to ``available_tags``. Also adding new field ``tag_ranges``. These new fields have the type ``dict[str, list[list[int]]]``. Example ``` available_tags = {"vlan": [[1, 299], [301, 4095]]}