-
Notifications
You must be signed in to change notification settings - Fork 49
Allow hydrators to set _embedded
#52
Comments
The only potential problem I see may be just an error of omission: any item under |
@weierophinney Yeah, I dropped out most of it for brevity. Anything passed as |
@tjlytle Go for it, then. :) |
Wouldn't this allow hydrators to do more than they're intended to do? My understanding is that their primary purpose is to extract/hydrate data from/to an object. If that's correct, configuring HAL links would seem out of scope for Hydrators... Instead maybe we could fire an event after extraction and before linking? |
@gabrielsomoza Hydrators exist to help facilitate the process of creating a representation; they're effectively part of the view layer when it comes to Apigility. As such, I think this is perfectly in their realm. @tjlytle How's the PR coming? :) |
This repository has been closed and moved to laminas-api-tools/api-tools-hal; a new issue has been opened at laminas-api-tools/api-tools-hal#22. |
I have an odd case where the entity (hal resource) has a property name that is also (sometimes) the name of a link and embedded object. Basically a message can be sent by a user (which a link and embedded object exist for), or a non-user where some basic information had been gathered to identify them (but no link or embedded resource because they're not an user).
Quick example:
Because the hydrator can send back a link collection, which is merged into the entities links during render, it's possible to have both a link and an entity property with the same name. However, it's not possible to have both a entity property and an embedded entity with the same name, since both are passed from the hydrator using a simple array.
My thought is to add support for hydrators to return an
_embedded
key (optionally), and anything found there will be treated as embedded entities.If I put this together as a PR, any opposition to merging it in?
The text was updated successfully, but these errors were encountered: