diff options
author | Christian Poessinger <christian@poessinger.com> | 2020-03-19 20:04:53 +0100 |
---|---|---|
committer | Christian Poessinger <christian@poessinger.com> | 2020-03-28 20:48:32 +0100 |
commit | 65f0c6bf68f4f903d8011d0083385aa0f3c280ce (patch) | |
tree | 25c9025e9c5fb2bad314d20795427dbed45babf6 | |
parent | ced45949bc282d23b0767f698f31b580602f0c9c (diff) | |
download | vyos-1x-65f0c6bf68f4f903d8011d0083385aa0f3c280ce.tar.gz vyos-1x-65f0c6bf68f4f903d8011d0083385aa0f3c280ce.zip |
wwan: T1988: support interface disable
-rw-r--r-- | interface-definitions/interfaces-wirelessmodem.xml.in | 18 | ||||
-rwxr-xr-x | src/conf_mode/interfaces-wirelessmodem.py | 45 | ||||
-rwxr-xr-x | src/migration-scripts/interfaces/6-to-7 | 63 |
3 files changed, 109 insertions, 17 deletions
diff --git a/interface-definitions/interfaces-wirelessmodem.xml.in b/interface-definitions/interfaces-wirelessmodem.xml.in index e8946fa68..81efbdb54 100644 --- a/interface-definitions/interfaces-wirelessmodem.xml.in +++ b/interface-definitions/interfaces-wirelessmodem.xml.in @@ -16,6 +16,11 @@ </valueHelp> </properties> <children> + <leafNode name="apn"> + <properties> + <help>Access Point Name (APN)</help> + </properties> + </leafNode> <node name="backup"> <properties> <help>Insert backup default route</help> @@ -37,26 +42,19 @@ </children> </node> #include <include/interface-description.xml.i> + #include <include/interface-disable.xml.i> <leafNode name="device"> <properties> <help>System device name (default: ttyUSB0)</help> <valueHelp> - <format>>ttyXXX%lt;</format> + <format>ttyXXX</format> <description>System TTY device name</description> </valueHelp> </properties> </leafNode> #include <include/interface-disable-link-detect.xml.i> #include <include/interface-mtu-68-9000.xml.i> - <leafNode name="network"> - <properties> - <help>Carrier network to define dial strings</help> - <completionHelp> - <script>ls /etc/ppp/peers/chat</script> - </completionHelp> - </properties> - </leafNode> - <leafNode name="no-dns"> + <leafNode name="no-peer-dns"> <properties> <help>Do not use peer supplied DNS server information</help> <valueless/> diff --git a/src/conf_mode/interfaces-wirelessmodem.py b/src/conf_mode/interfaces-wirelessmodem.py index 93f60d038..adb8bdc2d 100755 --- a/src/conf_mode/interfaces-wirelessmodem.py +++ b/src/conf_mode/interfaces-wirelessmodem.py @@ -36,6 +36,8 @@ config_wwan_tmpl = """### Autogenerated by interfaces-wirelessmodem.py ### /dev/{{ device }} ipparam {{ intf }} {{ metric }} +ifname {{ intf }} +linkname {{ intf }} {% if on_demand -%} demand {%- endif %} @@ -43,7 +45,7 @@ demand usepeerdns {%- endif %} logfile {{ logfile }} -linkname {{ intf }} + lcp-echo-failure 0 115200 debug @@ -56,11 +58,24 @@ crtscts lock persist +connect '/usr/sbin/chat -v -t6 -f /etc/ppp/peers/{{ intf }}.chat' + +""" + +# Please be careful if you edit the template. +chat_wwan_tmpl = """ +ABORT 'NO DIAL TONE' ABORT 'NO ANSWER' ABORT 'NO CARRIER' ABORT DELAYED +'' AT +OK ATZ +OK 'AT+CGDCONT=1,"IP","{{ apn }}"' +OK ATD*99# +CONNECT '' """ default_config_data = { 'address': [], + 'apn': '', 'deleted': False, 'description': '', 'device': 'ttyUSB0', @@ -71,7 +86,6 @@ default_config_data = { 'metric': '10', 'mtu': '1500', 'name_server': True, - 'network': 'att', 'intf': '' } @@ -106,6 +120,10 @@ def get_config(): conf.set_level('interfaces wirelessmodem ' + wwan['intf']) # get metrick for backup default route + if conf.exists(['apn']): + wwan['apn'] = conf.return_value(['apn']) + + # get metrick for backup default route if conf.exists(['backup', 'distance']): wwan['metric'] = conf.return_value(['backup', 'distance']) @@ -117,6 +135,10 @@ def get_config(): if conf.exists(['device']): wwan['device'] = conf.return_value(['device']) + # disable interface + if conf.exists('disable'): + wwan['disable'] = True + # ignore link state changes if conf.exists('disable-link-detect'): wwan['disable_link_detect'] = 2 @@ -126,11 +148,7 @@ def get_config(): wwan['mtu'] = conf.return_value(['mtu']) # Do not use DNS servers provided by the peer - if conf.exists(['network']): - wwan['network'] = conf.return_value(['network']) - - # Do not use DNS servers provided by the peer - if conf.exists(['no-dns']): + if conf.exists(['no-peer-dns']): wwan['name_server'] = False # Access concentrator name (only connect to this concentrator) @@ -143,6 +161,9 @@ def verify(wwan): if wwan['deleted']: return None + if not wwan['apn']: + raise ConfigError(f"APN for {wwan['intf']} not configured") + # we can not use isfile() here as Linux device files are no regular files # thus the check will return False if not os.path.exists(f"/dev/{wwan['device']}"): @@ -152,6 +173,7 @@ def verify(wwan): def generate(wwan): config_file_wwan = f"/etc/ppp/peers/{wwan['intf']}" + chat_file_wwan = f"/etc/ppp/peers/{wwan['intf']}.chat" # Always hang-up WWAN connection prior generating new configuration file cmd = f"systemctl stop ppp@{wwan['intf']}.service" @@ -161,6 +183,8 @@ def generate(wwan): # Delete PPP configuration files if os.path.exists(config_file_wwan): os.unlink(config_file_wwan) + if os.path.exists(chat_file_wwan): + os.unlink(chat_file_wwan) else: # Create PPP configuration files @@ -169,6 +193,13 @@ def generate(wwan): with open(config_file_wwan, 'w') as f: f.write(config_text) + + # Create PPP chat script + tmpl = Template(chat_wwan_tmpl) + config_text = tmpl.render(wwan) + with open(chat_file_wwan, 'w') as f: + f.write(config_text) + return None def apply(wwan): diff --git a/src/migration-scripts/interfaces/6-to-7 b/src/migration-scripts/interfaces/6-to-7 new file mode 100755 index 000000000..b4f59c363 --- /dev/null +++ b/src/migration-scripts/interfaces/6-to-7 @@ -0,0 +1,63 @@ +#!/usr/bin/env python3 +# +# Copyright (C) 2020 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/>. + +# Remove network provider name from CLI and rather use provider APN from CLI + +import sys +from vyos.configtree import ConfigTree + +if __name__ == '__main__': + if (len(sys.argv) < 1): + print("Must specify file name!") + exit(1) + + file_name = sys.argv[1] + with open(file_name, 'r') as f: + config_file = f.read() + + config = ConfigTree(config_file) + base = ['interfaces', 'wirelessmodem'] + + if not config.exists(base): + # Nothing to do + sys.exit(0) + + # list all individual interface types like dummy, ethernet and so on + for i in config.list_nodes(base): + iface = base + [i] + + # only three carries have been supported in the past, thus + # this will be fairly simple \o/ - and only one (AT&T) did + # configure an APN + if config.exists(iface + ['network']): + network = config.return_value(iface + ['network']) + if network == "att": + apn = 'isp.cingular' + config.set(iface + ['apn'], value=apn) + + config.delete(iface + ['network']) + + # synchronize DNS configuration with PPPoE interfaces to have a + # uniform CLI experience + if config.exists(iface + ['no-dns']): + config.rename(iface + ['no-dns'], 'no-peer-dns') + + 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)) + sys.exit(1) |