-
Notifications
You must be signed in to change notification settings - Fork 701
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
look into supporting JSON API #452
Comments
Nice use of JSON to enhance hypermedias. |
i have no immediate plans to work on it .. just put it here so that its not forgotten and in the hopes that someone else picks it up. |
@lsmith77 ok :), I am ready to participate if someone take the lead of it. Right now I have no idea where to start. |
I guess a start could be building a Symfony Standard edition fork that (re-)builds one of the examples from the ember.js community and seeing what is currently missing. |
I think the read part can already be achieved using FSCHateosBundle and JMSSerializerBundle (and returning the appropriate data in your controller). the update part requires work as the json patch format needs to be parsed and converted into an update of the object. |
Keep in mind http://jsonapi.org/ is still a work in progress: "This media type is still a work in progress, and we are extremely open to feedback and proposals for improvement. That said, implementation work has already begun, and we value good working systems over perfect vaporware." That being said if this can be implemented properly, FOSRestBundle will truly help developers support Ember-data (Outside of this ticket the only active support I have seen is from the Ruby and Python communities). I think two big keys here will be making the documentation, and keeping the implementation simple. I've been attempting to implement something of my own, and failing miserably as of late. I have high hopes for this however, and I am willing to try and help where ever I can (time permitting). |
I've been going through the pains of trying to implement a simple one to many relationship. Spent pretty much all day attempting to simulate the docs, and it is not as easy as it may seem. There is an incredible amount of labor involved, and I fear I may end up writing a LOT of custom code. I am struggling coming up with common code that could ease this pain yet. I am open for suggestions, but at this point I fear this implementation is just not worth the effort given the current state of existing REST, Serializer, and HATEOS bundles. |
This needs to be driven from the ORM/ODM metadata which then needs to be combined with the metadata in FSCHateoasBundle. Is there information missing on the ORM/ODM side? |
As far as the read side goes; I am fairly sure that the ORM/ODM should have all the information it needs with the possible exception of the relationship data required to build the HATEOS links (HATEOS will know the relationship, but not the URL path to the target REST API). This is the first time i've really looked at any of the internals for the REST bundle, so I am definitely working a bit uphill. |
The key thing to look at is the view layer. However I think a lot of this will actually end up being done inside the Serializer. This is exactly what FSCHateosBundle takes as the integration point. As a result you might actually want to focus on that Bundle for now. Here is a PR to integrate it with FOSRestBundle #327 .. as you can see it works in principle but the integration is not done in a very efficient manner. If you could wrap that up it would be a huge step forward for this topic. |
I can say after developing a full "restful api" from scratch using the HAL / Hateos specs, I wish I would have come across http://jsonapi.org much sooner b/c it makes way more sense in most cases. HAL / Hateos complicates things a bit... and I had to sit down with front-end people all the time b/c they we're confused. |
granted, i only skimmed through the http://jsonapi.org stuff.... but i liked the small amount of what i saw and it seemed simple and dumbed down. |
Also looking for something like this, I am currently working/trying on creating a bundle which follows the jsonapi spec using JMS Serializer. Currently trying to figure out how to add data to the top-level. Anybody also working on a solution to support jsonapi? |
IMO you should connect with @willdurand and @adrienbrault. They have a library that currently supports json+hal and are looking into also supporting other formats. |
Thanks, I see they are already on it, will try to help them out. :) |
Hey, guys. I built a HATEOAS library / bundle that supports the full spec of JSON-API on top of a Symfony 2 with full Doctrine 2 entity mappings. It also incorporates RAML into the mix. Thought you might want to check it out. |
@skqr Wow, looks good. But, why doesn't it integrate with JMS Serializer? A lot of people are using this when building there API's. Also when using this you are tight to use JSON API right? You cannot easily switch to XML or another format? The approach of HateoasBundle of @willdurand is very flexible (uses the JMS serializer also). What I like about your library is that you have sorting etc. automatically working when using Doctrine. Looks good overall, but I don't think it would integerate very well with popular existing bundles and projects. |
Thanks, @steffenbrem =) Absolutely. The project is quite opinionated. It requires you to use RAML, Doctrine 2, some Symfony 2 components - and JSON. Here's why. I tried the JMS Serializer a number of times, and it simply was not built for the task. At least currently, and at least as far as I tried, it couldn't handle the kind of complex flattened and referenced serialization that JSON-API proposes. I started the project attempting to implement HAL, and I originally intended to start with a fork of @willdurand's project. I tried this for about a week. Then JSON-API hit me like a bucket of ice. It really blew my mind. It addresses several of today's most popular API's gravest errors in a slick and elegant manner. So then I tried to make JSON-API happen along with the JMS Serializer and Will's lib, but that wasn't happening either. That's when I realized that a different, more focused approach, might fit my intentions better. Abstractions might happen later, but will probably target things like the web framework (e.g. Laravel) or the specific ORM (e.g. Eloquent). This is definitely a RAML + JSON-API HATEOAS project. I also love what the guys at MuleSoft are doing with RAML. I hear one of their tools lets you generate a JavaScript SDK for your API from your RAML definitions, and will soon be able to handle the other popular langs. |
@skqr Ah I've been there too. Here is a Gist of the serializer I wrote for JMS Serializer and the library of @willdurand. It supports linked resources, links etc. Not the whole json-api spec (but I don't need the whole spec, yet). https://gist.github.com/steffenbrem/ebfe0f07fe7b1df93b54. It is hacky in some sort, but it is still experimental for me. It is currently optimized to work with Here is a screenshot of an example response that my serializer creates: I don't know if this would help you ;) But I understand that you created your own solutions for this, you need a deeper understanding of the libraries before you can deal with the complex stuff JSON-API comes with. That last thing you said, is very interesting haha. But I like how |
Oh, that was you! 😺 Yeah, I was originally using your snippet as a base. Took it from here. It was a great help then! Ember is quite cool. We're using it, as a matter of fact. This lib I made is the mini framework on top of which the APIs in the company I'm with will run. Clients will either be PHP SDKs or Ember apps. The first client is a hybrid mobile app that's hitting the markets sometime next week. We were not too happy with the adapter JSON-API suggests, though. We're likely going to make our own soon. It's not that I don't appreciate the flexible possibilities that JMS provides. It's just that the current design will never allow you to implement something like JSON-API, either comfortably or otherwise. The main issue is resource relationship expansion. If you check out the example app using The GOintegro lib supports any depth of recursive relationship expansion, so you can do stuff like this.
Seriously. All of that is supported. |
@steffenbrem I like your |
@skqr I am not so sure, JMS does a pretty good job on the serialization/deserialization part. Of course, you need to move the functionalities like sorting and including embedded resources with the @willdurand Sure, I was thinking about creating a PR for this library. I need to write proper tests for this and clean stuff a bit up. What do you think about functionality like Also my current implementation gets its relation (linked) key from the |
@steffenbrem, it's your class that got me rolling 😸 @willdurand's amazing post and projects too, obviously. I'd love to see how this PR progresses. Keep rocking, guys. |
Hey there! I just wanted to let you know that JSON API has hit RC3, and we'd like client libraries to start implementing it like it was 1.0, as a final check that we're good for 1.0. So hopefully that can inform the discussion here a bit. |
@lsmith77: I can start working on this, it is an interresting topic ! |
@amenophis : you will be a hero if you accomplish this! |
I have read whole json api spec now and it will not be as simple as it looks, there are many complicated scenarios and this spec is really extensive, but I hope we will have some implementation in near future, because I really like this new fresh spec. |
Is anyone working on this? JSON API hit the 1.0 stable and Ember Data just pushed the first stable release using it. |
not that I know of .. would be awesome! |
I am currently working on this, trying to get it out for public. I inspired most of it from the Hateoas bundle from willdurand. For example, this is how you would configure the JSON-API serializer for your data models (later on it can also support XML of YAML, since I use /**
* @Hateoas\Resource(type="posts")
*
* @author Steffen Brem <steffenbrem@gmail.com>
*/
class Post
{
/**
* @Hateoas\Id
*/
protected $id;
/**
* @var string
*/
protected $title;
/**
* @var string
*/
protected $description;
/**
* @Hateoas\HasMany(includeByDefault=true)
*/
protected $comments;
// ...
} What I am working on now is a seperate bundle, that will integrate with |
I am not sure though if it needs to be another |
Hi, from my point of view this is the way which I would also went. I really like how the This problem could be accomplished by so many ways. I prefer to use and extend the When you will have working bundle which will be compatible with You can use many code from This is how I'm looking on this enhancement. And about this unassuming line:
I'm really impatient how it will be implemented. ;-) |
@szachara I will put something public today, for now I am only working with an AnnotationDriver. Currently I've got some basic Here is a simple output from the serializer that I wrote of a basic {
"data": [
{
"type": "posts",
"id": 1,
"attributes": {
"tiiitel": "My post",
"description": "This is the first post"
},
"relationships": {
"comments": {
"data": [
{
"type": "comments",
"id": 1
}
]
}
}
},
{
"type": "posts",
"id": 2,
"attributes": {
"tiiitel": "My second post",
"description": "This is the second post"
},
"relationships": {
"comments": {
"data": [
{
"type": "comments",
"id": 1
}
]
}
}
},
{
"type": "posts",
"id": 3,
"attributes": {
"tiiitel": "My third post",
"description": "This is the third post"
},
"relationships": {
"comments": {
"data": []
}
}
}
],
"included": [
{
"type": "comments",
"id": 1,
"attributes": {
"title": "This is a comment title",
"body": "My body"
}
}
]
} |
Great start, I have not found any error in serialized output, already now it's valid
This is very important. |
If anyone wants to discuss about this topic, I created a public repo, which I will soon fill with my work that I have done. See: https://github.com/steffenbrem/JsonApiBundle |
👍 |
ok .. closing the ticket as there is now a Bundle for this |
http://jsonapi.org
The text was updated successfully, but these errors were encountered: