Revert to using wait_for_hs for ephemeral HS

Using `await_publication = True` blocks inside stem until the hidden
service is published, which makes OnionShare appear to hang. This is a
quick fix that reverts to using `wait_for_hs` for ephemeral hidden
services (as well as non-ephemeral hidden services), which avoids
blocking OnionShare.
This commit is contained in:
Garrett Robinson 2015-12-22 23:09:30 -05:00
parent 41a30dd4e4
commit 9d5ba9b4f6
3 changed files with 6 additions and 8 deletions

View File

@ -87,7 +87,7 @@ class HS(object):
print strings._("connecting_ctrlport").format(int(port)) print strings._("connecting_ctrlport").format(int(port))
if self.supports_ephemeral: if self.supports_ephemeral:
print strings._('using_ephemeral') print strings._('using_ephemeral')
res = self.c.create_ephemeral_hidden_service({ 80: port }, await_publication = True) res = self.c.create_ephemeral_hidden_service({ 80: port }, await_publication = False)
self.service_id = res.content()[0][2].split('=')[1] self.service_id = res.content()[0][2].split('=')[1]
onion_host = res.content()[0][2].split('=')[1] + '.onion' onion_host = res.content()[0][2].split('=')[1] + '.onion'
return onion_host return onion_host

View File

@ -159,10 +159,9 @@ def main(cwd=None):
try: # Trap Ctrl-C try: # Trap Ctrl-C
# wait for hs, only if using old version of tor # wait for hs, only if using old version of tor
if not app.local_only: if not app.local_only:
if not app.hs.supports_ephemeral: ready = app.hs.wait_for_hs(app.onion_host)
ready = app.hs.wait_for_hs(app.onion_host) if not ready:
if not ready: sys.exit()
sys.exit()
print strings._("give_this_url") print strings._("give_this_url")
print 'http://{0:s}/{1:s}'.format(app.onion_host, web.slug) print 'http://{0:s}/{1:s}'.format(app.onion_host, web.slug)

View File

@ -169,9 +169,8 @@ class OnionShareGui(QtGui.QWidget):
# wait for hs # wait for hs
if not self.app.local_only: if not self.app.local_only:
if not self.app.hs.supports_ephemeral: self.status_bar.showMessage(strings._('gui_starting_server3', True))
self.status_bar.showMessage(strings._('gui_starting_server3', True)) self.app.hs.wait_for_hs(self.app.onion_host)
self.app.hs.wait_for_hs(self.app.onion_host)
# done # done
self.start_server_finished.emit() self.start_server_finished.emit()