DOCS GraphQL blacklisted fields (#9768)

This commit is contained in:
Ingo Schommer 2021-01-14 10:19:24 +13:00 committed by GitHub
parent 51a8245694
commit d308bb022c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -126,7 +126,7 @@ Page:
#### Customising the input types #### Customising the input types
The input types, specifically in `create` and `update` can be customised with a whitelist The input types, specifically in `create` and `update` can be customised with a whitelist
and/or blacklist of fields. and/or [blacklist](#blacklisted-fields) of fields.
**app/_graphql/models.yml** **app/_graphql/models.yml**
``` ```
@ -220,6 +220,26 @@ Page:
paginateList: false # don't paginate the read operation paginateList: false # don't paginate the read operation
``` ```
### Blacklisted fields {#blacklisted-fields}
While selecting all fields via `*` is usedful, there are some fields that you
don't want to accidentally expose, especially if you're a module author
and expect models within this code to be used through custom GraphQL endpoints.
For example, a module might add a secret "preview token" to each `SiteTree`.
A custom GraphQL endpoint might have used `fields: '*'` on `SiteTree` to list pages
on the public site, which now includes a sensitive field.
The `graphql_blacklisted_fields` property on `DataObject` allows you to
blacklist fields globally for all GraphQL schemas.
This blacklist applies for all operations (read, update, etc).
**app/_config/graphql.yml**
```yaml
SilverStripe\CMS\Model\SiteTree:
graphql_blacklisted_fields:
myPreviewTokenField: true
```
### Model configuration ### Model configuration
There are several settings you can apply to your model class (typically `DataObjectModel`), There are several settings you can apply to your model class (typically `DataObjectModel`),