| 1 | |
|---|
| 2 | |
|---|
| 3 | |
|---|
| 4 | |
|---|
| 5 | |
|---|
| 6 | |
|---|
| 7 | |
|---|
| 8 | |
|---|
| 9 | |
|---|
| 10 | |
|---|
| 11 | |
|---|
| 12 | |
|---|
| 13 | |
|---|
| 14 | |
|---|
| 15 | |
|---|
| 16 | |
|---|
| 17 | |
|---|
| 18 | |
|---|
| 19 | |
|---|
| 20 | |
|---|
| 21 | |
|---|
| 22 | import sys, os, syslog, signal |
|---|
| 23 | import gdhost.server as server |
|---|
| 24 | import gdhost.daemon as daemon |
|---|
| 25 | from gdhost.version import version_string |
|---|
| 26 | |
|---|
| 27 | |
|---|
| 28 | if sys.version_info >= (2, 2) and \ |
|---|
| 29 | sys.version_info < (2,3): |
|---|
| 30 | try: |
|---|
| 31 | import optik as optparse |
|---|
| 32 | except ImportError: |
|---|
| 33 | try: |
|---|
| 34 | import optparse |
|---|
| 35 | except ImportError: |
|---|
| 36 | print >> sys.stderr, "You must either install optik (http://optik.sf.net) or upgrade to python 2.3" |
|---|
| 37 | elif sys.version_info >= (2,3): |
|---|
| 38 | import optparse |
|---|
| 39 | else: |
|---|
| 40 | print >> sys.stderr, "This program requires python 2.2 with the optik module (http://optik.sf.net) or python 2.3 or greater" |
|---|
| 41 | sys.exit(1) |
|---|
| 42 | |
|---|
| 43 | parser = optparse.OptionParser(version=version_string, |
|---|
| 44 | usage="%prog [options] command") |
|---|
| 45 | parser.add_option( '-d', '--debug', action="store_true", |
|---|
| 46 | dest="debug", default=False, |
|---|
| 47 | help="Turn on debugging" ) |
|---|
| 48 | parser.add_option('-D', '--daemon', action="store_true", |
|---|
| 49 | dest="daemon", default=False, |
|---|
| 50 | help="Fork off a daemon" ) |
|---|
| 51 | parser.add_option('-c', '--config', action="store", |
|---|
| 52 | dest="config", default="/etc/gdhost/config", |
|---|
| 53 | help="Configuration File" ) |
|---|
| 54 | parser.add_option( '-S', '--syslog', action="store_true", |
|---|
| 55 | dest="syslog", default=False, |
|---|
| 56 | help="Use Syslog to log events. This is forced to true if you run as a daemon." ) |
|---|
| 57 | |
|---|
| 58 | if '__main__' == __name__: |
|---|
| 59 | options, commands = parser.parse_args() |
|---|
| 60 | progname = os.path.basename(sys.argv[0]) |
|---|
| 61 | |
|---|
| 62 | if not os.path.exists(options.config): |
|---|
| 63 | print >> sys.stderr, "The configuration file doesn't exist: %s" % options.config |
|---|
| 64 | sys.exit(10) |
|---|
| 65 | |
|---|
| 66 | if options.daemon: |
|---|
| 67 | retCode = deamon.createDaemon() |
|---|
| 68 | |
|---|
| 69 | if options.daemon or options.syslog: |
|---|
| 70 | def log_info(msg, pri = syslog.LOG_INFO): |
|---|
| 71 | syslog.openlog('%s[%d]' % ( progname, |
|---|
| 72 | os.getpid()), 0, syslog.LOG_DAEMON) |
|---|
| 73 | syslog.syslog(pri, msg) |
|---|
| 74 | syslog.closelog() |
|---|
| 75 | else: |
|---|
| 76 | def log_info( msg ): |
|---|
| 77 | sys.stdout.write( msg ) |
|---|
| 78 | if not msg.endswith('\n'): |
|---|
| 79 | sys.stdout.write( '\n' ) |
|---|
| 80 | |
|---|
| 81 | server = server.Server(options.config, |
|---|
| 82 | log_info, |
|---|
| 83 | debug=options.debug) |
|---|
| 84 | |
|---|
| 85 | def exitServer(signum = None, frame = None): |
|---|
| 86 | "Quit nicely on the correct signal" |
|---|
| 87 | server.log( "...Shutting down" ) |
|---|
| 88 | sys.exit(0) |
|---|
| 89 | |
|---|
| 90 | server.log( "Starting..." ) |
|---|
| 91 | signal.signal(signal.SIGHUP, server.reconfig) |
|---|
| 92 | signal.signal(signal.SIGINT, exitServer) |
|---|
| 93 | signal.signal(signal.SIGTERM, exitServer) |
|---|
| 94 | |
|---|
| 95 | server.serve_forever() |
|---|