summaryrefslogtreecommitdiff
path: root/qutebrowser
AgeCommit message (Collapse)Author
2021-11-01Fix cleanupsremove-frozenFlorian Bruhin
2021-11-01Bring back PyInstaller resource handlingFlorian Bruhin
Seems to be still needed, at least on macOS
2021-11-01Remove some old PyInstaller handlingFlorian Bruhin
2021-10-30Add flatpak hint to :spawn messageFlorian Bruhin
See https://www.reddit.com/r/qutebrowser/comments/qirb5k/editor_gvim_failed_to_start_execpv_no_such_file/
2021-10-29earlyinit: Remove unnecessary 'as e:' tooFlorian Bruhin
2021-10-29Fix accessing log in earlyinitFlorian Bruhin
2021-10-25Don't crash on notification daemon crashFlorian Bruhin
2021-10-25Improve error handling with early faulthandler enableFlorian Bruhin
Speculative fix for issue reported by a macOS user: https://crashes.qutebrowser.org/lists?search=NullWriter See https://github.com/pyinstaller/pyinstaller/issues/4481
2021-10-21Release v2.4.0v2.4.0Florian Bruhin
2021-10-21Fix typoFlorian Bruhin
2021-10-21utils: Fix coverage pragma locationFlorian Bruhin
2021-10-21utils: Don't require coverage for old PyYAML workaroundFlorian Bruhin
2021-10-21Update UA completionsFlorian Bruhin
2021-10-21CVE-2021-41146: Add --untrusted-args to avoid argument injectionFlorian Bruhin
On Windows, if an application is registered as an URL handler like this: HKEY_CLASSES_ROOT https URL Protocol = "" [...] shell open command (Default) = ".../qutebrowser.exe" "%1" one would think that Windows takes care of making sure URLs can't inject arguments by containing a quote. However, this is not the case, as stated by the Microsoft docs: https://docs.microsoft.com/en-us/previous-versions/windows/internet-explorer/ie-developer/platform-apis/aa767914(v=vs.85) Security Warning: Applications that handle URI schemes must consider how to respond to malicious data. Because handler applications can receive data from untrusted sources, the URI and other parameter values passed to the application may contain malicious data that attempts to exploit the handling application. and As noted above, the string that is passed to a pluggable protocol handler might be broken across multiple parameters. Malicious parties could use additional quote or backslash characters to pass additional command line parameters. For this reason, pluggable protocol handlers should assume that any parameters on the command line could come from malicious parties, and carefully validate them. Applications that could initiate dangerous actions based on external data must first confirm those actions with the user. In addition, handling applications should be tested with URIs that are overly long or contain unexpected (or undesirable) character sequences. Indeed it's trivial to pass a command to qutebrowser this way - given how trivial the exploit is to recreate given the information above, here's a PoC: https:x" ":spawn calc (or qutebrowserurl: instead of https: if qutebrowser isn't registered as a default browser) Some applications do escape the quote characters before calling qutebrowser - but others, like Outlook Desktop or .url files, do not. As a fix, we add an --untrusted-args flag and some early validation of the raw sys.argv, before parsing any arguments or e.g. creating a QApplication (which might already allow injecting Qt flags there). We assume that there's no way for an attacker to inject flags *before* the %1 placeholder in the registry, and add --untrusted-args as the last argument of the registry entry. This way, it'd still be possible for users to customize their invocation flags without having to remove --untrusted-args. After --untrusted-args, however, we have some rather strict checks: - There should be zero or one arguments, but not two (or more) - Any argument may not start with - (flag) or : (qutebrowser command) We also add the --untrusted-args flag to the Linux .desktop file, though it should not be needed there, as the specification there is sane: https://specifications.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html#exec-variables Implementations must take care not to expand field codes into multiple arguments unless explicitly instructed by this specification. This means that name fields, filenames and other replacements that can contain spaces must be passed as a single argument to the executable program after expansion. There is no comparable mechanism on macOS, which opens the application without arguments and then sends an "open" event to it: https://doc.qt.io/qt-5/qfileopenevent.html This issue was introduced in qutebrowser v1.7.0 which started registering it as URL handler: baee2888907b260881d5831c68500941937261a0 / #4086 This is by no means an issue isolated to qutebrowser. Many other projects have had similar trouble with Windows' rather unexpected behavior: Electron / Exodus Bitcoin wallet: - http://web.archive.org/web/20190702112128/https://medium.com/0xcc/electrons-bug-shellexecute-to-blame-cacb433d0d62 - https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2018-1000006 - https://medium.com/hackernoon/exploiting-electron-rce-in-exodus-wallet-d9e6db13c374 IE/Firefox: - https://bugzilla.mozilla.org/show_bug.cgi?id=384384 - https://bugzilla.mozilla.org/show_bug.cgi?id=1572838 Others: - http://web.archive.org/web/20210930203632/https://www.vdoo.com/blog/exploiting-custom-protocol-handlers-in-windows - https://parsiya.net/blog/2021-03-17-attack-surface-analysis-part-2-custom-protocol-handlers/ - etc. etc. See CVE-2021-41146 / GHSA-vw27-fwjf-5qxm: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-41146 https://github.com/qutebrowser/qutebrowser/security/advisories/GHSA-vw27-fwjf-5qxm Thanks to Ping Fan (Zetta) Ke of Valkyrie-X Security Research Group (VXRL/@vxresearch) for finding and responsibly disclosing this issue.
2021-10-09doc: Clarify SOCKS auth supportFlorian Bruhin
2021-09-26Add GM_setClipboardFlorian Bruhin
Based on the Greasemonkey implementation: https://github.com/greasemonkey/greasemonkey/blob/4.11/src/bg/api-provider-source.js#L232-L249 Needed by e.g. this script to work at all: https://greasyfork.org/en/scripts/394820-mouseover-popup-image-viewer (cherry picked from commit 1bea82698153ba3e20529e010bc3f254b9904231)
2021-09-10Update doc for tab-clone's --private flagNicholas Boyd Isacsson
Co-authored-by: Florian Bruhin <me@the-compiler.org>
2021-09-10Add --private flag to :tab-cloneNicholas Boyd Isacsson
2021-09-08Improve docs for URL patternsFlorian Bruhin
Closes #6454, see #5069
2021-09-06Bind Shift-Escape in insert modeFlorian Bruhin
2021-08-25Remove unused var/importFlorian Bruhin
2021-08-25Move download origin handling to DownloadItemFlorian Bruhin
2021-08-25Prevent mixed content downloading by defaultFlorian Bruhin
https://blog.chromium.org/2020/02/protecting-users-from-insecure.html https://therecord.media/firefox-follows-chrome-and-prepares-to-block-insecure-downloads/
2021-08-21Don't try to hide deleted systray iconFlorian Bruhin
2021-08-17Update changelogFlorian Bruhin
2021-08-17Further simplify rapid hint target checkFlorian Bruhin
2021-08-17Clean up target list for hintingFlorian Bruhin
2021-08-10Clarify referer docsFlorian Bruhin
Closes #6640
2021-08-02Add support for overrideMimeType in Greasemonkey scriptsjcromero
2021-07-28Release v2.3.1Florian Bruhin
2021-07-28Switch back to Firefox UA for Google Account quirkFlorian Bruhin
Looks like the Edge one doesn't work anymore. Reverts db13e5283e2d20e83d348f15ea0f46c92e9f3e29 and reintroduces the Firefox UA removed in e010afd3a20a86639396a9c844abfea7b23cc67a (but updated). Closes #5182.
2021-07-20Update docsFlorian Bruhin
2021-07-19the backslash is redundant between bracketsAnder Punnar
2021-07-19fix pylint C0301Ander Punnar
2021-07-19make blocking subdomains configurableAnder Punnar
2021-07-13Simplify exception catchingFlorian Bruhin
2021-07-13Handle and test more file path corner casesFlorian Bruhin
2021-07-13Fixed infinite loop (tested it too)Jason Rosenzweig
2021-07-13Took suggestionsJason Rosenzweig
2021-07-13Added back question code which was accidentally removedJason Rosenzweig
2021-07-13Made implementation simpler, removed unrelated changeJason Rosenzweig
2021-07-13Removed code that I put in a comment to save it and fixed the styles of that ↵Jason Rosenzweig
comment
2021-07-13Initial commit of fix for issue 6549Jason Rosenzweig
2021-07-13Fix lint/docsFlorian Bruhin
2021-07-13Merge remote-tracking branch 'origin/pr/6507'Florian Bruhin
2021-07-13Handle UnicodeEncodeError in path completionFlorian Bruhin
2021-07-12Fix lintFlorian Bruhin
2021-07-12Log debug information on adblock errorFlorian Bruhin
See #6436
2021-07-12Revert "Fix enum stringification for Python 3.10 a7+"Florian Bruhin
This reverts commit e2c5fe6262564d9d85806bfa9d4486a411cf5045. See https://mail.python.org/archives/list/python-dev@python.org/thread/ZMC67QA2JVQJSWSFWRS6IM6ZX4EK277G/#LSTMFAPSPD3BGZ4D6HQFODXZVB3PLYKF
2021-07-12Add fff and lf as file selectorsFlorian Bruhin