Files
api-guidelines/protocol/content-negotiation.md
apidesigner 9ef2c92157 Updates protocol/content-negotiation.md
Auto commit by GitBook Editor
2017-02-01 16:47:40 +00:00

1.5 KiB

Content Negotiation

Every API MUST implement and every API Consumer MUST use HTTP content negotiation where a representation of a resource is requested.

NOTE: The content negotiation plays the key role in evolving an API, change management and versioning.

Example

A client is programmed to use the application/vnd.example.resource+json; version=2 media type. The client requests a representation of the /greeting resource in desired the media type (including its version) from the server:

GET /greeting HTTP/1.1
Accept: application/vnd.example.resource+json; version=2
...

The server is able to provide only a newer version of the requested media type version=2.1.3. But since the newer version is backward compatible with the requested version=2 (related: Changes & Versioning) it is able to satisfy the request and responds:

HTTP/1.1 200 OK
Content-Type: application/vnd.example.resource+json; version=2.1.3
...

NOTE: A server that doesn't have the requested representation media type available MUST respond with the HTTP Status Code 406 Not Acceptable.

NOTE: A server MAY have multiple choices available and MAY respond with the 300 Multiple Choices response. In which case client SHOULD choose from the presented choices.

You can read more about content negotiation at MDN Content negotiation.