electrum

Electrum Bitcoin wallet
git clone https://git.parazyd.org/electrum
Log | Files | Refs | Submodules

commit febaedcd3696b2989aaa2136dc50c4edfe9fa807
parent 98a91c9306b47b8319b1f169051fe51f1b76cf1c
Author: SomberNight <somber.night@protonmail.com>
Date:   Tue, 20 Feb 2018 16:06:34 +0100

crash reporting: catch exceptions from requests.post

Diffstat:
Mgui/qt/exception_window.py | 16++++++++++++----
1 file changed, 12 insertions(+), 4 deletions(-)

diff --git a/gui/qt/exception_window.py b/gui/qt/exception_window.py @@ -107,14 +107,22 @@ class Exception_Window(QWidget): def send_report(self): if bitcoin.NetworkConstants.GENESIS[-4:] not in ["4943", "e26f"] and ".electrum.org" in report_server: # Gah! Some kind of altcoin wants to send us crash reports. - self.main_window.show_critical("Please report this issue manually.") + self.main_window.show_critical(_("Please report this issue manually.")) return report = self.get_traceback_info() report.update(self.get_additional_info()) report = json.dumps(report) - response = requests.post(report_server, data=report) - QMessageBox.about(self, "Crash report", response.text) - self.close() + try: + response = requests.post(report_server, data=report, timeout=20) + except BaseException as e: + traceback.print_exc(file=sys.stderr) + self.main_window.show_critical(_('There was a problem with the automatic reporting:') + '\n' + + str(e) + '\n' + + _("Please report this issue manually.")) + return + else: + QMessageBox.about(self, "Crash report", response.text) + self.close() def on_close(self): Exception_Window._active_window = None