mirror of
				https://github.com/adidas/api-guidelines.git
				synced 2025-10-25 15:19:19 +00:00 
			
		
		
		
	Define adidas guidelines in spectral ruleset
This commit is contained in:
		
							
								
								
									
										177
									
								
								spectral.yml
									
									
									
									
									
								
							
							
						
						
									
										177
									
								
								spectral.yml
									
									
									
									
									
								
							| @@ -1,68 +1,141 @@ | ||||
| extends: [[spectral:oas2, off]] | ||||
| extends: spectral:oas2 | ||||
| rules: | ||||
|   fields-camelCase: | ||||
|     description: All YAML and JSON fields MUST follow fields-camelCase | ||||
|     severity: error | ||||
|     given: $.paths[*] | ||||
|   operation-operationId: false | ||||
|   operation-tags: info | ||||
|   operation-2xx-response: error | ||||
|   paths-camelCase: | ||||
|     description: All YAML/JSON paths MUST follow camelCase | ||||
|     severity: warn | ||||
|     recommended: true | ||||
|     message: "{{property}} is not camelCase: {{error}}" | ||||
|     given: $.paths[*]~ | ||||
|     then: | ||||
|       function:  | ||||
|   fields-alphanumeric: | ||||
|     description: Field names MUST be ASCII alphanumeric characters or `_` or `$` | ||||
|       function: pattern | ||||
|       functionOptions: | ||||
|         # match: "/^(\/{1}(([{]?[a-z])[A-Za-z0-9]*[}]?)*)+$/" # - more generic one, allows /asasd{asdas}sadas pattern but also not closed braces | ||||
|         match: "^\/([a-z][a-zA-Z0-9]+)?(\/[a-z][a-zA-Z0-9]+|\/{[a-z][a-zA-Z0-9]+})*$" # doesn't allow /asasd{asdas}sadas pattern or not closed braces | ||||
|   definitions-camelCase-alphanumeric: | ||||
|     description: All YAML/JSON definitions MUST follow fields-camelCase and be ASCII alphanumeric characters or `_` or `$`. | ||||
|     severity: error | ||||
|   fields-collections-plural: | ||||
|     description: Collection/array fields MUST have names in plural | ||||
|     recommended: true | ||||
|     message: "{{property}} MUST follow camelCase and be ASCII alphanumeric characters or `_` or `$`." | ||||
|     given: $.definitions[*]~ | ||||
|     then: | ||||
|       function: pattern | ||||
|       functionOptions: | ||||
|         match: "/^[a-z$_]{1}[A-Z09$_]*/" | ||||
|   properties-camelCase-alphanumeric: | ||||
|     description: All JSON Schema properties MUST follow fields-camelCase and be ASCII alphanumeric characters or `_` or `$`. | ||||
|     severity: error | ||||
|   protocol-https: | ||||
|     description: All requests MUST go through `https` protocol | ||||
|     severity: error | ||||
|   response-2xx-obligatory: | ||||
|     description: Every API operation MUST have at least one `2xx` response | ||||
|     recommended: true | ||||
|     message: "{{property}} MUST follow camelCase and be ASCII alphanumeric characters or `_` or `$`." | ||||
|     given: $.definitions..properties[*]~ | ||||
|     then: | ||||
|       function: pattern | ||||
|       functionOptions: | ||||
|         match: "/^[a-z$_]{1}[A-Z09$_]*/" | ||||
|   protocol-https-only: | ||||
|     description: "ALL requests MUST go through `https` protocol only" | ||||
|     recommended: true | ||||
|     severity: error | ||||
|     type: "style" | ||||
|     message: "Schemes MUST be https and no other value is allowed." | ||||
|     given: $ | ||||
|     then: | ||||
|       field: schemes | ||||
|       function: schema | ||||
|       functionOptions: | ||||
|         schema: | ||||
|           type: array | ||||
|           items: | ||||
|             type: string | ||||
|             enum: ["https"] | ||||
|           maxItems: 1 | ||||
|   request-GET-no-body: | ||||
|     description: A `GET` request MUST NOT accept a `body` parameter | ||||
|     severity: error | ||||
|   response-success-hal: | ||||
|     given: $.paths..get.parameters..in | ||||
|     then: | ||||
|       function: pattern | ||||
|       functionOptions: | ||||
|         notMatch: "/^body$/" | ||||
|   response-success-hal: # schemes and/or produces | ||||
|     description: All success responses MUST be of media type `application/hal+json` | ||||
|     severity: error | ||||
|   response-error-problem: | ||||
|     given: $.paths..responses[?( @property >= 200 && @property < 300 )] | ||||
|     recommended: true | ||||
|     severity: error | ||||
|     type: "style" | ||||
|     message: "Response documents MUST follow application/hal+json: {{error}}" | ||||
|     then: | ||||
|       field: schema | ||||
|       function: schema | ||||
|       functionOptions: | ||||
|         schema: | ||||
|           $ref: ./hal.yaml | ||||
|   response-error-problem: # schemes and/or produces | ||||
|     description: All error responses MUST be of media type `application/problem+json` | ||||
|     severity: error | ||||
|   request-support-json: | ||||
|     given: $.paths..responses[?( @property >= 400 && @property < 600 )] | ||||
|     recommended: true | ||||
|     severity: error | ||||
|     type: "style" | ||||
|     message: "Error response document MUST follow application/problem+json: {{error}}" | ||||
|     then: | ||||
|       field: schema | ||||
|       function: schema | ||||
|       functionOptions: | ||||
|         schema: | ||||
|           $ref: ./problem.yaml | ||||
|   request-support-json: # This will have to take into account the schemes as well as consumes parameter | ||||
|     description: Every request SHOULD support `application/json` media type | ||||
|     severity: warning | ||||
|   mediatype-hal-correctness: | ||||
|     description: Mediatype `application/hal+json` follows https://supermodel.io/adidas/api/HAL `JSON-Schema` | ||||
|     severity: hint | ||||
|   mediatype-problem-title: | ||||
|     description: All `application/problem+json` messages MUST include `title` field | ||||
|     severity: error | ||||
|   mediatype-problem-detail: | ||||
|     description: All `application/problem+json` messages MUST include `detail` field | ||||
|     severity: error | ||||
|   mediatype-problem-type: | ||||
|     description: All `application/problem+json` messages SHOULD include `type` field | ||||
|     severity: warning | ||||
|   fields-date-iso8601: | ||||
|     description: Date and time MUST follow [`ISO 8601` standard](https://www.iso.org/iso-8601-date-and-time-format.html) | ||||
|     severity: error | ||||
|   fields-language-iso639: | ||||
|     description: Language codes MUST follow [`ISO 639` standard](https://www.iso.org/iso-639-language-codes.html) | ||||
|     severity: error | ||||
|   fields-country-iso3166: | ||||
|     description: Country codes MUST follow [`ISO 3166 alpha-2` standard](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) | ||||
|     severity: error | ||||
|   fields-currency-iso4217: | ||||
|     description: Currency codes MUST follow [`ISO 4217` standard](https://en.wikipedia.org/wiki/ISO_4217) | ||||
|     severity: error | ||||
|   response-303-async-link-header: | ||||
|     description: A successful and finished async api request returns `303` response code and sends the target resource location in the `Link` header | ||||
|     severity: hint | ||||
|     severity: warn | ||||
|     message: "{{description}}: {{error}}" | ||||
|     recommended: true | ||||
|     given: "$..consumes" | ||||
|     then: | ||||
|       function: schema | ||||
|       functionOptions: | ||||
|         schema: | ||||
|           type: array | ||||
|           contains: | ||||
|             type: string | ||||
|             enum: | ||||
|               - application/json | ||||
|   uri-template-cannot-dash: | ||||
|     description: The `URI` template ([RFC 6570](https://tools.ietf.org/html/rfc6570)) cannot contain a `-` character | ||||
|     severity: error | ||||
|   headers-hyphenated-pascal-case: | ||||
|     description: All `HTTP` headers MUST use `Hyphenated-Pascal-Case` notation | ||||
|     severity: error | ||||
|   heders-no-x-headers: | ||||
|     description: All `HTTP` headers SHOULD NOT include `X-` headers (https://tools.ietf.org/html/rfc6648). All non-standard headers are named without the `X-` prefix. | ||||
|     severity: warning | ||||
|     recommended: true | ||||
|     message: "{{property}}: {{description}}" | ||||
|     given: $.paths[*]~ | ||||
|     then: | ||||
|       function: pattern | ||||
|       functionOptions: | ||||
|         notMatch: "/-/" | ||||
|   # Needs update of JSON Schema in spectral to draft-07 or newer to implement if-then statements | ||||
|   # headers-hyphenated-pascal-case: | ||||
|   #   description: All `HTTP` headers MUST use `Hyphenated-Pascal-Case` notation | ||||
|   #   severity: error | ||||
|   #   given: $..parameters[*].in | ||||
|   # heders-no-x-headers: | ||||
|   #   description: All `HTTP` headers SHOULD NOT include `X-` headers (https://tools.ietf.org/html/rfc6648). All non-standard headers are named without the `X-` prefix. | ||||
|   #   severity: warning | ||||
|   #   given: $..parameters[*].in | ||||
|  | ||||
| ## Other rules which are redundant or not feasible | ||||
|    | ||||
|   # fields-date-iso8601: | ||||
|   #   description: Date and time MUST follow [`ISO 8601` standard](https://www.iso.org/iso-8601-date-and-time-format.html) | ||||
|   #   severity: error | ||||
|   # fields-language-iso639: | ||||
|   #   description: Language codes MUST follow [`ISO 639` standard](https://www.iso.org/iso-639-language-codes.html) | ||||
|   #   severity: error | ||||
|   # fields-country-iso3166: | ||||
|   #   description: Country codes MUST follow [`ISO 3166 alpha-2` standard](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) | ||||
|   #   severity: error | ||||
|   # fields-currency-iso4217: | ||||
|   #   description: Currency codes MUST follow [`ISO 4217` standard](https://en.wikipedia.org/wiki/ISO_4217) | ||||
|   #   severity: error | ||||
|   # response-303-async-link-header: | ||||
|   #   description: A successful and finished async api request returns `303` response code and sends the target resource location in the `Link` header | ||||
|   #   severity: hint | ||||
		Reference in New Issue
	
	Block a user