ZeroNet/zeronet.py

92 lines
2.8 KiB
Python
Raw Normal View History

#!/usr/bin/env python2.7
2015-06-17 23:31:38 +02:00
# Included modules
import os
import sys
def main():
2017-06-21 00:03:26 +02:00
if "--silent" not in sys.argv:
print "- Starting ZeroNet..."
2015-06-17 23:31:38 +02:00
main = None
try:
app_dir = os.path.dirname(os.path.abspath(__file__))
os.chdir(app_dir) # Change working dir to zeronet.py dir
sys.path.insert(0, os.path.join(app_dir, "src/lib")) # External liblary directory
sys.path.insert(0, os.path.join(app_dir, "src")) # Imports relative to src
2015-06-17 23:31:38 +02:00
import main
main.start()
if main.update_after_shutdown: # Updater
import gc
import update
import atexit
2015-06-17 23:31:38 +02:00
# Try cleanup openssl
try:
if "lib.opensslVerify" in sys.modules:
sys.modules["lib.opensslVerify"].opensslVerify.closeLibrary()
except Exception, err:
print "Error closing opensslVerify lib", err
try:
if "lib.pyelliptic" in sys.modules:
sys.modules["lib.pyelliptic"].openssl.closeLibrary()
except Exception, err:
print "Error closing pyelliptic lib", err
2015-06-17 23:31:38 +02:00
2016-11-08 15:02:28 +01:00
# Close lock file
sys.modules["main"].lock.close()
2016-12-04 18:55:33 +01:00
# Update
try:
update.update()
except Exception, err:
print "Update error: %s" % err
2016-12-04 18:55:33 +01:00
2015-06-17 23:31:38 +02:00
# Close log files
logger = sys.modules["main"].logging.getLogger()
for handler in logger.handlers[:]:
handler.flush()
handler.close()
logger.removeHandler(handler)
atexit._run_exitfuncs()
2017-01-11 13:12:20 +01:00
except Exception, err: # Prevent closing
import traceback
2017-01-11 13:12:20 +01:00
try:
import logging
logging.exception("Unhandled exception: %s" % err)
except Exception, log_err:
print "Failed to log error:", log_err
traceback.print_exc()
from Config import config
traceback.print_exc(file=open(config.log_dir + "/error.log", "a"))
2015-06-17 23:31:38 +02:00
if main and main.update_after_shutdown: # Updater
# Restart
gc.collect() # Garbage collect
print "Restarting..."
2016-03-16 21:27:00 +01:00
import time
time.sleep(1) # Wait files to close
2015-06-17 23:31:38 +02:00
args = sys.argv[:]
2017-01-21 23:01:29 +01:00
sys.executable = sys.executable.replace(".pkg", "") # Frozen mac fix
if not getattr(sys, 'frozen', False):
args.insert(0, sys.executable)
2015-06-17 23:31:38 +02:00
if sys.platform == 'win32':
args = ['"%s"' % arg for arg in args]
2017-01-21 23:01:29 +01:00
try:
print "Executing %s %s" % (sys.executable, args)
os.execv(sys.executable, args)
except Exception, err:
print "Execv error: %s" % err
2015-06-17 23:31:38 +02:00
print "Bye."
2017-01-21 23:01:29 +01:00
if __name__ == '__main__':
2017-01-11 13:12:20 +01:00
main()