During the hackathon multiple API Platform contributors were present, some of them from the core team and available to help others.
When it comes to API Platform we merged 20 PR, opened 10 new PR, closed 87 issues and opened 4 new. Lots of work being done by the contributors, big kudos!!
Since 2 years ago, API Platform supports subresources, which allows to access a relation from a resource. It is used a lot and is very powerful, but it has a lot of complexity and is limited.
With the help of @vincentchalamon, @soyuka and @torreytsui, some research was made on how to improve the subresources by reducing the complexity of the implementation and by enabling the POST/PUT operations for the subresources (api-platform/core#2598, api-platform/core#2428).
Thanks to @jewome62, it's now possible to populate an object recursively with the serializer to normalize a DateTimeZone
object, and to get an instanciated object from an associative array of values.
@soyuka did a lot to close stale issues, along with @vincentchalamon.
@gregoirehebert fixed an issue where the cache was still purged even if there was no GET operation on an ApiResource, and added a way to switch the API Platform version for the documentation (api-platform/website#103).
@Deuchnord worked on the client generator, you'll be able to use Mercure on the Vue.js generated client soon.
@alanpoulain worked on multiple things about GraphQL, MongoDB, and the event system of API Platform:
- The event system is being reworked to have internal events in API Platform instead of being based on the Symfony ones. It will allow to be decoupled from Symfony and to add events for GraphQL (api-platform/core#2506)
- Relay Input Object Mutations Specification (GraphQL) was not fully respected (api-platform/core#2696)
- Input messenger was not tested with MongoDB
- Improve the contributing documentation
@jfthuillier worked on the documentation on how to customize easily the API Platform admin. He also started a PoC on how to use the guesser from react-admin in API Platform Admin.
@antograssiot did work on multiple features and fixes:
- Apply DenyAccessListener before deserialization
- Be more intelligent in determining property writable/readable link
- Makes URL generation strategy default value configurable
Same for @toflar who worked on his great improvements, like removing some hard dependencies:
- Added an additional test for strict types validation
- Removed hard dependencies on Doctrine ODM to run the tests
- Worked on a proposition for a general batch endpoint
- Added support for pagination parameters in subresource docs
@Nek worked on features and bugfixes:
- Ignore property that does not exist for interfaces (identifiers for interfaces)
- Fix error message in identifiers extractor
- Resource resolver for inheritance
@soyuka finished something @simperfit started improving IDs management.