3 sys.setdefaultencoding("utf-8")
5 import win32serviceutil
15 # this logging should go away once service startup is considered debugged.
16 logfilehandle = file('c:\\tahoe_service.log', 'ab+')
18 logfilehandle.write("%s: %s\r\n" % (time.strftime('%Y%m%d_%H%M%S'), msg))
20 logmsg('service loaded')
23 # Now with some bootstrap util functions in place, let's try and init things:
25 from allmydata.util import pkgresutil # override pkg_resources zip provider for py2exe deployment
26 pkgresutil.install() # this is done before nevow is imported
28 logmsg('loading base dir')
29 from allmydata.windows import registry
30 basedir = registry.get_base_dir_path()
31 logmsg("got base dir (%s)" % (basedir,))
33 regpth = "%s : %s " % (registry._AMD_KEY, registry._BDIR_KEY)
34 raise RuntimeError('"%s" not set in registry' % (regpth,))
36 logmsg("chdir(%s)" % (basedir,))
39 traceback.print_exc(None, logfilehandle)
44 class Tahoe(win32serviceutil.ServiceFramework):
46 _svc_display_name_ = "Allmydata Tahoe Node"
47 def __init__(self, args):
50 # The exe-file has messages for the Event Log Viewer.
51 # Register the exe-file as event source.
53 # Probably it would be better if this is done at installation time,
54 # so that it also could be removed if the service is uninstalled.
55 # Unfortunately it cannot be done in the 'if __name__ == "__main__"'
56 # block below, because the 'frozen' exe-file does not run this code.
58 logmsg("service start")
59 win32evtlogutil.AddSourceToRegistry(self._svc_display_name_,
62 win32serviceutil.ServiceFramework.__init__(self, args)
63 self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)
67 traceback.print_exc(None, logfilehandle)
74 logmsg("service stop")
75 self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
76 win32event.SetEvent(self.hWaitStop)
82 # Write a 'started' event to the event log...
83 win32evtlogutil.ReportEvent(self._svc_display_name_,
84 servicemanager.PYS_SERVICE_STARTED,
86 servicemanager.EVENTLOG_INFORMATION_TYPE,
87 (self._svc_name_, ''))
89 reactor_type = registry.get_registry_value('reactor')
90 if reactor_type == 'iocp':
91 from twisted.internet import iocpreactor
94 from twisted.internet import selectreactor
95 selectreactor.install()
96 from twisted.internet import reactor
98 if os.path.exists('DISABLE_STARTUP'):
99 logmsg("DISABLE_STARTUP exists: exiting")
101 logmsg("runing reactorthread")
103 # launch main thread...
104 thread.start_new_thread(self.launch_node, ())
106 # ...and block until service stop request
107 win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)
111 reactor.callFromThread(reactor.stop)
113 time.sleep(2) # give the node/reactor a chance to cleanup
115 # and write a 'stopped' event to the event log.
116 win32evtlogutil.ReportEvent(self._svc_display_name_,
117 servicemanager.PYS_SERVICE_STOPPED,
119 servicemanager.EVENTLOG_INFORMATION_TYPE,
120 (self._svc_name_, ''))
124 traceback.print_exc(None, logfilehandle)
125 logfilehandle.flush()
126 logfilehandle.close()
130 def launch_node(self):
132 logmsg("main thread startup")
134 import depends # import dependencies so that py2exe finds them
135 _junk = depends # appease pyflakes
137 from twisted.internet import reactor
138 from twisted.python import log, logfile
139 from allmydata import client
141 # set up twisted logging. this will become part of the node rsn.
142 logdir = os.path.join(basedir, 'logs')
143 if not os.path.exists(logdir):
145 lf = logfile.LogFile('tahoesvc.log', logdir)
148 # run the node itself
149 c = client.Client(basedir)
150 reactor.callLater(0, c.startService) # after reactor startup
151 reactor.run(installSignalHandlers=False)
153 logmsg("main thread shutdown")
156 traceback.print_exc(None, logfilehandle)
157 logfilehandle.flush()
160 if __name__ == '__main__':
161 logmsg("service main")
162 win32serviceutil.HandleCommandLine(Tahoe)