Skip to main content

This site requires you to update your browser. Your browsing experience maybe affected by not having the most up to date version.

CVE-2020-6165 Limited queries break CanViewPermissionChecker

Severity:
Medium (?)
Identifier:
CVE-2020-6165
Versions Affected:
silverstripe/graphql: ^3.2, silverstripe/recipe-cms: ^4.5.0
Versions Fixed:
silverstripe/graphql: 3.2.4, silverstripe/graphql: 3.3.0
Release Date:
2020-07-13

The automatic permission checking mechanism in the silverstripe/graphql module does not provide complete protection against lists that are limited (e.g. through pagination), resulting in records that should fail the permission check being added to the final result set.

GraphQL endpoints are configured by default through the CMS (e.g. for assets), but the admin/graphql endpoint is access protected by default. This limits the vulnerability to users with access to the CMS, but still applies when those authenticated users have limited permissions (e.g. where viewing records exposed through admin/graphql require administrator permissions).

Where custom GraphQL endpoints have been be configured for a specific implementation (usually under /graphql), this vulnerability could also be exploited through unauthenticated requests.

This vulnerability only applies for reading records it does not allow unauthorised changing of records.

If your project implements custom GraphQL queries returning a query-limited result set, you might have to validate that those queries still work as expected and adjust them if they don't.

Review the 4.5.3 changelogs or the 4.6.0 changelogs for additional details on how to upgrade your project.

Base CVSS Score: 5.3

CWP CVSS Score: 5.3

Reporter: Matthias Leutenegger, CEO, Syntro GmbH and Rob Ingram