Opencast versions prior to 9.10 allow HTTP method spoofing, allowing to change the assumed HTTP method via URL parameter. This allows attackers to turn HTTP GET requests into PUT requests or an HTTP form to send DELETE requests. This bypasses restrictions otherwise put on these types of requests and aids in cross-site request forgery (CSRF) attacks, which would otherwise not be possible.
The vulnerability allows attackers to craft links or forms which may change the server state. For example, the following GET request would create a new user:
% curl -i -u admin:opencast \
'https://legacy.opencast.org/admin-ng/users/test.json?_method=PUT&username=test&password=attack'
HTTP/2 200
…
If an admin is logged in to legacy.opencast.org and accidentally clicks this link, a user will silently be created.
This issue is fixed in Opencast 9.10 and 10.0.
You can mitigate the problem by setting the SameSite=Strict
attribute for your cookies. If this is a viable option for you depends on your integrations. We strongly recommend updating in any case.
If you have any questions or comments about this advisory: * Open an issue in our issue tracker * Email us at security@opencast.org
{ "nvd_published_at": "2021-12-14T18:15:00Z", "github_reviewed_at": "2021-12-14T18:49:26Z", "severity": "HIGH", "github_reviewed": true, "cwe_ids": [ "CWE-290" ] }