I'm using Spring Data REST, which supports HATEOAS. I'm new to this paradigm.
In GET
responses from my RESTful web service I often receive results inside a node named _embedded
.
I'm wondering: what is _embedded
node for? Is it part of REST specification? Or part of HATEOAS specification? Or is it specific for the Spring implementation of them?
This is an example of JSON result for GET http://localhost:8080/mywebservice/features
:
{
"_links":
{
"search": { "href": "http://localhost:8080/mywebservice/features/search" }
},
"_embedded":
{
"features":
[
{
"feature": "GROUND",
"name": "Terreno",
"data_type": "String",
"_links":
{
"self" : { "href": "http://localhost:8080/mywebservice/features/GROUND" },
"values": { "href": "http://localhost:8080/mywebservice/features/GROUND }
}
},
...
]
}
}
I noticed that I almost always have _embedded
node in the response: if I request a collection, but even if a request a single resource by a search (for instance with GET http://localhost:8080/mywebservice/persons/search/findByEmail?email=example@example@.com
).
I don't get _embedded
node only if the request is for a specific resource, for instance when doing GET http://localhost:8080/mywebservice/features/GROUND
.