Skip to content

Commit

Permalink
T6199: remove unused Python imports from migration scripts
Browse files Browse the repository at this point in the history
(cherry picked from commit 489e6fa)

# Conflicts:
#	src/migration-scripts/dhcp-server/9-to-10
#	src/migration-scripts/dhcpv6-server/3-to-4
  • Loading branch information
c-po authored and mergify[bot] committed Apr 6, 2024
1 parent 66428fb commit 0a129c3
Show file tree
Hide file tree
Showing 51 changed files with 212 additions and 163 deletions.
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ LIBS := -lzmq
CFLAGS :=
BUILD_ARCH := $(shell dpkg-architecture -q DEB_BUILD_ARCH)
J2LINT := $(shell command -v j2lint 2> /dev/null)
PYLINT_FILES := $(shell git ls-files *.py)
PYLINT_FILES := $(shell git ls-files *.py src/migration-scripts)

config_xml_src = $(wildcard interface-definitions/*.xml.in)
config_xml_obj = $(config_xml_src:.xml.in=.xml)
Expand Down
1 change: 0 additions & 1 deletion src/migration-scripts/conntrack/2-to-3
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
import sys

from vyos.configtree import ConfigTree
from vyos.version import get_version

if len(sys.argv) < 2:
print('Must specify file name!')
Expand Down
74 changes: 74 additions & 0 deletions src/migration-scripts/dhcp-server/9-to-10
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
#!/usr/bin/env python3
#
# Copyright (C) 2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.

# T3316:
# - Migrate dhcp options under new option node
# - Add subnet IDs to existing subnets

import sys
from vyos.configtree import ConfigTree

if len(sys.argv) < 2:
print("Must specify file name!")
sys.exit(1)

file_name = sys.argv[1]

with open(file_name, 'r') as f:
config_file = f.read()

base = ['service', 'dhcp-server', 'shared-network-name']
config = ConfigTree(config_file)

if not config.exists(base):
# Nothing to do
sys.exit(0)

option_nodes = ['bootfile-name', 'bootfile-server', 'bootfile-size', 'captive-portal',
'client-prefix-length', 'default-router', 'domain-name', 'domain-search',
'name-server', 'ip-forwarding', 'ipv6-only-preferred', 'ntp-server',
'pop-server', 'server-identifier', 'smtp-server', 'static-route',
'tftp-server-name', 'time-offset', 'time-server', 'time-zone',
'vendor-option', 'wins-server', 'wpad-url']

subnet_id = 1

for network in config.list_nodes(base):
for option in option_nodes:
if config.exists(base + [network, option]):
config.set(base + [network, 'option'])
config.copy(base + [network, option], base + [network, 'option', option])
config.delete(base + [network, option])

if config.exists(base + [network, 'subnet']):
for subnet in config.list_nodes(base + [network, 'subnet']):
base_subnet = base + [network, 'subnet', subnet]

for option in option_nodes:
if config.exists(base_subnet + [option]):
config.set(base_subnet + ['option'])
config.copy(base_subnet + [option], base_subnet + ['option', option])
config.delete(base_subnet + [option])

config.set(base_subnet + ['subnet-id'], value=subnet_id)
subnet_id += 1

try:
with open(file_name, 'w') as f:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
89 changes: 89 additions & 0 deletions src/migration-scripts/dhcpv6-server/3-to-4
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
#!/usr/bin/env python3
#
# Copyright (C) 2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.

# T3316:
# - Add subnet IDs to existing subnets
# - Move options to option node
# - Migrate address-range to range tagNode

import sys
from vyos.configtree import ConfigTree

if len(sys.argv) < 2:
print("Must specify file name!")
sys.exit(1)

file_name = sys.argv[1]

with open(file_name, 'r') as f:
config_file = f.read()

base = ['service', 'dhcpv6-server', 'shared-network-name']
config = ConfigTree(config_file)

if not config.exists(base):
# Nothing to do
sys.exit(0)

option_nodes = ['captive-portal', 'domain-search', 'name-server',
'nis-domain', 'nis-server', 'nisplus-domain', 'nisplus-server',
'sip-server', 'sntp-server', 'vendor-option']

subnet_id = 1

for network in config.list_nodes(base):
if config.exists(base + [network, 'subnet']):
for subnet in config.list_nodes(base + [network, 'subnet']):
base_subnet = base + [network, 'subnet', subnet]

if config.exists(base_subnet + ['address-range']):
config.set(base_subnet + ['range'])
config.set_tag(base_subnet + ['range'])

range_id = 1

if config.exists(base_subnet + ['address-range', 'prefix']):
for prefix in config.return_values(base_subnet + ['address-range', 'prefix']):
config.set(base_subnet + ['range', range_id, 'prefix'], value=prefix)

range_id += 1

if config.exists(base_subnet + ['address-range', 'start']):
for start in config.list_nodes(base_subnet + ['address-range', 'start']):
stop = config.return_value(base_subnet + ['address-range', 'start', start, 'stop'])

config.set(base_subnet + ['range', range_id, 'start'], value=start)
config.set(base_subnet + ['range', range_id, 'stop'], value=stop)

range_id += 1

config.delete(base_subnet + ['address-range'])

for option in option_nodes:
if config.exists(base_subnet + [option]):
config.set(base_subnet + ['option'])
config.copy(base_subnet + [option], base_subnet + ['option', option])
config.delete(base_subnet + [option])

config.set(base_subnet + ['subnet-id'], value=subnet_id)
subnet_id += 1

try:
with open(file_name, 'w') as f:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
13 changes: 5 additions & 8 deletions src/migration-scripts/firewall/10-to-11
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env python3
#
# Copyright (C) 2023 VyOS maintainers and contributors
# Copyright (C) 2023-2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
Expand All @@ -16,12 +16,12 @@

# T5160: Firewall re-writing

# cli changes from:
# cli changes from:
# set firewall name <name> ...
# set firewall ipv6-name <name> ...
# To
# set firewall ipv4 name <name>
# set firewall ipv6 name <name>
# set firewall ipv4 name <name>
# set firewall ipv6 name <name>

## Also from 'firewall interface' removed.
## in and out:
Expand All @@ -37,13 +37,10 @@
# set firewall [ipv4 | ipv6] input filter rule <5,10,15,...> action jump
# set firewall [ipv4 | ipv6] input filter rule <5,10,15,...> jump-target <name>

import re

from sys import argv
from sys import exit

from vyos.configtree import ConfigTree
from vyos.ifconfig import Section

if len(argv) < 2:
print("Must specify file name!")
Expand Down Expand Up @@ -207,4 +204,4 @@ try:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
exit(1)
7 changes: 2 additions & 5 deletions src/migration-scripts/firewall/11-to-12
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env python3
#
# Copyright (C) 2023 VyOS maintainers and contributors
# Copyright (C) 2023-2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
Expand All @@ -22,13 +22,10 @@
# set firewall ... rule <rule> [inbound-interface | outboubd-interface] name <iface>
# set firewall ... rule <rule> [inbound-interface | outboubd-interface] group <iface_group>

import re

from sys import argv
from sys import exit

from vyos.configtree import ConfigTree
from vyos.ifconfig import Section

if len(argv) < 2:
print("Must specify file name!")
Expand Down Expand Up @@ -71,4 +68,4 @@ try:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
exit(1)
7 changes: 2 additions & 5 deletions src/migration-scripts/firewall/12-to-13
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env python3
#
# Copyright (C) 2023 VyOS maintainers and contributors
# Copyright (C) 2023-2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
Expand All @@ -25,13 +25,10 @@
# set firewall ... rule <rule> state <state>
# Remove command if log=disable or <state>=disable

import re

from sys import argv
from sys import exit

from vyos.configtree import ConfigTree
from vyos.ifconfig import Section

if len(argv) < 2:
print("Must specify file name!")
Expand Down Expand Up @@ -89,4 +86,4 @@ try:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
exit(1)
5 changes: 1 addition & 4 deletions src/migration-scripts/firewall/7-to-8
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env python3
#
# Copyright (C) 2022 VyOS maintainers and contributors
# Copyright (C) 2022-2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
Expand All @@ -17,13 +17,10 @@
# T2199: Migrate interface firewall nodes to firewall interfaces <ifname> <direction> name/ipv6-name <name>
# T2199: Migrate zone-policy to firewall node

import re

from sys import argv
from sys import exit

from vyos.configtree import ConfigTree
from vyos.ifconfig import Section

if len(argv) < 2:
print("Must specify file name!")
Expand Down
9 changes: 3 additions & 6 deletions src/migration-scripts/firewall/8-to-9
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env python3
#
# Copyright (C) 2022 VyOS maintainers and contributors
# Copyright (C) 2022-2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
Expand All @@ -15,18 +15,15 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>.

# T4780: Add firewall interface group
# cli changes from:
# cli changes from:
# set firewall [name | ipv6-name] <name> rule <number> [inbound-interface | outbound-interface] <interface_name>
# To
# set firewall [name | ipv6-name] <name> rule <number> [inbound-interface | outbound-interface] [interface-name | interface-group] <interface_name | interface_group>

import re

from sys import argv
from sys import exit

from vyos.configtree import ConfigTree
from vyos.ifconfig import Section

if len(argv) < 2:
print("Must specify file name!")
Expand Down Expand Up @@ -88,4 +85,4 @@ try:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
exit(1)
13 changes: 5 additions & 8 deletions src/migration-scripts/firewall/9-to-10
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env python3
#
# Copyright (C) 2023 VyOS maintainers and contributors
# Copyright (C) 2023-2024 VyOS maintainers and contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or later as
Expand All @@ -15,18 +15,15 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>.

# T5050: Log options
# cli changes from:
# cli changes from:
# set firewall [name | ipv6-name] <name> rule <number> log-level <log_level>
# To
# set firewall [name | ipv6-name] <name> rule <number> log-options level <log_level>

import re

from sys import argv
from sys import exit

from vyos.configtree import ConfigTree
from vyos.ifconfig import Section

if len(argv) < 2:
print("Must specify file name!")
Expand All @@ -50,7 +47,7 @@ if config.exists(base + ['name']):
continue

for rule in config.list_nodes(base + ['name', name, 'rule']):
log_options_base = base + ['name', name, 'rule', rule, 'log-options']
log_options_base = base + ['name', name, 'rule', rule, 'log-options']
rule_log_level = base + ['name', name, 'rule', rule, 'log-level']

if config.exists(rule_log_level):
Expand All @@ -64,7 +61,7 @@ if config.exists(base + ['ipv6-name']):
continue

for rule in config.list_nodes(base + ['ipv6-name', name, 'rule']):
log_options_base = base + ['ipv6-name', name, 'rule', rule, 'log-options']
log_options_base = base + ['ipv6-name', name, 'rule', rule, 'log-options']
rule_log_level = base + ['ipv6-name', name, 'rule', rule, 'log-level']

if config.exists(rule_log_level):
Expand All @@ -77,4 +74,4 @@ try:
f.write(config.to_string())
except OSError as e:
print("Failed to save the modified config: {}".format(e))
exit(1)
exit(1)
Loading

0 comments on commit 0a129c3

Please sign in to comment.