Inherit
Content items are arranged in a hierarchy. Each content item has a parent, each of which may have its own parent, continuing all the way to the site root. Together, the chain of parents are ancestors of the content item.
The @inherit
service makes it possible to access data from a behavior defined on one of these ancestors.
To use the service, send a GET
request to the @inherit
endpoint in the context of the content item that is the starting point for inheriting. Specify the expand.inherit.behaviors
parameter as a comma-separated list of behaviors.
GET /news/@inherit?expand.inherit.behaviors=navigation_root HTTP/1.1
Accept: application/json
Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiJhZG1pbiIsImZ1bGxuYW1lIjoiQWRtaW4iLCJpYXQiOjE2NDkzMTI0NDl9.RS1Ny_r0v7vIylFfK6q0JVJrkiDuTOh9iG9IL8xbzAk
For each behavior, the service will find the closest ancestor which provides that behavior. The result includes from
(the @id
and title
of the item from which values were inherited) and data
(values for any fields that are part of the behavior).
HTTP/1.1 200 OK
Content-Type: application/json
{
"@id": "http://localhost:8080/news/@inherit",
"navigation_root": {
"data": {},
"from": {
"@id": "http://localhost:8080",
"title": "Welcome to Nick!"
}
}
}
Ancestor items for which the current user lacks the View
permission will be skipped.