1
0
mirror of https://github.com/CumulusNetworks/ifupdown2.git synced 2024-05-06 15:54:50 +00:00
Julien Fortin 3218f49d81 use "except Exception:" instead of "except:"
Signed-off-by: Julien Fortin <julien@cumulusnetworks.com>
2020-06-24 01:12:24 +02:00

134 lines
4.2 KiB
Python
Executable File

#!/usr/bin/env python3
# Copyright (C) 2016, 2017, 2018, 2019 Cumulus Networks, Inc. all rights reserved
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation; version 2.
#
# 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, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA.
#
# https://www.gnu.org/licenses/gpl-2.0-standalone.html
#
# Author:
# Julien Fortin, julien@cumulusnetworks.com
#
# ifupdown2 - Network Manager
#
import os
import sys
try:
from ifupdown2.lib.log import LogManager, root_logger
from ifupdown2.lib.status import Status
except Exception:
from lib.log import LogManager, root_logger
from lib.status import Status
# first thing first, setup the logging infra
LogManager.get_instance()
try:
import ifupdown2.ifupdown.config as config
from ifupdown2 import __version__
config.__version__ = __version__
from ifupdown2.lib.exceptions import ExitWithStatus, ExitWithStatusAndError
from ifupdown2.ifupdown.client import Client
from ifupdown2.ifupdown.exceptions import ArgvParseHelp, ArgvParseError
except Exception:
import ifupdown.config as config
config.__version__ = __import__("__init__").__version__
from lib.exceptions import ExitWithStatus, ExitWithStatusAndError
from ifupdown.client import Client
from ifupdown.exceptions import ArgvParseHelp, ArgvParseError
def daemon_mode():
""" Check ifupdown2 config to see if we should start the client """
try:
with open(config.IFUPDOWN2_CONF_PATH) as f:
return "use_daemon=yes" in f.read()
except Exception:
return False
def client():
try:
status = Client(sys.argv).run()
except ExitWithStatusAndError as e:
root_logger.error(e.message)
status = e.status
except ExitWithStatus as e:
status = e.status
return status
def stand_alone():
if not sys.argv[0].endswith("query") and os.geteuid() != 0:
sys.stderr.write('must be root to run this command\n')
return 1
try:
from ifupdown2.ifupdown.main import Ifupdown2
from ifupdown2.lib.nlcache import NetlinkListenerWithCache, NetlinkListenerWithCacheErrorNotInitialized
except Exception:
from ifupdown.main import Ifupdown2
from lib.nlcache import NetlinkListenerWithCache, NetlinkListenerWithCacheErrorNotInitialized
ifupdown2 = Ifupdown2(daemon=False, uid=os.geteuid())
try:
ifupdown2.parse_argv(sys.argv)
LogManager.get_instance().start_standalone_logging(ifupdown2.args)
except ArgvParseError as e:
LogManager.get_instance().root_logger().error(str(e))
return Status.Client.STATUS_ARGV_ERROR
except ArgvParseHelp:
# on --help parse_args raises SystemExit, we catch it and raise a
# custom exception ArgvParseHelp to return 0
return 0
try:
status = ifupdown2.main()
finally:
try:
if NetlinkListenerWithCache.is_init():
NetlinkListenerWithCache.get_instance().cleanup()
except NetlinkListenerWithCacheErrorNotInitialized:
status = Status.Client.STATUS_NLERROR
LogManager.get_instance().write("exit status %s" % status)
return status
def main():
try:
if daemon_mode():
return client()
else:
return stand_alone()
except ArgvParseHelp:
return Status.Client.STATUS_SUCCESS
except KeyboardInterrupt:
return Status.Client.STATUS_KEYBOARD_INTERRUPT
except Exception as e:
root_logger.exception("main: %s" % str(e))
return Status.Client.STATUS_EXCEPTION_MAIN
if __name__ == '__main__':
try:
sys.exit(main())
except KeyboardInterrupt:
sys.exit(Status.Client.STATUS_KEYBOARD_INTERRUPT)