Fix conflicts from snowflake merge, and fix detection of lack of meek in Moat BridgeDB request

This commit is contained in:
Miguel Jacq 2021-10-20 15:52:29 +11:00
commit 242312ba82
No known key found for this signature in database
GPG key ID: EEA4341C6D97A0B6
3 changed files with 38 additions and 19 deletions

View file

@ -338,6 +338,7 @@ class Onion(object):
for line in self.settings.get("tor_bridges_use_moat_bridges").split( for line in self.settings.get("tor_bridges_use_moat_bridges").split(
"\n" "\n"
): ):
if line.strip() != "":
f.write(f"Bridge {line}\n") f.write(f"Bridge {line}\n")
f.write("\nUseBridges 1\n") f.write("\nUseBridges 1\n")
@ -345,6 +346,7 @@ class Onion(object):
for line in self.settings.get( for line in self.settings.get(
"tor_bridges_use_custom_bridges" "tor_bridges_use_custom_bridges"
).split("\n"): ).split("\n"):
if line.strip() != "":
f.write(f"Bridge {line}\n") f.write(f"Bridge {line}\n")
f.write("\nUseBridges 1\n") f.write("\nUseBridges 1\n")

View file

@ -22,6 +22,7 @@ from PySide2 import QtCore, QtWidgets, QtGui
import requests import requests
import os import os
import base64 import base64
import json
from . import strings from . import strings
from .gui_common import GuiCommon from .gui_common import GuiCommon
@ -61,6 +62,11 @@ class MoatDialog(QtWidgets.QDialog):
self.solution_lineedit.editingFinished.connect( self.solution_lineedit.editingFinished.connect(
self.solution_lineedit_editing_finished self.solution_lineedit_editing_finished
) )
self.submit_button = QtWidgets.QPushButton(strings._("moat_captcha_submit"))
self.submit_button.clicked.connect(self.submit_clicked)
solution_layout = QtWidgets.QHBoxLayout()
solution_layout.addWidget(self.solution_lineedit)
solution_layout.addWidget(self.submit_button)
# Error label # Error label
self.error_label = QtWidgets.QLabel() self.error_label = QtWidgets.QLabel()
@ -68,8 +74,6 @@ class MoatDialog(QtWidgets.QDialog):
self.error_label.hide() self.error_label.hide()
# Buttons # Buttons
self.submit_button = QtWidgets.QPushButton(strings._("moat_captcha_submit"))
self.submit_button.clicked.connect(self.submit_clicked)
self.reload_button = QtWidgets.QPushButton(strings._("moat_captcha_reload")) self.reload_button = QtWidgets.QPushButton(strings._("moat_captcha_reload"))
self.reload_button.clicked.connect(self.reload_clicked) self.reload_button.clicked.connect(self.reload_clicked)
self.cancel_button = QtWidgets.QPushButton( self.cancel_button = QtWidgets.QPushButton(
@ -77,7 +81,6 @@ class MoatDialog(QtWidgets.QDialog):
) )
self.cancel_button.clicked.connect(self.cancel_clicked) self.cancel_button.clicked.connect(self.cancel_clicked)
buttons_layout = QtWidgets.QHBoxLayout() buttons_layout = QtWidgets.QHBoxLayout()
buttons_layout.addWidget(self.submit_button)
buttons_layout.addStretch() buttons_layout.addStretch()
buttons_layout.addWidget(self.reload_button) buttons_layout.addWidget(self.reload_button)
buttons_layout.addWidget(self.cancel_button) buttons_layout.addWidget(self.cancel_button)
@ -86,7 +89,7 @@ class MoatDialog(QtWidgets.QDialog):
layout = QtWidgets.QVBoxLayout() layout = QtWidgets.QVBoxLayout()
layout.addWidget(self.label) layout.addWidget(self.label)
layout.addWidget(self.captcha) layout.addWidget(self.captcha)
layout.addWidget(self.solution_lineedit) layout.addLayout(solution_layout)
layout.addStretch() layout.addStretch()
layout.addWidget(self.error_label) layout.addWidget(self.error_label)
layout.addLayout(buttons_layout) layout.addLayout(buttons_layout)
@ -135,7 +138,11 @@ class MoatDialog(QtWidgets.QDialog):
self.common, self.common,
self.meek, self.meek,
"check", "check",
{"challenge": self.challenge, "solution": self.solution_lineedit.text()}, {
"transport": self.transport,
"challenge": self.challenge,
"solution": self.solution_lineedit.text(),
},
) )
self.t_check.bridgedb_error.connect(self.bridgedb_error) self.t_check.bridgedb_error.connect(self.bridgedb_error)
self.t_check.captcha_error.connect(self.captcha_error) self.t_check.captcha_error.connect(self.captcha_error)
@ -166,9 +173,10 @@ class MoatDialog(QtWidgets.QDialog):
self.solution_lineedit.setEnabled(True) self.solution_lineedit.setEnabled(True)
def captcha_ready(self, image, challenge): def captcha_ready(self, transport, image, challenge):
self.common.log("MoatDialog", "captcha_ready") self.common.log("MoatDialog", "captcha_ready")
self.transport = transport
self.challenge = challenge self.challenge = challenge
# Save captcha image to disk, so we can load it # Save captcha image to disk, so we can load it
@ -210,7 +218,7 @@ class MoatThread(QtCore.QThread):
bridgedb_error = QtCore.Signal() bridgedb_error = QtCore.Signal()
captcha_error = QtCore.Signal(str) captcha_error = QtCore.Signal(str)
captcha_ready = QtCore.Signal(str, str) captcha_ready = QtCore.Signal(str, str, str)
bridges_ready = QtCore.Signal(str) bridges_ready = QtCore.Signal(str)
def __init__(self, common, meek, action, data={}): def __init__(self, common, meek, action, data={}):
@ -231,7 +239,9 @@ class MoatThread(QtCore.QThread):
# We should only fetch bridges if we can domain front, # We should only fetch bridges if we can domain front,
# but we can override this in local-only mode. # but we can override this in local-only mode.
if not self.meek.meek_proxies and not self.common.gui.local_only: if not self.meek.meek_proxies and not self.common.gui.local_only:
raise MeekNotRunning() self.common.log("MoatThread", "run", f"Could not identify meek proxies to make request")
self.bridgedb_error.emit()
return
if self.action == "fetch": if self.action == "fetch":
self.common.log("MoatThread", "run", f"starting fetch") self.common.log("MoatThread", "run", f"starting fetch")
@ -246,7 +256,10 @@ class MoatThread(QtCore.QThread):
{ {
"version": "0.1.0", "version": "0.1.0",
"type": "client-transports", "type": "client-transports",
"supported": [self.transport], "supported": [
"obfs4",
"snowflake",
],
} }
] ]
}, },
@ -270,17 +283,12 @@ class MoatThread(QtCore.QThread):
self.common.log("MoatThread", "run", f"type != moat-challange") self.common.log("MoatThread", "run", f"type != moat-challange")
self.bridgedb_error.emit() self.bridgedb_error.emit()
return return
if moat_res["data"][0]["transport"] != self.transport:
self.common.log(
"MoatThread", "run", f"transport != {self.transport}"
)
self.bridgedb_error.emit()
return
transport = moat_res["data"][0]["transport"]
image = moat_res["data"][0]["image"] image = moat_res["data"][0]["image"]
challenge = moat_res["data"][0]["challenge"] challenge = moat_res["data"][0]["challenge"]
self.captcha_ready.emit(image, challenge) self.captcha_ready.emit(transport, image, challenge)
except Exception as e: except Exception as e:
self.common.log("MoatThread", "run", f"hit exception: {e}") self.common.log("MoatThread", "run", f"hit exception: {e}")
self.bridgedb_error.emit() self.bridgedb_error.emit()
@ -300,7 +308,7 @@ class MoatThread(QtCore.QThread):
"id": "2", "id": "2",
"type": "moat-solution", "type": "moat-solution",
"version": "0.1.0", "version": "0.1.0",
"transport": self.transport, "transport": self.data["transport"],
"challenge": self.data["challenge"], "challenge": self.data["challenge"],
"solution": self.data["solution"], "solution": self.data["solution"],
"qrcode": "false", "qrcode": "false",
@ -315,6 +323,11 @@ class MoatThread(QtCore.QThread):
try: try:
moat_res = r.json() moat_res = r.json()
self.common.log(
"MoatThread",
"run",
f"got bridges:\n{json.dumps(moat_res,indent=2)}",
)
if "errors" in moat_res: if "errors" in moat_res:
self.common.log("MoatThread", "run", f"errors={moat_res['errors']}") self.common.log("MoatThread", "run", f"errors={moat_res['errors']}")

View file

@ -808,10 +808,14 @@ class TorSettingsDialog(QtWidgets.QDialog):
meek_lite_pattern = re.compile( meek_lite_pattern = re.compile(
"(meek_lite)(\s)+([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+)(\s)+([0-9A-Z]+)(\s)+url=(.+)(\s)+front=(.+)" "(meek_lite)(\s)+([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+)(\s)+([0-9A-Z]+)(\s)+url=(.+)(\s)+front=(.+)"
) )
snowflake_pattern = re.compile(
"(snowflake)(\s)+([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+)(\s)+([0-9A-Z]+)"
)
if ( if (
ipv4_pattern.match(bridge) ipv4_pattern.match(bridge)
or ipv6_pattern.match(bridge) or ipv6_pattern.match(bridge)
or meek_lite_pattern.match(bridge) or meek_lite_pattern.match(bridge)
or snowflake_pattern.match(bridge)
): ):
new_bridges.append(bridge) new_bridges.append(bridge)
bridges_valid = True bridges_valid = True