summaryrefslogtreecommitdiff
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-11-01Merge pull request #6791 from qutebrowser/update-dependenciesFlorian Bruhin
Update dependencies
2021-11-01Update dependenciesqutebrowser bot
2021-10-30Avoid pytest-bdd 5 for nowFlorian Bruhin
See https://github.com/pytest-dev/pytest-bdd/issues/447
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-25Merge pull request #6768 from qutebrowser/update-dependenciesFlorian Bruhin
Update dependencies
2021-10-25Update changelogFlorian Bruhin
2021-10-25Don't crash on notification daemon crashFlorian Bruhin
2021-10-25Update changelogFlorian 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-25Update dependenciesqutebrowser bot
2021-10-25Add pylint_checkers build dir to .gitignoreFlorian Bruhin
2021-10-22doc: Add breath themeFlorian Bruhin
2021-10-21Release v2.4.0v2.4.0Florian Bruhin
2021-10-21Merge remote-tracking branch 'origin/update-dependencies'Florian Bruhin
2021-10-21Update changelogFlorian Bruhin
2021-10-21Fix typoFlorian Bruhin
2021-10-21utils: Fix coverage pragma locationFlorian Bruhin
2021-10-21Update dependenciesqutebrowser bot
2021-10-21scripts: Fix changelog URLs for realFlorian Bruhin
2021-10-21scripts: Use new Qt path in build_releaseFlorian Bruhin
2021-10-21Revert "scripts: Remove macOS symlinking"Florian Bruhin
This reverts commit a0bfb7c824900881f01c53204d9e8cd0b5b78f53. It *is* required, just used the wrong path... gg
2021-10-21scripts: Remove old -Qt5 PyQt packagesFlorian Bruhin
2021-10-21requirements: PyQt 5.15.5Florian Bruhin
2021-10-21utils: Don't require coverage for old PyYAML workaroundFlorian Bruhin
2021-10-21scripts: Remove macOS symlinkingFlorian Bruhin
Seems to be fixed in PyInstaller 4.4? See #6611.
2021-10-21tox: Use newest PyQt for pyinstallerFlorian Bruhin
See #6611
2021-10-21scripts: Adjust changelog URLsFlorian Bruhin
2021-10-21Merge remote-tracking branch 'origin/update-dependencies'Florian Bruhin
2021-10-21Update docsFlorian Bruhin
2021-10-21Update UA completionsFlorian Bruhin
2021-10-21Don't register qutebrowserurl: as URL protocolFlorian Bruhin
This was originally intended as a fix for CVE-2021-41146, but it turned out the same exploit works via e.g. https:// just as well. Still, it makes sense to remove it.
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-18Update dependenciesqutebrowser bot
2021-10-14tests: Adjust for PyYAML 6.0Florian Bruhin
2021-10-14Merge pull request #6737 from qutebrowser/update-dependenciesFlorian Bruhin
Update dependencies
2021-10-11scripts: Update path to flake8 release notesFlorian Bruhin
2021-10-11scripts: Add cached-property changelog URLFlorian Bruhin
2021-10-11Update dependenciesqutebrowser bot
2021-10-09doc: Clarify SOCKS auth supportFlorian Bruhin
2021-10-04Merge pull request #6725 from qutebrowser/update-dependenciesFlorian Bruhin
Update dependencies
2021-10-04scripts: Adjust py-filelock changelog URLFlorian Bruhin
2021-10-04Update dependenciesqutebrowser bot
2021-10-01requirements: Revert to pytest-bdd release for bleedingFlorian Bruhin
See https://github.com/pytest-dev/pytest-bdd/issues/447
2021-09-29Merge pull request #6720 from haztecaso/patch-1Florian Bruhin
Add userscript bitwarden-rofi to the list of userscripts
2021-09-29Add userscript bitwarden-rofiAdrián Lattes