RFC 2. RFC2. Content Negotiation Client Responsibilities. Clients MUST send all JSON API data in request documents with the header. Content Type applicationvnd. Clients that include the JSON API media type in their Accept header MUST. Clients MUST ignore any parameters for the applicationvnd. Content Type header of response documents. Server Responsibilities. Servers MUST send all JSON API data in response documents with the header. Content Type applicationvnd. Servers MUST respond with a 4. Unsupported Media Type status code if. Content Type applicationvnd. Servers MUST respond with a 4. Not Acceptable status code if a. Accept header contains the JSON API media type and all instances. Note The content negotiation requirements exist to allow future versions. Document Structure. This section describes the structure of a JSON API document, which is identified. JSON API documents are defined in Java. Script Object Notation JSON. RFC7. 15. 9. Although the same media type is used for both request and response documents. These differences are. Unless otherwise noted, objects defined by this specification MUST NOT. Client and server implementations MUST. Note These conditions allow this specification to evolve through additive. Top Level. A JSON object MUST be at the root of every JSON API request and response. This object defines a documents top level. A document MUST contain at least one of the following top level members data the documents primary dataerrors an array of error objectsmeta a meta object that contains non standard. The members data and errors. MUST NOT coexist in the same document. A document MAY contain any of these top level members jsonapi an object describing the servers implementationlinks a links object related to the primary data. If a document does not contain a top level data key, the included member. MUST NOT be present either. The top level links object. MAY contain the following members self the link that generated the current response document. The documents primary data is a representation of the resource or collection. Primary data MUST be either For example, the following primary data is a single resource object data type articles,id 1,attributes. The following primary data is a single resource identifier object that. A logical collection of resources MUST be represented as an array, even if. Resource ObjectsResource objects appear in a JSON API document to represent resources. A resource object MUST contain at least the following top level members Exception The id member is not required when the resource object originates at. In addition, a resource object MAY contain any of these top level members attributes an attributes object representing some of the resources data. JSON API resources. Heres how an article i. Rails is Omakase,relationships author links self articles1relationshipsauthor,related articles1author,data type people,id 9. Identification. Every resource object. MUST contain an id member and a type member. The values of the id and type members MUST be strings. Within a given API, each resource objects type and id pair MUST. The set of URIs controlled by a server. API. The type member is used to describe resource objects that share common. The values of type members MUST adhere to the same constraints as. Note This spec is agnostic about inflection rules, so the value of type. However, the same value should be used. Fields. A resource objects attributes and its relationships are collectively called. Fields for a resource object. MUST share a common namespace with each. In other words, a resource can not have an. Attributes. The value of the attributes key MUST be an object an attributes. Members of the attributes object attributes represent information. Attributes may contain any valid JSON value. Complex data structures involving JSON objects and arrays are allowed as. However, any object that constitutes or is contained in an. MUST NOT contain a relationships or links member, as those. Although has one foreign keys e. SHOULD NOT appear as attributes. Note See fields and member names for more restrictions on this container. Relationships. The value of the relationships key MUST be an object a relationships. Members of the relationships object relationships represent. Relationships may be to one or to many. A relationship object MUST contain at least one of the following links a links object containing at least one of the following. This. link allows the client to directly manipulate the relationship. For example. removing an author through an articles relationship URL would disconnect. When fetched successfully, this link returns the linkage. See Fetching Relationships. A relationship object that represents a to many relationship MAY also contain. Note See fields and member names for more restrictions on this container. Related Resource Links. A related resource link provides access to resource objectslinked. When fetched, the related resource objects. For example, an articles commentsrelationship could. GET request. If present, a related resource link MUST reference a valid URL, even if the. Additionally. a related resource link MUST NOT change because its relationships content. Resource Linkage. Resource linkage in a compound document allows a client to link together all. GET any URLs via links. Resource linkage MUST be represented as one of the following Note The spec does not impart meaning to order of resource identifier. Arrays of resource identifier objects may represent ordered. For example, the following article is associated with an author. Rails is Omakase,relationships author links self http example. The author relationship includes a link for the relationship itself which. Resource Links. The optional links member within each resource object contains links. If present, this links object MAY contain a selflink that. Rails is Omakase,links self http example. How To Install A Toilet Pan more. A server MUST respond to a GET request to the specified URL with a. Resource Identifier Objects. A resource identifier object is an object that identifies an individual. A resource identifier object MUST contain type and id members. A resource identifier object MAY also include a meta member, whose value is a meta object that. Compound Documents. To reduce the number of HTTP requests, servers MAY allow responses that. Such. responses are called compound documents. In a compound document, all included resources MUST be represented as an.