mirror of
				https://github.com/adidas/api-guidelines.git
				synced 2025-10-25 15:19:19 +00:00 
			
		
		
		
	GitBook: [master] 69 pages modified
This commit is contained in:
		
							
								
								
									
										126
									
								
								rest-api-guidelines/message/error-reporting.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								rest-api-guidelines/message/error-reporting.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| # Problem Detail | ||||
|  | ||||
| The [`application/problem+json`](https://tools.ietf.org/html/rfc7807) \(Problem Detail\) **MUST** be used to communicate details about an error. | ||||
|  | ||||
| Problem Detail is intended for use with the HTTP status codes 4xx and 5xx. Problem Detail **MUST NOT** be used with 2xx status code responses. | ||||
|  | ||||
| At the minimum, any Problem Detail response **MUST** have the `title` and `detail` fields. | ||||
|  | ||||
| ### Example | ||||
|  | ||||
| ```javascript | ||||
| { | ||||
|   "title": "Authentication required", | ||||
|   "detail": "Missing authentication credentials for the Greeting resource." | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ## Optional Fields | ||||
|  | ||||
| It **SHOULD** has the `type` field with the identifier of the error, besides it **MAY** have the `instance` field with the URI of the resource in question. If the Problem Detail response has the `status` field it **MUST** have the same value as HTTP Status code from of the response. | ||||
|  | ||||
| ```javascript | ||||
| { | ||||
|   "type": "https://adidas-group.com/problems/scv/unauthorized", | ||||
|   "title": "Authentication required", | ||||
|   "detail": "Missing authentication credentials for the Greeting resource.", | ||||
|   "instance": "/greeting", | ||||
|   "status": 401 | ||||
| } | ||||
| ``` | ||||
|  | ||||
| > NOTE: The `type` field is an identifier, and as such it **MAY** be used to denote additional error codes. Keep in mind that the identifier should be a URI. | ||||
|  | ||||
| ## Additional Fields | ||||
|  | ||||
| If needed, the Problem Detail **MAY** include additional fields, refer to [RFC7807](https://tools.ietf.org/html/rfc7807) for details. | ||||
|  | ||||
| ## Validation Errors | ||||
|  | ||||
| When necessary, a Problem Detail response **MAY** include additional error details about the problems that have occurred. | ||||
|  | ||||
| These additional errors **MUST** be under the `errors` and **MUST** follow the Problem Detail structure. | ||||
|  | ||||
| ### Example | ||||
|  | ||||
| Request: | ||||
|  | ||||
| ```text | ||||
| POST /my-resource HTTP/1.1 | ||||
| Content-Type: application/json | ||||
|  | ||||
| { | ||||
|   "age": -32, | ||||
|   "color": "cyan" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| Response: | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 400 Bad Request | ||||
| Content-Type: application/problem+json | ||||
| Content-Language: en | ||||
|  | ||||
| { | ||||
|   "type": "https://example.net/validation_error", | ||||
|   "title": "Your request parameters didn't validate.", | ||||
|   "instance": "/my-resource", | ||||
|   "status": 400, | ||||
|  | ||||
|   "errors": [ | ||||
|     { | ||||
|       "type": "https://example.net/invalid_params", | ||||
|       "instance": "/age", | ||||
|       "title": "Invalid Parameter", | ||||
|       "detail": "age must be a positive integer" | ||||
|     }, | ||||
|     { | ||||
|       "type": "https://example.net/invalid_params", | ||||
|       "instance": "/color", | ||||
|       "title": "Invalid Parameter", | ||||
|       "detail": "color must be 'green', 'red' or 'blue'" | ||||
|     } | ||||
|   ] | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ## Problem Detail and Content Negotiation | ||||
|  | ||||
| ### Example | ||||
|  | ||||
| A request is made to retrieve a resource representation: | ||||
|  | ||||
| ```text | ||||
| GET /greeting HTTP/1.1 | ||||
| Accept: application/hal+json | ||||
| ``` | ||||
|  | ||||
| However, in order to make this request, the client needs to be authorized. Since the request is made without the authorization credentials the **401 Unauthorized** response is returned together with details using the `application/problem+json` media type: | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 401 Unauthorized | ||||
| Content-Type: application/problem+json | ||||
| Content-Language: en | ||||
|  | ||||
| { | ||||
|   "type": "https://adidas-group.com/problems/scv/unauthorized", | ||||
|   "title": "Authentication required", | ||||
|   "detail": "Missing authentication credentials for the Greeting resource.", | ||||
|   "instance": "/greeting", | ||||
|   "status": 401 | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ## No Stack Traces or Server Logs | ||||
|  | ||||
| > _Problem details are not a debugging tool for the underlying implementation; rather, they are a way to expose greater detail about the HTTP interface itself._ | ||||
| > | ||||
| > _–_ [_RFC7807_](https://tools.ietf.org/html/rfc7807) | ||||
|  | ||||
| A Problem Detail response **MUST NOT** contain a program stack trace or server log for debugging purposes. Instead, provide a `logref` field with reference to the particular server log. | ||||
|  | ||||
| ## Working with Problem Detail | ||||
|  | ||||
| There are a whole plethora of libraries working with Problem Detail, for example, see [Zalando / Problem](https://github.com/zalando/problem) \(Java\). | ||||
|  | ||||
		Reference in New Issue
	
	Block a user