1
0
mirror of https://github.com/CumulusNetworks/ifupdown2.git synced 2024-05-06 15:54:50 +00:00
Files
CumulusNetworks-ifupdown2/ifupdown2/addons/usercmds.py
Alex Hermann ac645a1a82 addons: usercmds: Set environment just like the original ifupdown
The original ifupdown sets all interface options as IF_<option> environment
variable. Duplicate that behavior for compatibility.
2021-04-20 18:42:40 +02:00

106 lines
4.0 KiB
Python

#!/usr/bin/env python3
#
# Copyright 2014-2017 Cumulus Networks, Inc. All rights reserved.
# Author: Roopa Prabhu, roopa@cumulusnetworks.com
#
import os
try:
from ifupdown2.ifupdown.utils import utils
from ifupdown2.ifupdownaddons.modulebase import moduleBase
except (ImportError, ModuleNotFoundError):
from ifupdown.utils import utils
from ifupdownaddons.modulebase import moduleBase
class usercmds(moduleBase):
""" ifupdown2 addon module to configure user specified commands """
_modinfo = {'mhelp' : 'user commands for interfaces',
'attrs' : {
'pre-up' :
{'help' : 'run command before bringing the interface up',
'multiline' : True},
'up' :
{'help' : 'run command at interface bring up',
'multiline' : True},
'post-up' :
{'help' : 'run command after interface bring up',
'multiline' : True},
'pre-down' :
{'help' : 'run command before bringing the interface down',
'multiline' : True},
'down' :
{'help' : 'run command at interface down',
'multiline' : True},
'post-down' :
{'help' : 'run command after bringing interface down',
'multiline' : True}}}
def _run_command(self, ifaceobj, op):
cmd_list = ifaceobj.get_attr_value(op)
if cmd_list:
env = os.environ | {
'LOGICAL': ifaceobj.name if ifaceobj.name else '',
'METHOD': ifaceobj.addr_method if ifaceobj.addr_method else '',
'ADDRFAM': ','.join(ifaceobj.addr_family) if ifaceobj.addr_family else ''
} | ifaceobj.get_env()
for cmd in cmd_list:
try:
utils.exec_user_command(cmd, env=env)
except Exception as e:
if not self.ignore_error(str(e)):
self.logger.warning('%s: %s %s' % (ifaceobj.name, op,
str(e).strip('\n')))
pass
def _query_check(self, ifaceobj, ifaceobjcurr):
if ifaceobj.config:
for ops in ['pre-up',
'up',
'post-up',
'pre-down',
'down',
'post-down']:
for cmd in ifaceobj.config.get(ops, []):
ifaceobjcurr.update_config_with_status(ops, cmd, -1)
_run_ops = {'pre-up' : _run_command,
'pre-down' : _run_command,
'up' : _run_command,
'post-up' : _run_command,
'down' : _run_command,
'post-down' : _run_command,
'query-checkcurr': _query_check}
def get_ops(self):
""" returns list of ops supported by this module """
return list(self._run_ops.keys())
def run(self, ifaceobj, operation, query_ifaceobj=None, **extra_args):
""" run user commands
Args:
**ifaceobj** (object): iface object
**operation** (str): list of ops
Kwargs:
**query_ifaceobj** (object): query check ifaceobject. This is only
valid when op is 'query-checkcurr'. It is an object same as
ifaceobj, but contains running attribute values and its config
status. The modules can use it to return queried running state
of interfaces. status is success if the running state is same
as user required state in ifaceobj. error otherwise.
"""
op_handler = self._run_ops.get(operation)
if not op_handler:
return
if operation == 'query-checkcurr':
op_handler(self, ifaceobj, query_ifaceobj)
else:
op_handler(self, ifaceobj, operation)