mirror of
				https://github.com/CumulusNetworks/ifupdown2.git
				synced 2024-05-06 15:54:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			134 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			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)
 |