The HTML form for a read-only canned query includes the hidden CSRF token field added in #798 for writable canned queries (#698).
This means that submitting those read-only forms exposes the CSRF token in the URL - for example on https://latest.datasette.io/fixtures/neighborhood_search submitting the form took me to:
https://latest.datasette.io/fixtures/neighborhood_search?text=down&csrftoken=CSRFTOKEN-HERE
This token could potentially leak to an attacker if the resulting page has a link to an external site on it and the user clicks the link, since the token would be exposed in the referral logs.
A fix for this issue has been released in Datasette 0.46.
You can fix this issue in a Datasette instance without upgrading by copying the 0.46 query.html template into a custom templates/
directory and running Datasette with the --template-dir=templates/
option.
Issue 918 discusses this in details: https://github.com/simonw/datasette/issues/918
Contact swillison at gmail with any questions.
{ "nvd_published_at": null, "cwe_ids": [ "CWE-200" ], "severity": "MODERATE", "github_reviewed": true, "github_reviewed_at": "2020-08-10T22:36:11Z" }