Attempt to fix CannotListenError

This commit is contained in:
David Amrhein 2016-09-02 16:04:27 -04:00
parent e67fa3cadc
commit 756427560c
2 changed files with 40 additions and 9 deletions

View file

@ -1,8 +1,16 @@
import _winreg as winreg import _winreg as winreg
import os import os
import sys
import win32con
import win32gui
def main(): def main():
try:
install = 'remove' not in sys.argv[1]
except:
install = True
lbry_path = os.path.join(os.environ["ProgramFiles"], "LBRY", "LBRY.exe") lbry_path = os.path.join(os.environ["ProgramFiles"], "LBRY", "LBRY.exe")
key_url = 'lbry' key_url = 'lbry'
@ -10,8 +18,12 @@ def main():
key = winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, key_url, 0, winreg.KEY_ALL_ACCESS) key = winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, key_url, 0, winreg.KEY_ALL_ACCESS)
except: except:
key = winreg.CreateKey(winreg.HKEY_CLASSES_ROOT, key_url) key = winreg.CreateKey(winreg.HKEY_CLASSES_ROOT, key_url)
winreg.SetValueEx(key, None, 0, winreg.REG_SZ, "URL:LBRY Protocol") if install:
winreg.SetValueEx(key, "URL Protocol", 0, winreg.REG_SZ, "") winreg.SetValueEx(key, None, 0, winreg.REG_SZ, "URL:LBRY Protocol")
winreg.SetValueEx(key, "URL Protocol", 0, winreg.REG_SZ, "")
else:
winreg.DeleteKey(winreg.HKEY_CLASSES_ROOT, key_url)
winreg.CloseKey(key) winreg.CloseKey(key)
key_icon = os.path.join('lbry', 'DefaultIcon') key_icon = os.path.join('lbry', 'DefaultIcon')
@ -19,7 +31,10 @@ def main():
key = winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, key_icon, 0, winreg.KEY_ALL_ACCESS) key = winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, key_icon, 0, winreg.KEY_ALL_ACCESS)
except: except:
key = winreg.CreateKey(winreg.HKEY_CLASSES_ROOT, key_icon) key = winreg.CreateKey(winreg.HKEY_CLASSES_ROOT, key_icon)
winreg.SetValueEx(key, None, 0, winreg.REG_SZ, "\"LBRY.exe,1\"") if install:
winreg.SetValueEx(key, None, 0, winreg.REG_SZ, "\"LBRY.exe,1\"")
else:
winreg.DeleteKey(winreg.HKEY_CLASSES_ROOT, key_icon)
winreg.CloseKey(key) winreg.CloseKey(key)
key_command = os.path.join('lbry', 'shell', 'open', 'command') key_command = os.path.join('lbry', 'shell', 'open', 'command')
@ -27,8 +42,13 @@ def main():
key = winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, key_command, 0, winreg.KEY_ALL_ACCESS) key = winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, key_command, 0, winreg.KEY_ALL_ACCESS)
except: except:
key = winreg.CreateKey(winreg.HKEY_CLASSES_ROOT, key_command) key = winreg.CreateKey(winreg.HKEY_CLASSES_ROOT, key_command)
winreg.SetValueEx(key, None, 0, winreg.REG_SZ, "\"{0}\" \"%1\"".format(lbry_path)) if install:
winreg.SetValueEx(key, None, 0, winreg.REG_SZ, "\"{0}\" \"%1\"".format(lbry_path))
else:
winreg.DeleteKey(winreg.HKEY_CLASSES_ROOT, key_command)
winreg.CloseKey(key) winreg.CloseKey(key)
win32gui.SendMessage(win32con.HWND_BROADCAST, win32con.WM_SETTINGCHANGE, 0, 'Environment')
if __name__ == "__main__": if __name__ == "__main__":
main() main()

View file

@ -11,6 +11,7 @@ import win32gui_struct
from jsonrpc.proxy import JSONRPCProxy from jsonrpc.proxy import JSONRPCProxy
from twisted.internet import reactor, error from twisted.internet import reactor, error
from twisted.web import server from twisted.web import server
import twisted
try: try:
import winxpgui as win32gui import winxpgui as win32gui
@ -19,15 +20,21 @@ except ImportError:
from lbrynet.lbrynet_daemon.LBRYDaemonServer import LBRYDaemonServer, LBRYDaemonRequest from lbrynet.lbrynet_daemon.LBRYDaemonServer import LBRYDaemonServer, LBRYDaemonRequest
from lbrynet.conf import API_PORT, API_INTERFACE, ICON_PATH, APP_NAME from lbrynet.conf import API_PORT, API_INTERFACE, ICON_PATH, APP_NAME
from lbrynet.conf import UI_ADDRESS, API_CONNECTION_STRING from lbrynet.conf import UI_ADDRESS, API_CONNECTION_STRING, LOG_FILE_NAME
from packaging.uri_handler.LBRYURIHandler import LBRYURIHandler from packaging.uri_handler.LBRYURIHandler import LBRYURIHandler
# TODO: omg, this code is essentially duplicated in LBRYDaemon
data_dir = os.path.join(os.path.expanduser("~"), ".lbrynet")
if not os.path.isdir(data_dir):
os.mkdir(data_dir)
lbrynet_log = os.path.join(data_dir, LOG_FILE_NAME)
log = logging.getLogger(__name__)
if getattr(sys, 'frozen', False) and os.name == "nt": if getattr(sys, 'frozen', False) and os.name == "nt":
os.environ["REQUESTS_CA_BUNDLE"] = os.path.join(os.path.dirname(sys.executable), "cacert.pem") os.environ["REQUESTS_CA_BUNDLE"] = os.path.join(os.path.dirname(sys.executable), "cacert.pem")
log = logging.getLogger(__name__)
REMOTE_SERVER = "www.google.com" REMOTE_SERVER = "www.google.com"
@ -282,7 +289,11 @@ def main(lbry_name=None):
d.addCallback(lambda _: LBRYURIHandler.open_address(lbry_name)) d.addCallback(lambda _: LBRYURIHandler.open_address(lbry_name))
lbrynet_server = server.Site(lbry.root) lbrynet_server = server.Site(lbry.root)
lbrynet_server.requestFactory = LBRYDaemonRequest lbrynet_server.requestFactory = LBRYDaemonRequest
reactor.listenTCP(API_PORT, lbrynet_server, interface=API_INTERFACE) try:
reactor.listenTCP(API_PORT, lbrynet_server, interface=API_INTERFACE)
except error.CannotListenError:
log.info('Daemon already running, exiting app')
sys.exit(1)
reactor.run() reactor.run()
if __name__ == '__main__': if __name__ == '__main__':
@ -298,7 +309,7 @@ if __name__ == '__main__':
lbry_name = LBRYURIHandler.parse_name(sys.argv[1]) lbry_name = LBRYURIHandler.parse_name(sys.argv[1])
except IndexError: except IndexError:
lbry_name = None lbry_name = None
start_daemon = True
if start_daemon: if start_daemon:
main(lbry_name) main(lbry_name)
else: else: