mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2024-12-20 05:28:04 +00:00
don't check for existence of portnum file and then try to open it -- instead try to open it and catch exception
This avoids a race condition, also known as time-of-check-to-time-of-use.
This commit is contained in:
parent
98066ccaee
commit
921e643b93
@ -47,11 +47,12 @@ class Node(service.MultiService):
|
||||
f.write(idlib.b2a(self.nodeid) + "\n")
|
||||
f.close()
|
||||
self.short_nodeid = self.tub.tubID[:4] # ready for printing
|
||||
portnum = 0
|
||||
assert self.PORTNUMFILE, "Your node.Node subclass must provide PORTNUMFILE"
|
||||
self._portnumfile = os.path.join(self.basedir, self.PORTNUMFILE)
|
||||
if os.path.exists(self._portnumfile):
|
||||
portnum = int(open(self._portnumfile, "r").read())
|
||||
try:
|
||||
portnum = int(open(self._portnumfile, "rU").read())
|
||||
except EnvironmentError, ValueError:
|
||||
portnum = 0
|
||||
self.tub.listenOn("tcp:%d" % portnum)
|
||||
# we must wait until our service has started before we can find out
|
||||
# our IP address and thus do tub.setLocation, and we can't register
|
||||
|
Loading…
Reference in New Issue
Block a user