mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-25 10:42:58 -03:00
Fix conflicts from snowflake merge, and fix detection of lack of meek in Moat BridgeDB request
This commit is contained in:
commit
242312ba82
3 changed files with 38 additions and 19 deletions
|
@ -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")
|
||||||
|
|
||||||
|
|
|
@ -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']}")
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Reference in a new issue