mirror of
				https://github.com/adidas/api-guidelines.git
				synced 2025-10-25 15:19:19 +00:00 
			
		
		
		
	Solved conflict
This commit is contained in:
		
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -106,6 +106,5 @@ dist | ||||
| # SSHFS | ||||
| ._* | ||||
|  | ||||
| _book/ | ||||
|  | ||||
| **/.DS_Store | ||||
| .DS_Store | ||||
|   | ||||
| @@ -244,24 +244,40 @@ rules: | ||||
|         match: "/^https:/" | ||||
|  | ||||
|   adidas-oas3-response-success-hal: | ||||
|     description: "All success responses MUST be of media type `application/hal+json`" | ||||
|     description: "All success responses MUST be of media type `application/hal+json` " | ||||
|     severity: error | ||||
|     given: $.paths..responses[?( @property >= 200 && @property < 300 && @property != 204)].content[*]~ | ||||
|     given: $.paths..responses[?( @property >= 201 && @property < 300 && @property != 204)].content[*]~ | ||||
|     recommended: true | ||||
|     # type: "style" | ||||
|     formats: | ||||
|       - oas3 | ||||
|     message: "Response documents MUST be of application/hal+json media type: {{error}}" | ||||
|     message: "Response documents MUST be of application/hal+json media types: {{error}}" | ||||
|     then: | ||||
|       function: enumeration | ||||
|       functionOptions: | ||||
|         values: | ||||
|           - application/hal+json | ||||
|    | ||||
|   # sync and async patterns that can return hal OR problem+json | ||||
|   adidas-oas3-response-success-OK: | ||||
|     description: "All success responses MUST be of media type `application/hal+json` or `application/problem+json`" | ||||
|     severity: error | ||||
|     given: $.paths..responses[?( @property == 200 )].content[*]~ | ||||
|     recommended: true | ||||
|     formats: | ||||
|       - oas3 | ||||
|     message: "Response documents MUST be of application/hal+json or application/problem+json media types: {{error}}" | ||||
|     then: | ||||
|       function: enumeration | ||||
|       functionOptions: | ||||
|         values: | ||||
|           - application/hal+json | ||||
|           - application/problem+json | ||||
|            | ||||
|   adidas-oas3-response-success-hal-body: # schemes and/or produces | ||||
|     description: "All success responses MUST follow `application/hal+json` schema" | ||||
|     severity: error | ||||
|     given: $.paths..responses[?( @property >= 200 && @property < 300 && @property != 204)].content[?(@property === "application/hal+json")] | ||||
|     given: $.paths..responses[?( @property == 200 && @property < 300 && @property != 204)].content[?(@property === "application/hal+json")] | ||||
|     recommended: true | ||||
|     type: "style" | ||||
|     formats: | ||||
|   | ||||
							
								
								
									
										12
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								README.md
									
									
									
									
									
								
							| @@ -4,7 +4,7 @@ description: Guidelines for the API design and development at adidas | ||||
|  | ||||
| # adidas API Guidelines | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| [](https://opensource.org/licenses/MIT) | ||||
|  | ||||
| @@ -23,7 +23,7 @@ The API Guidelines are split into two main parts: | ||||
| * [General Guidelines](general-guidelines/general-guidelines.md) | ||||
| * API type-specific Guidelines | ||||
|   * [REST APIs Guidelines](rest-api-guidelines/rest.md) | ||||
|   * [Kafka Guidelines](kafka-guidelines/kafka.md) | ||||
|   * [Asynchronous APIs Guidelines](asynchronous-api-guidelines/asyncapi.md) | ||||
|  | ||||
| The general guidelines section discusses the core principles relevant to any kind of API. The API type-specific section further defines the guidelines specific to a given architectural style or API technique \(such as REST, Kafka or GraphQL APIs\). | ||||
|  | ||||
| @@ -61,7 +61,7 @@ For further documentation on Spectral refer to their [documentation](https://sto | ||||
|  | ||||
| ### Questions & Comments | ||||
|  | ||||
| _Please contact_ [_Zdenek.Nemec@externals.adidas-group.com_](mailto:Zdenek.Nemec@externals.adidas-group.com), [_andrzej.jarzyna@adidas.com_](mailto:andrzej.jarzyna@adidas.com) or [_samir.amzani@adidas.com_](mailto:samir.amzani@adidas.com) _in case of questions._ | ||||
| _Please contact_ [_samir.amzani@adidas.com_](mailto:samir.amzani@adidas.com) or [_jesusjavier.dediego@adidas.com_](mailto:jesusjavier.dediego@adidas.com) _in case of questions._ | ||||
|  | ||||
| ## Intended Use Cases | ||||
|  | ||||
| @@ -69,6 +69,10 @@ This project is intended to provide the guidelines for design & development of A | ||||
|  | ||||
| adidas is not responsible for the usage of this software for different purposes that the ones described in the use cases. | ||||
|  | ||||
| ## Last Review | ||||
|  | ||||
| February 2021 | ||||
|  | ||||
| ## License and Software Information | ||||
|  | ||||
| © adidas AG | ||||
| @@ -83,5 +87,5 @@ For further information open the [adidas terms and conditions](https://github.co | ||||
|  | ||||
| ### License | ||||
|  | ||||
| [MIT](https://github.com/adidas-group/api-guidelines/tree/657bc6fd49f1499f10c30ab18420f4bdb7cd841b/LICENSE/README.md) | ||||
| [MIT](https://github.com/adidas/api-guidelines/blob/master/LICENSE) | ||||
|  | ||||
|   | ||||
| @@ -39,7 +39,10 @@ | ||||
|   * [Common Data Types](rest-api-guidelines/application/common-data-types.md) | ||||
| * [Execution](rest-api-guidelines/execution/README.md) | ||||
|   * [Pagination](rest-api-guidelines/execution/pagination.md) | ||||
|   * [Asynchronous Tasks](rest-api-guidelines/execution/asynchronous-tasks.md) | ||||
|   * [Long Running Tasks](rest-api-guidelines/execution/long-running-tasks/README.md) | ||||
|     * [Polling](rest-api-guidelines/execution/long-running-tasks/polling.md) | ||||
|     * [Callback](rest-api-guidelines/execution/long-running-tasks/callback.md) | ||||
|     * [Files Upload](rest-api-guidelines/execution/long-running-tasks/files-upload.md) | ||||
|   * [Batch Operations](rest-api-guidelines/execution/batch-operations.md) | ||||
|   * [Search Requests](rest-api-guidelines/execution/search-requests.md) | ||||
|   * [Query Requests with Large Inputs](rest-api-guidelines/execution/query-requests-with-large-inputs.md) | ||||
| @@ -61,7 +64,7 @@ | ||||
|   * [Loose Coupling](rest-api-guidelines/clients/loose-coupling.md) | ||||
| * [Further References](rest-api-guidelines/miscellaneous.md) | ||||
|  | ||||
| ## Kafka Guidelines | ||||
| ## Asynchronous API Guidelines | ||||
|  | ||||
| * [Introduction](kafka-guidelines/kafka.md) | ||||
| * [Introduction](asynchronous-api-guidelines/asyncapi.md) | ||||
|  | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								adidaslogo.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								adidaslogo.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 12 KiB | 
							
								
								
									
										6
									
								
								asynchronous-api-guidelines/asyncapi.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								asynchronous-api-guidelines/asyncapi.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| # Introduction | ||||
|  | ||||
| ## adidas Asynchronous APIs Guidelines | ||||
|  | ||||
|  | ||||
|  | ||||
| @@ -1,365 +0,0 @@ | ||||
| swagger: '2.0' | ||||
| info: | ||||
|   version: '3.0.0' | ||||
|   title: '[Demo] Orders API' | ||||
|   contact:  | ||||
|     name: Z | ||||
|     email: "z@goodapi.co" | ||||
|   description: | | ||||
|     Sample API conforming to [adidas API Guidelines](https://adidas.gitbook.io/api-guidelines/). | ||||
|  | ||||
| produces: | ||||
|   - application/hal+json      # Representation message format | ||||
|   - application/problem+json  # Error message format | ||||
|  | ||||
| schemes: | ||||
|   - https | ||||
|  | ||||
| host: "example.com" | ||||
|  | ||||
| securityDefinitions: | ||||
|    'API Key': | ||||
|      type: apiKey | ||||
|      in: header | ||||
|      name: x-api-key | ||||
|  | ||||
| security: | ||||
|   - "API Key": [] | ||||
|  | ||||
| paths: | ||||
|   /: | ||||
|     x-summary: API Root | ||||
|  | ||||
|     get: | ||||
|       summary: Retrieve API Root | ||||
|       description: The API Root contains the initial set of link relations. | ||||
|       responses: | ||||
|         200: | ||||
|           description: The root of the API | ||||
|           schema: | ||||
|             allOf: | ||||
|               - $ref: '#/definitions/supermodelIoAdidasApiHAL' | ||||
|             example: | ||||
|               _links: | ||||
|                 self: | ||||
|                   href: / | ||||
|                 orders: | ||||
|                   href: /orders | ||||
|  | ||||
|   /orders: | ||||
|     x-summary: List of Orders | ||||
|  | ||||
|     get: | ||||
|       summary: Retrieve List of Orders | ||||
|       description: Retrieves a list of orders with pagination. | ||||
|       parameters: | ||||
|         - $ref: '#/parameters/offset' | ||||
|         - $ref: '#/parameters/limit' | ||||
|       responses: | ||||
|         200: | ||||
|           description: The list of Orders | ||||
|           schema: | ||||
|             $ref: '#/definitions/supermodelIoAdidasExamplesOrderApiOrders' | ||||
|  | ||||
|     post: | ||||
|       summary: Create a New Order | ||||
|       description: Creates a new order. | ||||
|       consumes: | ||||
|         - application/json | ||||
|       parameters: | ||||
|         - name: Order | ||||
|           in: body | ||||
|           description: Order to be created | ||||
|           required: true | ||||
|           schema: | ||||
|             $ref: '#/definitions/supermodelIoAdidasExamplesOrderOrder' | ||||
|       responses: | ||||
|         201: | ||||
|           description: Newly created order | ||||
|           schema: | ||||
|             $ref: '#/definitions/supermodelIoAdidasExamplesOrderApiOrder' | ||||
|  | ||||
|   /orders/{orderId}: | ||||
|     x-summary: Order | ||||
|  | ||||
|     parameters: | ||||
|       - name: orderId | ||||
|         in: path | ||||
|         description: Id of the Order | ||||
|         required: true | ||||
|         type: string | ||||
|         x-example: '1234' | ||||
|  | ||||
|     get: | ||||
|       summary: Retrieve Order | ||||
|       description: Retrieves an order with specified fields. | ||||
|       parameters: | ||||
|         - $ref: '#/parameters/fields' | ||||
|       responses: | ||||
|         200: | ||||
|           description: A particular Order | ||||
|           schema: | ||||
|             $ref: '#/definitions/supermodelIoAdidasExamplesOrderApiOrder' | ||||
|         404: | ||||
|           description: The request Order wasn't found | ||||
|           headers: | ||||
|             Content-Type: | ||||
|               type: string | ||||
|               default: application/problem+json | ||||
|           schema: | ||||
|             allOf: | ||||
|               - $ref: '#/definitions/supermodelIoAdidasApiProblemDetail' | ||||
|             example: | ||||
|               title: 'Not Found' | ||||
|               detail: 'Cannot find the requested order' | ||||
|               status: 404 | ||||
|               instance: '/orders/1234' | ||||
|  | ||||
|     patch: | ||||
|       summary: Update Order | ||||
|       description: Does a partial update of an order. | ||||
|       consumes: | ||||
|         - application/json | ||||
|       parameters: | ||||
|         - name: Order | ||||
|           in: body | ||||
|           description: Partial order update | ||||
|           required: true | ||||
|           schema: | ||||
|             $ref: '#/definitions/supermodelIoAdidasExamplesOrderApiOrderPatch' | ||||
|       responses: | ||||
|         200: | ||||
|           description: The Order was updated | ||||
|           schema: | ||||
|             $ref: '#/definitions/supermodelIoAdidasExamplesOrderApiOrder' | ||||
|  | ||||
|     delete: | ||||
|       summary: Delete Order | ||||
|       description: Deletes an order without returning its instance. | ||||
|       produces: [] | ||||
|       responses: | ||||
|         204: | ||||
|           description: The Order was deleted | ||||
|  | ||||
| parameters: | ||||
|   # adidas API guidelines: Pagination | ||||
|   offset: | ||||
|     name: offset | ||||
|     in: query | ||||
|     description: Number of results to skip from the start of the list | ||||
|     required: false | ||||
|     type: string | ||||
|     default: '0' | ||||
|     x-example: '10' | ||||
|  | ||||
|   # adidas API guidelines: Pagination | ||||
|   limit: | ||||
|     name: limit | ||||
|     in: query | ||||
|     description: The maximum number of reusults to return | ||||
|     required: false | ||||
|     type: string | ||||
|     default: '10' | ||||
|     x-example: '5' | ||||
|  | ||||
|   # adidas API guidelines: Sparse fieldset | ||||
|   fields: | ||||
|     name: fields | ||||
|     in: query | ||||
|     description: Comma-separated list of fields to include in the response | ||||
|     required: false | ||||
|     type: array | ||||
|     items: | ||||
|       type: string | ||||
|     collectionFormat: csv | ||||
|     x-example: | ||||
|       - articleNumber | ||||
|       - modelNumber | ||||
|  | ||||
|   # adidas API guidelines: Sparse fieldset | ||||
|   embedded: | ||||
|     name: embedded | ||||
|     in: query | ||||
|     description: Comma-separated list of resource (relations) to embed in the response | ||||
|     required: false | ||||
|     type: array | ||||
|     items: | ||||
|       type: string | ||||
|     collectionFormat: csv | ||||
|     x-example: | ||||
|       - prices | ||||
|       - assets | ||||
|  | ||||
| # DO NOT EDIT | ||||
| # This definitions section is automatically generated by supermodel.io | ||||
| # | ||||
| # http://supermodel.io | ||||
| # https://github.com/supermodel/supermodel-cli | ||||
| definitions: | ||||
|   supermodelIoAdidasExamplesOrderApiOrder: | ||||
|     title: Order HAL Representation | ||||
|     type: object | ||||
|     allOf: | ||||
|       - $ref: '#/definitions/supermodelIoAdidasApiHAL' | ||||
|       - $ref: '#/definitions/supermodelIoAdidasExamplesOrderOrder' | ||||
|     example: | ||||
|       _links: | ||||
|         self: | ||||
|           href: /orders/1234 | ||||
|         edit: | ||||
|           href: /orders/1234 | ||||
|         delete: | ||||
|           href: /orders/1234 | ||||
|         profile: | ||||
|           href: 'https://adidas-group.com/gdm/OMS' | ||||
|       orderNumber: 1234 | ||||
|       itemCount: 42 | ||||
|       status: pending | ||||
|   supermodelIoAdidasExamplesOrderApiOrderPatch: | ||||
|     title: OrderPatch | ||||
|     description: OrderPatch model description | ||||
|     type: object | ||||
|     allOf: | ||||
|       - $ref: '#/definitions/supermodelIoAdidasExamplesOrderOrder' | ||||
|     example: | ||||
|       status: cancelled | ||||
|       orderNumber: 1 | ||||
|       itemCount: 2 | ||||
|   supermodelIoAdidasExamplesOrderApiOrders: | ||||
|     title: Collection of Orders HAL Representation | ||||
|     type: object | ||||
|     allOf: | ||||
|       - $ref: '#/definitions/supermodelIoAdidasApiHAL' | ||||
|     example: | ||||
|       _links: | ||||
|         self: | ||||
|           href: /orders | ||||
|         create: | ||||
|           href: /orders | ||||
|         next: | ||||
|           href: /orders?offset=5&limit=5 | ||||
|         first: | ||||
|           href: /orders?offset=0&limit=5 | ||||
|         last: | ||||
|           href: /orders?offset=40&limit=5 | ||||
|       _embedded: | ||||
|         order: | ||||
|           - _links: | ||||
|               self: | ||||
|                 href: /orders/1234 | ||||
|               edit: | ||||
|                 href: /orders/1234 | ||||
|               delete: | ||||
|                 href: /orders/1234 | ||||
|               profile: | ||||
|                 href: 'https://adidas-group.com/gdm/OMS' | ||||
|             orderNumber: 1234 | ||||
|             itemCount: 42 | ||||
|             status: pending | ||||
|   supermodelIoAdidasExamplesOrderApiProblemDetail: | ||||
|     title: Problem Detail | ||||
|     type: object | ||||
|     allOf: | ||||
|       - $ref: '#/definitions/supermodelIoAdidasApiProblemDetail' | ||||
|   supermodelIoAdidasApiHAL: | ||||
|     title: HAL | ||||
|     description: >- | ||||
|       JSON Hypertext Application Language. Definition of [HAL message | ||||
|       format](https://tools.ietf.org/html/draft-kelly-json-hal-08) | ||||
|     type: object | ||||
|     properties: | ||||
|       _links: | ||||
|         type: object | ||||
|         additionalProperties: | ||||
|           allOf: | ||||
|             - $ref: '#/definitions/supermodelIoAdidasApiHALDefinitionsHalLinkObject' | ||||
|             - type: array | ||||
|               items: | ||||
|                 $ref: '#/definitions/supermodelIoAdidasApiHALDefinitionsHalLinkObject' | ||||
|         properties: | ||||
|           curies: | ||||
|             allOf: | ||||
|               - $ref: '#/definitions/supermodelIoAdidasApiHALDefinitionsHalCuriesLink' | ||||
|               - type: array | ||||
|                 items: | ||||
|                   $ref: >- | ||||
|                     #/definitions/supermodelIoAdidasApiHALDefinitionsHalCuriesLink | ||||
|       _embedded: | ||||
|         type: object | ||||
|         additionalProperties: | ||||
|           allOf: | ||||
|             - $ref: '#/definitions/supermodelIoAdidasApiHAL' | ||||
|             - type: array | ||||
|               items: | ||||
|                 $ref: '#/definitions/supermodelIoAdidasApiHAL' | ||||
|   supermodelIoAdidasApiHALDefinitionsHalLinkObject: | ||||
|     title: HAL Link Object | ||||
|     type: object | ||||
|     properties: | ||||
|       href: | ||||
|         type: string | ||||
|       templated: | ||||
|         type: boolean | ||||
|       type: | ||||
|         type: string | ||||
|       deprecation: | ||||
|         type: string | ||||
|       name: | ||||
|         type: string | ||||
|       profile: | ||||
|         type: string | ||||
|       title: | ||||
|         type: string | ||||
|       hreflang: | ||||
|         type: string | ||||
|     required: | ||||
|       - href | ||||
|   supermodelIoAdidasApiHALDefinitionsHalCuriesLink: | ||||
|     title: HAL Curies Link | ||||
|     allOf: | ||||
|       - type: object | ||||
|         properties: | ||||
|           templated: | ||||
|             enum: | ||||
|               - true | ||||
|         required: | ||||
|           - templated | ||||
|       - $ref: '#/definitions/supermodelIoAdidasApiHALDefinitionsHalLinkObject' | ||||
|   supermodelIoAdidasExamplesOrderOrder: | ||||
|     title: Order | ||||
|     type: object | ||||
|     description: Order model description | ||||
|     properties: | ||||
|       orderNumber: | ||||
|         type: number | ||||
|       itemCount: | ||||
|         type: number | ||||
|       status: | ||||
|         type: string | ||||
|     required: | ||||
|       - orderNumber | ||||
|       - itemCount | ||||
|     example: | ||||
|       orderNumber: 42 | ||||
|       itemCount: 3 | ||||
|       status: pending | ||||
|   supermodelIoAdidasApiProblemDetail: | ||||
|     title: Problem Details for HTTP APIs | ||||
|     description: >- | ||||
|       Definition of [RFC7807](https://tools.ietf.org/html/rfc7807) problem | ||||
|       detail | ||||
|     type: object | ||||
|     properties: | ||||
|       type: | ||||
|         type: string | ||||
|       title: | ||||
|         type: string | ||||
|       status: | ||||
|         type: number | ||||
|       detail: | ||||
|         type: string | ||||
|       instance: | ||||
|         type: string | ||||
|     required: | ||||
|       - title | ||||
|       - detail | ||||
| @@ -1,158 +1,164 @@ | ||||
| openapi: "3.0.0" | ||||
| info: | ||||
|   version: 1.0.0 | ||||
|   title: Swagger Petstore | ||||
|   description: A sample API that uses a petstore as an example to demonstrate features in the OpenAPI 3.0 specification | ||||
|   termsOfService: http://swagger.io/terms/ | ||||
|   contact: | ||||
|     name: Swagger API Team | ||||
|     email: apiteam@swagger.io | ||||
|     url: http://swagger.io | ||||
|   license: | ||||
|     name: Apache 2.0 | ||||
|     url: https://www.apache.org/licenses/LICENSE-2.0.html | ||||
| servers: | ||||
|   - url: http://petstore.swagger.io/api | ||||
| paths: | ||||
|   /pets: | ||||
|     get: | ||||
|       description: | | ||||
|         Returns all pets from the system that the user has access to | ||||
|         Nam sed condimentum est. Maecenas tempor sagittis sapien, nec rhoncus sem sagittis sit amet. Aenean at gravida augue, ac iaculis sem. Curabitur odio lorem, ornare eget elementum nec, cursus id lectus. Duis mi turpis, pulvinar ac eros ac, tincidunt varius justo. In hac habitasse platea dictumst. Integer at adipiscing ante, a sagittis ligula. Aenean pharetra tempor ante molestie imperdiet. Vivamus id aliquam diam. Cras quis velit non tortor eleifend sagittis. Praesent at enim pharetra urna volutpat venenatis eget eget mauris. In eleifend fermentum facilisis. Praesent enim enim, gravida ac sodales sed, placerat id erat. Suspendisse lacus dolor, consectetur non augue vel, vehicula interdum libero. Morbi euismod sagittis libero sed lacinia. | ||||
| 
 | ||||
|         Sed tempus felis lobortis leo pulvinar rutrum. Nam mattis velit nisl, eu condimentum ligula luctus nec. Phasellus semper velit eget aliquet faucibus. In a mattis elit. Phasellus vel urna viverra, condimentum lorem id, rhoncus nibh. Ut pellentesque posuere elementum. Sed a varius odio. Morbi rhoncus ligula libero, vel eleifend nunc tristique vitae. Fusce et sem dui. Aenean nec scelerisque tortor. Fusce malesuada accumsan magna vel tempus. Quisque mollis felis eu dolor tristique, sit amet auctor felis gravida. Sed libero lorem, molestie sed nisl in, accumsan tempor nisi. Fusce sollicitudin massa ut lacinia mattis. Sed vel eleifend lorem. Pellentesque vitae felis pretium, pulvinar elit eu, euismod sapien. | ||||
|       operationId: findPets | ||||
|       parameters: | ||||
|         - name: tags | ||||
|           in: query | ||||
|           description: tags to filter by | ||||
|           required: false | ||||
|           style: form | ||||
|           schema: | ||||
|             type: array | ||||
|             items: | ||||
|               type: string | ||||
|         - name: limit | ||||
|           in: query | ||||
|           description: maximum number of results to return | ||||
|           required: false | ||||
|           schema: | ||||
|             type: integer | ||||
|             format: int32 | ||||
|       responses: | ||||
|         '200': | ||||
|           description: pet response | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 type: array | ||||
|                 items: | ||||
|                   $ref: '#/components/schemas/Pet' | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
|     post: | ||||
|       description: Creates a new pet in the store.  Duplicates are allowed | ||||
|       operationId: addPet | ||||
|       requestBody: | ||||
|         description: Pet to add to the store | ||||
|         required: true | ||||
|         content: | ||||
|           application/json: | ||||
|             schema: | ||||
|               $ref: '#/components/schemas/NewPet' | ||||
|       responses: | ||||
|         '200': | ||||
|           description: pet response | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Pet' | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
|   /pets/{id}: | ||||
|     get: | ||||
|       description: Returns a user based on a single ID, if the user does not have access to the pet | ||||
|       operationId: find pet by id | ||||
|       parameters: | ||||
|         - name: id | ||||
|           in: path | ||||
|           description: ID of pet to fetch | ||||
|           required: true | ||||
|           schema: | ||||
|             type: integer | ||||
|             format: int64 | ||||
|       responses: | ||||
|         '200': | ||||
|           description: pet response | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Pet' | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
|     delete: | ||||
|       description: deletes a single pet based on the ID supplied | ||||
|       operationId: deletePet | ||||
|       parameters: | ||||
|         - name: id | ||||
|           in: path | ||||
|           description: ID of pet to delete | ||||
|           required: true | ||||
|           schema: | ||||
|             type: integer | ||||
|             format: int64 | ||||
|       responses: | ||||
|         '204': | ||||
|           description: pet deleted | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
| components: | ||||
|   schemas: | ||||
|     Pet: | ||||
|       allOf: | ||||
|         - $ref: '#/components/schemas/NewPet' | ||||
|         - type: object | ||||
|           required: | ||||
|           - id | ||||
|           properties: | ||||
|             id: | ||||
|               type: integer | ||||
|               format: int64 | ||||
| 
 | ||||
|     NewPet: | ||||
|       type: object | ||||
|       required: | ||||
|         - name   | ||||
|       properties: | ||||
|         name: | ||||
|           type: string | ||||
|         tag: | ||||
|           type: string     | ||||
| 
 | ||||
|     Error: | ||||
|       type: object | ||||
|       required: | ||||
|         - code | ||||
|         - message | ||||
|       properties: | ||||
|         code: | ||||
|           type: integer | ||||
|           format: int32 | ||||
|         message: | ||||
|           type: string | ||||
| openapi: "3.0.0" | ||||
| info: | ||||
|   version: 1.0.0 | ||||
|   title: Swagger Petstore | ||||
|   description: A sample API that uses a petstore as an example to demonstrate features in the OpenAPI 3.0 specification | ||||
|   termsOfService: http://swagger.io/terms/ | ||||
|   contact: | ||||
|     name: Swagger API Team | ||||
|     email: apiteam@swagger.io | ||||
|     url: http://swagger.io | ||||
|   license: | ||||
|     name: Apache 2.0 | ||||
|     url: https://www.apache.org/licenses/LICENSE-2.0.html | ||||
| servers: | ||||
|   - url: http://petstore.swagger.io/api | ||||
| paths: | ||||
|   /pets: | ||||
|     get: | ||||
|       tags: [] | ||||
|       description: | | ||||
|         Returns all pets from the system that the user has access to | ||||
|         Nam sed condimentum est. Maecenas tempor sagittis sapien, nec rhoncus sem sagittis sit amet. Aenean at gravida augue, ac iaculis sem. Curabitur odio lorem, ornare eget elementum nec, cursus id lectus. Duis mi turpis, pulvinar ac eros ac, tincidunt varius justo. In hac habitasse platea dictumst. Integer at adipiscing ante, a sagittis ligula. Aenean pharetra tempor ante molestie imperdiet. Vivamus id aliquam diam. Cras quis velit non tortor eleifend sagittis. Praesent at enim pharetra urna volutpat venenatis eget eget mauris. In eleifend fermentum facilisis. Praesent enim enim, gravida ac sodales sed, placerat id erat. Suspendisse lacus dolor, consectetur non augue vel, vehicula interdum libero. Morbi euismod sagittis libero sed lacinia. | ||||
| 
 | ||||
|         Sed tempus felis lobortis leo pulvinar rutrum. Nam mattis velit nisl, eu condimentum ligula luctus nec. Phasellus semper velit eget aliquet faucibus. In a mattis elit. Phasellus vel urna viverra, condimentum lorem id, rhoncus nibh. Ut pellentesque posuere elementum. Sed a varius odio. Morbi rhoncus ligula libero, vel eleifend nunc tristique vitae. Fusce et sem dui. Aenean nec scelerisque tortor. Fusce malesuada accumsan magna vel tempus. Quisque mollis felis eu dolor tristique, sit amet auctor felis gravida. Sed libero lorem, molestie sed nisl in, accumsan tempor nisi. Fusce sollicitudin massa ut lacinia mattis. Sed vel eleifend lorem. Pellentesque vitae felis pretium, pulvinar elit eu, euismod sapien. | ||||
|       operationId: findPets | ||||
|       parameters: | ||||
|         - name: tags | ||||
|           in: query | ||||
|           description: tags to filter by | ||||
|           required: false | ||||
|           style: form | ||||
|           schema: | ||||
|             type: array | ||||
|             items: | ||||
|               type: string | ||||
|         - name: limit | ||||
|           in: query | ||||
|           description: maximum number of results to return | ||||
|           required: false | ||||
|           schema: | ||||
|             type: integer | ||||
|             format: int32 | ||||
|       responses: | ||||
|         '200': | ||||
|           description: pet response | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 type: array | ||||
|                 items: | ||||
|                   $ref: '#/components/schemas/Pet' | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
|     post: | ||||
|       tags: [] | ||||
|       description: Creates a new pet in the store.  Duplicates are allowed | ||||
|       operationId: addPet | ||||
|       requestBody: | ||||
|         description: Pet to add to the store | ||||
|         required: true | ||||
|         content: | ||||
|           application/json: | ||||
|             schema: | ||||
|               $ref: '#/components/schemas/NewPet' | ||||
|       responses: | ||||
|         '200': | ||||
|           description: pet response | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Pet' | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
|   /pets/{id}: | ||||
|     get: | ||||
|       tags: [] | ||||
|       description: Returns a user based on a single ID, if the user does not have access to the pet | ||||
|       operationId: getPetById | ||||
|       parameters: | ||||
|         - name: id | ||||
|           in: path | ||||
|           description: ID of pet to fetch | ||||
|           required: true | ||||
|           schema: | ||||
|             type: integer | ||||
|             format: int64 | ||||
|       responses: | ||||
|         '200': | ||||
|           description: pet response | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Pet' | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
|     delete: | ||||
|       tags: [] | ||||
|       description: deletes a single pet based on the ID supplied | ||||
|       operationId: deletePet | ||||
|       parameters: | ||||
|         - name: id | ||||
|           in: path | ||||
|           description: ID of pet to delete | ||||
|           required: true | ||||
|           schema: | ||||
|             type: integer | ||||
|             format: int64 | ||||
|       responses: | ||||
|         '204': | ||||
|           description: pet deleted | ||||
|         default: | ||||
|           description: unexpected error | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 $ref: '#/components/schemas/Error' | ||||
| components: | ||||
|   schemas: | ||||
|     Pet: | ||||
|       allOf: | ||||
|         - $ref: '#/components/schemas/NewPet' | ||||
|         - type: object | ||||
|           required: | ||||
|           - id | ||||
|           properties: | ||||
|             id: | ||||
|               type: integer | ||||
|               format: int64 | ||||
| 
 | ||||
|     NewPet: | ||||
|       type: object | ||||
|       required: | ||||
|         - name   | ||||
|       properties: | ||||
|         name: | ||||
|           type: string | ||||
|         tag: | ||||
|           type: string     | ||||
| 
 | ||||
|     Error: | ||||
|       type: object | ||||
|       required: | ||||
|         - code | ||||
|         - message | ||||
|       properties: | ||||
|         code: | ||||
|           type: integer | ||||
|           format: int32 | ||||
|         message: | ||||
|           type: string | ||||
| tags: | ||||
| - name: test | ||||
| @@ -9,3 +9,7 @@ Any JSON-based message **MUST** conform to the following rules: | ||||
| 5. Empty arrays and objects **SHOULD NOT**  be `null` \(use `[]` or `{}` instead\) | ||||
| 6. Array field names **SHOULD** be plural \(e.g. `"orders": []`\) | ||||
|  | ||||
| ## Validation | ||||
| All API designers **MUST** validate the definition of the payloads in requests/responses with the [JSON Schema](https://json-schema.org/) for the defined structure prior to the publication of the API Contract in SwaggerHub. | ||||
|  | ||||
| The publication of the JSON schema corresponding to the expected payloads in the bodies of requests and responses **SHOULD** be kept up to date according to the evolution of the API.  | ||||
|   | ||||
| @@ -1,6 +0,0 @@ | ||||
| # Introduction | ||||
|  | ||||
| ## adidas Kafka Guidelines | ||||
|  | ||||
|  | ||||
|  | ||||
| @@ -1,6 +1,6 @@ | ||||
| # API Design Platform | ||||
|  | ||||
| 1. [SwaggerHub](https://swagger.io/tools/swaggerhub/) is the primary platform supporting [API first approach](../../general-guidelines/api-first.md). SwaggerHub **SHOULD** be used during API Design. | ||||
| 1. [SwaggerHub](https://design.api.3stripes.io/) is the primary platform supporting [API first approach](../../general-guidelines/api-first.md). SwaggerHub **MUST** be used during API Design. | ||||
| 2. Every API description **MUST** be stored in [SwaggerHub](https://design.api.3stripes.io/) under the adidas team. | ||||
| 3. SwaggerHub **MUST** be the **single source of truth** to learn about existing APIs within the organization. | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| # OpenAPI Specification | ||||
|  | ||||
| Every API **MUST** be described using an API description format. The API description format used MUST be the [OpenAPI Specification \(formerly known as Swagger Specification\) version 2.0](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/2.0.md). | ||||
| Every API **MUST** be described using an API description format. The API description format used MUST be the [OpenAPI Specification \(formerly known as Swagger Specification\) version 2.0](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/2.0.md) OR the[OpenAPI Specification \(formerly known as Swagger Specification\) version 3.0.x](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.3.md). | ||||
|  | ||||
| Every API description **MUST** be published in adidas [API design platform](design-platform.md) and it **SHOULD** be stored in version control system \(Bitbucket, GitHub\) in the same repository as the API implementation. | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| ## Processing Similar Resources | ||||
|  | ||||
| An operation that needs to process several related resources in bulk **SHOULD** use a collection resource with the appropriate HTTP Request Method. When processing existing resource the request message body **MUST** contain the URLs of the respective resources being processed. | ||||
| An operation that needs to process several related resources in bulk **SHOULD** uses a collection resource with the appropriate HTTP Request Method. When processing existing resource the request message body **MUST** contain the URLs of the respective resources being processed. | ||||
|  | ||||
| ### Example | ||||
|  | ||||
|   | ||||
| @@ -1,43 +1,88 @@ | ||||
| # Caching | ||||
|  | ||||
| Every API implementation **SHOULD** return both the cache expiry information \([`Cache-Control` HTTP header](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control)\) and specific resource version information \([`ETag` HTTP Header](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/ETag)\). | ||||
| > From an architectural point of view, the API cache strategy can be defined at two main levels:  | ||||
| >  | ||||
| > - Backend service | ||||
| > - API Gateway.  | ||||
| >  | ||||
| > These guidelines handle the cache strategy in the backend service as part of the API implementation. Please consider additional cache settings to be defined in the **API Gateway** can  dramatically improve the performance and API consumer experience but they have to be defined in a specific way in the adidas product. | ||||
|  | ||||
| ## Cache-Control | ||||
| As a general rule, every API implementation **SHOULD** return both the cache expiry information \([`Cache-Control` HTTP header](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control)\) and specific resource version information \([`ETag` HTTP Header](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/ETag)\). | ||||
|  | ||||
|  | ||||
| ## Cache-Control  | ||||
|  | ||||
| Every API implementation's response **SHOULD** include information about cache-ability and cache expiration of the response. For HTTP 1.1 this is achieved using the `Cache-Control` header. | ||||
|  | ||||
|  | ||||
| ### Settings | ||||
|  | ||||
| #### adidas API Gateway | ||||
| The configuration of cache in the adidas API Gateway is mainly based on: | ||||
|  | ||||
| - Cacheable HTTP methods | ||||
| - When to cache. Response content types, headers to be considered for the cache key, relevant query parameters, etc. | ||||
| - Expiration time, meaning the number of seconds to keep resources in the storage backend. | ||||
| - Strategy. This means, which is the backing data store in which to hold cache entities. The only accepted value is `memory` for now. | ||||
|  | ||||
| > A complete reference for configuration can be seen [here](https://docs.konghq.com/hub/kong-inc/proxy-cache/). | ||||
|  | ||||
| #### API Consumer | ||||
| Clients **SHOULD** be capable of using `max-age` and `max-stale` headers to exclude the entity from being cached entirely or request stale copies of data if necessary. | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Common Cache-Control Scenarios | ||||
|  | ||||
| Two, most common scenarios for controlling the cache-ability of a response includes \(1\) Setting expiration and revalidation and \(2\) disabling the caching of a response. Refer to the [Cache-Control Documentation](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control) for additional controls. | ||||
| Most common scenarios for controlling the cache-ability of a response includes: | ||||
|  | ||||
| 1. Setting expiration and revalidation. | ||||
| 2. Disabling the caching of a response. Refer to the [Cache-Control Documentation](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control) for additional information. | ||||
|  | ||||
| > Remember the adidas **API Gateway** identifies the status of the request’s proxy cache behavior via the `X-Cache-Status` header. There are several possible values for this header: | ||||
|  | ||||
| > - `Miss` The request could be satisfied in cache, but an entry for the resource was not found in cache, and the request was proxied upstream. | ||||
| > - `Hit` The request was satisfied and served from cache. | ||||
| > - `Refresh` The resource was found in cache, but could not satisfy the request, due to Cache-Control behaviors or reaching its hard-coded cache_ttl threshold. | ||||
| > - `Bypass` The request could not be satisfied from cache based on plugin configuration. | ||||
|  | ||||
| #### 1. Cache Expiration & Revalidation | ||||
| You **SHOULD** define the expiration time and the case for revalidation in your API. | ||||
|  | ||||
| The common scenario to set cache expiration and revalidation policy is to use the `max-age` and `must-revalidate` directives: | ||||
| `max-age` is the oldest that a response can be, as long as the Cache-Control from the origin server indicates that it is still fresh. The value means seconds. | ||||
|  | ||||
| > **API Consumer Notes** | ||||
|  | ||||
| > Remember an API consumer's request **MAY** specify the **maximum age** (`max-age`) it is willing to accept an unvalidated response; specifying a value of zero forces the cache to revalidate all responses. A client MAY also specify the minimum time remaining before a response expires. (Reference)[https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html]. | ||||
|  | ||||
| > An API consumer **MAY** also specify that it will accept **stale responses**, up to some maximum amount of staleness. API consumers can cache a resource but must revalidate each time before using it. This means HTTP request occurs each time though, it can skip downloading HTTP body if the content is valid. (Reference)[https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html]. | ||||
|  | ||||
| From the semantic point of view `no-cache` and `max-age=0`, `must-revalidate` indicates same meaning: The backend service has to be contacted to get a stale result. | ||||
|  | ||||
| The common scenario to set cache expiration and revalidation policy is to use the `max-age`, `must-revalidate` or `max-age` as part of the `Cache-Control` directives. | ||||
|  | ||||
| The `max-age` directive states the maximum amount of time in seconds that fetched responses are allowed to be used again. For instance, `max-age=300` indicates that an asset can be reused (remains in the browser cache) for the next 5 minutes. For instance: | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 200 OK | ||||
| Date: Mon, 19 Aug 2017 00:00:00 CEST | ||||
| Last-Modified: Mon, 19 Aug 2017 00:00:00 CEST | ||||
| Cache-Control: max-age=3600,must-revalidate | ||||
| Content-Type: application/hal+json; charset=UTF-8 | ||||
| Cache-Control: max-age=300 | ||||
| ``` | ||||
|  | ||||
| ... | ||||
| The `must-revalidate` directive is used to tell a cache that it must first revalidate an asset with the origin after it becomes stale. The asset must not be delivered to the client without doing revalidation against the backend service. In short, stale assets must first be verified and expired assets should not be used. For instance: | ||||
|  | ||||
| ```text | ||||
| Cache-Control: must-revalidate | ||||
| ``` | ||||
|  | ||||
| #### 2. Disabling Cache | ||||
|  | ||||
| To disable caching completely API implementation **SHOULD** use the `no-cache` and `no-store` directives: | ||||
| The `no-cache` directive shows that returned responses can't be used for subsequent requests to the same URL before checking if server responses have changed. If a proper ETag (identity of the specific version of the returned resource) is present as a result, no-cache incurs a roundtrip in an effort to validate cached responses. | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 200 OK | ||||
| Date: Mon, 19 Aug 2017 00:00:00 CEST | ||||
| Last-Modified: Mon, 19 Aug 2017 00:00:00 CEST | ||||
| Cache-Control: no-cache, no-store, must-revalidate | ||||
| Content-Type: application/hal+json; charset=UTF-8 | ||||
|  | ||||
| ... | ||||
| Cache-Control: no-cache | ||||
| ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| ## ETag | ||||
|  | ||||
| Every API implementation's response to a [cacheable request](https://github.com/for-GET/know-your-http-well/blob/master/methods.md#cacheable) **SHOULD** include the [`ETag` HTTP Header](https://tools.ietf.org/html/rfc7232#section-2.3) to identify the specific version of the returned resource. | ||||
|   | ||||
							
								
								
									
										10
									
								
								rest-api-guidelines/execution/long-running-tasks/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								rest-api-guidelines/execution/long-running-tasks/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| # Long Running Tasks | ||||
|  | ||||
| This section includes the recommended approaches to handling long running tasks (LRTs) in REST APIs.  | ||||
|  | ||||
| You can identify a LRT quite easily. The main factor to consider are the metrics from latency of the endpoint. If it requiress tens of seconds even minutes we are facing a problem related to LRTs. | ||||
|  | ||||
| LRTs cannot be handled in a regular straight synchronous call. The amount of commited recources at the network, client and server levels are huge when connections are blocked for several minutes.   | ||||
|  | ||||
| It is strongly recommended to follow a non-blocking solution as it is proposed in this section. | ||||
|  | ||||
							
								
								
									
										136
									
								
								rest-api-guidelines/execution/long-running-tasks/callback.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								rest-api-guidelines/execution/long-running-tasks/callback.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | ||||
| # Callback | ||||
|  | ||||
| Callback or Webhooks are another way of handling long running tasks (LRTs). Callbacks are based on the subscription principle, whereas the API notifies the API Consumer in a different connection. This pattern is also applicable to the subscription to any kind of events to get notifications from your API. | ||||
|  | ||||
| The roles are: | ||||
|  | ||||
| - API Consumer / Subscriber | ||||
| - API Producer / Publisher | ||||
|  | ||||
| If the chosen way is based on using callbacks, the response to such an asynchronous operation **MUST** return, in the case of success, the **202 Accepted** status code together with an `application/hal+json` representation of a new **task-tracking resource**. | ||||
|  | ||||
| > This pattern is described by [OAS v3.0.x](https://swagger.io/docs/specification/callbacks/). | ||||
|  | ||||
|  | ||||
| ## Subscription | ||||
|  | ||||
| The subscriber enrolls to specfic notifications. The subscriber resource **MUST** provide the information about the callback URL. Any data needed to require the execution of a task **MUST** be included in the request body. | ||||
|  | ||||
| The subscription is created by using the HTTP POST Request Method. It **SHOULD** be designed as follows: | ||||
|  | ||||
| 1. Subscription is accepted | ||||
|  | ||||
|    Return **201 Created** and representation of the current status. Content type: `application/hal+json` | ||||
|    The publisher resource **MUST** provide a UUID to identify the subscription. | ||||
|  | ||||
| 2. Subscription is not accepted | ||||
|  | ||||
|    Return **403 Forbidden** . Content type: `application/problem+json` with the problem detail information. | ||||
|  | ||||
|  | ||||
| ## Notification | ||||
|  | ||||
| The publisher resource **MUST** use callback URL provided by the subscriber. Any data with the output of the requested task **SHOULD** be sent to the subscriber in this request. | ||||
|  | ||||
| The callback request has to use the HTTP POST Request Method **SHOULD** as follows: | ||||
|  | ||||
| 1. The subscriber accepts the callback. Content type: `application/hal+json` | ||||
|  | ||||
|    Return **200 OK**. | ||||
|  | ||||
| 2. The subscriber does not accept the callback | ||||
|  | ||||
|    Return **403 Forbidden** . Content type: `application/problem+json` with the problem detail information. | ||||
|  | ||||
|  | ||||
| ## Cancel Subscription | ||||
|  | ||||
| The subscriber resource **MUST**  include the UUID to identify the subscription. | ||||
|  | ||||
| It has to be used the HTTP PUT Request Method **SHOULD** as follows: | ||||
|  | ||||
| 1. Subscription is accepted | ||||
|  | ||||
|    Return **202 Accepted**. Content type: `application/hal+json` | ||||
|  | ||||
| 2. Subscription is not accepted | ||||
|  | ||||
|    Return **403 Forbidden** . Content type: `application/problem+json` with the problem detail information. | ||||
|  | ||||
|  | ||||
| ## Design Note | ||||
|  | ||||
| - The subscription pattern supports two main approaches: | ||||
|   - On one side, it can be **only-once**. The callback will be invoked only once by the publisher and it will be cancelled automatically after. | ||||
|   - On the other side, it can be **continuous**. In this case the subscription **MUST** be explicitly cancelled. Regarding the subscriber, its API is also the subject of the adidas API guidelines. | ||||
|  | ||||
| - The callback can be based on an Asynchronous/Streaming API topic. In this case the subscription is made as mentioned above but with the following differences in the workflow: | ||||
|   - The API Consumer does not send a callback URL in the initial request. | ||||
|   - The API Producer **SHOULD** provide the name of the topic and the UID of the task to correlate the input.  | ||||
|   - It is up to the API Consumer to subscribe to the Asynchronous/Streaming API topic to receive the input from the provider. Please read the Asynchronous/Streaming API section. | ||||
|  | ||||
| ### Example | ||||
|  | ||||
| 1. **Settle the subscription** | ||||
|    | ||||
|     ``` | ||||
|     POST /items/tasks/ HTTP/1.1 | ||||
|     Content-Type: application/json | ||||
|  | ||||
|     { | ||||
|       "callbackUrl": "https://myserver.com/send/callback/here" | ||||
|     } | ||||
|  | ||||
|     ... | ||||
|  | ||||
|     HTTP/1.1 201 Created | ||||
|     Content-Type: application/hal+json | ||||
|  | ||||
|     { | ||||
|       "_links": { | ||||
|         "self": { "href": "/items/tasks/4746" } | ||||
|       }, | ||||
|       "message": "Your request to subscribe to the progress of the task has been accepted.", | ||||
|       "UUID": "4746" | ||||
|     } | ||||
|     ``` | ||||
|  | ||||
| 2. **The Publisher sends the callback** | ||||
|  | ||||
|     ``` | ||||
|     POST https://myserver.com/send/callback/here HTTP/1.1 | ||||
|  | ||||
|     { | ||||
|       "_links": { | ||||
|         "self": { "href": "/items/tasks/4746" } | ||||
|       }, | ||||
|       "UUID": "4746", | ||||
|       { | ||||
|         <Data with the callback> | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     ... | ||||
|  | ||||
|     HTTP/1.1 200 Ok | ||||
|     Content-Type: application/hal+json | ||||
|  | ||||
|     ``` | ||||
|  | ||||
| 3. **Eventually the subscriber cancels the subscription** | ||||
|  | ||||
|     ``` | ||||
|     PUT /feeds/tasks/1 HTTP/1.1 | ||||
|     ... | ||||
|  | ||||
|     HTTP/1.1 202 Accepted | ||||
|     Content-Type: application/hal+json | ||||
|  | ||||
|     { | ||||
|       "_links": { | ||||
|         "self": { "href": "/feeds/tasks/4746" } | ||||
|       }, | ||||
|       "message": "Your subscription is cancelled." | ||||
|     } | ||||
|     ``` | ||||
|  | ||||
| @@ -0,0 +1,82 @@ | ||||
| # Files Upload | ||||
|  | ||||
| The upload of files using a REST API endpoint is a common practice. It implies certain concerns taht have to be addressed in the design phase of the API. | ||||
|  | ||||
| The API Consumer performs a key role in this case. The MIME type in the Content-Type header of the request is an important factor for a successful operation. An operation that needs to upload binary files **SHOULD** uses a collection resource with the POST HTTP Request Method. When processing an existing resource the request message body **MUST** contain the right MIME type of the resources being processed. | ||||
|  | ||||
|  | ||||
| ## Main Issues | ||||
|  | ||||
| - Too long time periods in timeout settings, blocking open HTTP connections for too long. It makes the API less reliable and more error-prone as it is more vulnerable to network-related issues.  | ||||
| - Interrupted connections that can result into corrupted files and false response status to the API Consumer. | ||||
| - No size limit in server can suppose an unacceptable load to the API operation in terms of resources, security and robustness as well as a huge increase in operational cost. | ||||
|  | ||||
| ## Checklist in File Upload Operations | ||||
|  | ||||
| ### Use the right MIME Type in the API Consumer Side | ||||
|  | ||||
| It is a common practice to use  | ||||
| [IANA](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types) distinguishes between two main generic types, **discrete** and **multipart**: | ||||
|  | ||||
| - Discrete types are types which represent a single file or medium, such as a single text, video, or music file. | ||||
| - Multipart type represents a document that is comprised of multiple component parts, each of which may have its own individual MIME type. It can also encapsulate multiple files being sent together in one single transaction.  | ||||
|  | ||||
| #### Using a Multipart Type | ||||
|  | ||||
| - multipart/form-data | ||||
| - multipart/byteranges | ||||
|  | ||||
| Frameworks like Spring offfer support for multipart files sending like the [MultipartFile](https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/web/multipart/MultipartFile.html) interface. | ||||
|  | ||||
| #### Using a Discrete Type | ||||
| It is recommended to upload the file alone, with no other content in the request. This approach allows to include the MIME type corresponding to the specific type of file. For instance: | ||||
|  | ||||
| - Graphical file -> image/jpeg, image/gif, image/bmp, etc. | ||||
| - Data file -> text/csv,  | ||||
| - Text file -> text/plain | ||||
| - PDF -> application/pdf | ||||
| etc. | ||||
|  | ||||
| It is also recommended to compress the file to be uploaded, then using these MIM types (examples): | ||||
|  | ||||
|  - gzip -> application/gzip | ||||
|  - zip -> application/zip | ||||
|  - 7z -> application/x-7z-compressed | ||||
|  - tar -> application/x-tar | ||||
|  etc. | ||||
|  | ||||
| > You can find a complete reference about the MIME types [here](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types). | ||||
|  | ||||
| ### Set Maximum Size Limit in the API Producer Side | ||||
|  | ||||
| The maximum size of the whole file **MUST** be set for the given endpoint/s in the APi upstream/backend service side. | ||||
|  | ||||
| The maximum size value depends on the use case and the expected payload in upload requests. | ||||
|  | ||||
| The settings **MUST** included in the upstream/backend service as a part of the configuration. | ||||
|  | ||||
| Otherwise, the API Gateway (Kong) **COULD** be configured enabling a maximum size of the payload for specific endpoint/s. | ||||
|  | ||||
| Frameworks like Spring includes configuration settings for multipart file uploading. The operation **SHOULD** be constrained as follows: | ||||
|  | ||||
| ``` | ||||
| spring.servlet.multipart.enabled=true # enables multipart uploads | ||||
| spring.servlet.multipart.file-size-threshold=2KB  # the threshold after which files are written to disk. | ||||
| spring.http.multipart.max-file-size=128KB  # the total file size cannot exceed the amount o. | ||||
| spring.http.multipart.max-request-size=128KB # the total request size for a multipart/form-data cannot exceed 128KB. | ||||
| ``` | ||||
|  | ||||
|  | ||||
| ### Configure Properly all the Components | ||||
|  | ||||
| Load tests should give you metrics about the average latency of the operations. Use these metrics to calcuate the best value for the timeout settings in the upstream/backend service. | ||||
|  | ||||
| The API Gateway timeout settings have to be considered for the expected timeout values, aligned with the values in the upstream/backend service. Al other components in the infrastructure **MUST** be considered for the calculation of the final metrics. | ||||
| git commit  | ||||
| ``` | ||||
| |API Consumer/Client Timeout| --->  |External Load Balancer|  ---> |API Gateway Timeout|  --->  |Internal Load Balancer|   ---> |Upstream/Backend Service Tiemout| | ||||
| ``` | ||||
|  | ||||
| The approach based on too long timeout values is not acceptable. You **MUST** follow a fast-fail approach with a expected duration of the upload. If this time is exceeded a timeout error **SHOULD** be sent to the API Consumer. The maximum size limit **SHOULD** be consistent with the timeout value. | ||||
|  | ||||
| > Please also consider the client and API Gateway Timeout settings. In this case the lack of retrieval of a response during a too long upload operation can trigger a timeout error. | ||||
| @@ -1,6 +1,6 @@ | ||||
| # Asynchronous Tasks | ||||
| # Polling | ||||
| 
 | ||||
| If an API operation is asynchronous, but a client could track its progress, the response to such an asynchronous operation **MUST** return, in the case of success, the **202 Accepted** status code together with an `application/hal+json` representation of a new **task-tracking resource**. | ||||
| If an API operation can be considered as a long running task and the API Consumer can track its progress, the response to the LRT **MUST** return, in the case of success, the **202 Accepted** status code together with an `application/hal+json` representation of a new **task-tracking resource**. | ||||
| 
 | ||||
| ## Task Tracking Resource | ||||
| 
 | ||||
| @@ -22,13 +22,16 @@ Retrieval of such a resource using the HTTP GET Request Method **SHOULD** be des | ||||
| 
 | ||||
| ## Design Note | ||||
| 
 | ||||
| The asynchronous operation task-tracking resource can be either **polled** by client or the client might initially provide a **callback** to be executed when the operation finishes. | ||||
| The polling (task-tracking) operation requires a clear adaptation on the API Consumer side: | ||||
| 
 | ||||
| - Polling requests frequency depend on the type of operation and specific latency of thre resource. | ||||
| - The identification of the resource has to be correlated along the series of polling requests. The API Consumer has to be able to save this ID and the API Producer has to be able to identify the progress of the operation with that ID.  | ||||
| - A security problem can be raised if a non-authorized client retrieves the response for a different resource ID. The authorization data and tasks in progress have to be strongly correlated and controlled to avoid consistency issues. | ||||
| 
 | ||||
| In the case of callback, the API and its client MUST agree on what HTTP method and request format is used for the callback invitation. If built within adidas, the "client" API is also the subject of the adidas API guidelines. | ||||
| 
 | ||||
| ### Example | ||||
| 
 | ||||
| 1. **Initiate the asynchronous task** | ||||
| 1. **Initiate the polling task** | ||||
|    | ||||
|     ``` | ||||
|     POST /feeds/tasks/ HTTP/1.1 | ||||
| @@ -1,69 +1,43 @@ | ||||
| # Rate Limiting | ||||
|  | ||||
| The API rate limiting is provided by the selected adidas API management platform – Mashery. | ||||
| Rate limit means how many HTTP requests can be made in a given period of time. | ||||
|  | ||||
| Rate limit information is provided in the for of HTTP headers. There are two types of rate limits: **Quota** and **Throttle**. The quota is a limit enforced per a longer period \(typically a day\). The throttle is the limit of calls per second. | ||||
| The API rate limiting is provided by the selected adidas API Gateway – [Kong](https://konghq.com/kong/). It can be applied to 1 or more endpoints or to the whole API. | ||||
|  | ||||
| ## Quota Limit | ||||
| Rate limit information is provided in the for of HTTP headers. | ||||
|  | ||||
| The limit on the number of calls per a period \(day\). The default quota limit is 5000 calls per day. | ||||
| ## Settings (adidas API Gateway) | ||||
|  | ||||
| ### Example | ||||
| The limit on the number of calls per a time period \(second, minute, hour, day, month, year\). The configuration settings have to be obtained from the Non-Functional Requirements of the API to be included as part of the settings of the API Gateway. | ||||
|  | ||||
| Example response to a request over the quota limit: | ||||
| A complete reference for configuration can be seen [here](https://adidas.gitbook.io/api-guidelines/rest-api-guidelines/execution/rate-limiting). | ||||
|  | ||||
|  | ||||
| ## Rate Limit | ||||
|  | ||||
| When this feature is enabled, the API Gateway will send some additional headers back to the client telling what are the limits allowed, how many requests are available and how long it will take until the quota will be restored. For instance (successful response): | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 403 Forbidden | ||||
| Content-Type: application/problem+json | ||||
|  | ||||
| X-Error-Detail-Header: Account Over Rate Limit | ||||
| X-Mashery-Error-Code: ERR_403_DEVELOPER_OVER_RATE | ||||
|  | ||||
| { | ||||
|   "title": "Rate Limit Exceeded", | ||||
|   "detail": "Account Over Rate Limit" | ||||
| } | ||||
| RateLimit-Limit: 6 | ||||
| RateLimit-Remaining: 4 | ||||
| RateLimit-Reset: 47 | ||||
| X-RateLimit-Limit-Minute: 10 | ||||
| X-RateLimit-Remaining-Minute: 9 | ||||
| ``` | ||||
|  | ||||
| ## Throttle Limit | ||||
| ## Rate Limit Exceeded | ||||
|  | ||||
| The limit on the number of calls per second. The default throttle limit is two calls per second. | ||||
|  | ||||
| ### Example | ||||
|  | ||||
| Example response to a request over the throttle limit: | ||||
| If any of the limits configured in the API Gateway is being reached, it will return a HTTP/1.1 429 status code to the client: | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 403 Forbidden | ||||
| Content-Type: application/problem+json | ||||
| HTTP/1.1 429 Too Many Requests | ||||
| Content-Type: application/json | ||||
|  | ||||
| Retry-After: 1 | ||||
| X-Error-Detail-Header: Account Over Queries Per Second Limit | ||||
| X-Mashery-Error-Code: ERR_403_DEVELOPER_OVER_QPS | ||||
|  | ||||
| { | ||||
|   "title": "Quota Limit Exceeded", | ||||
|   "detail": "Account Over Queries Per Second Limit" | ||||
| } | ||||
|  | ||||
| { "message": "API rate limit exceeded" } | ||||
| ``` | ||||
|  | ||||
| > NOTE: The `Retry-After` gives a hint how long before the same request should be repeated \(in seconds\). | ||||
|  | ||||
| ## Detail Information | ||||
|  | ||||
| By default, the headers do not contain details about the current usage and quotas. The default can be changed in the API management. | ||||
|  | ||||
| ### Example | ||||
|  | ||||
| A successful response with the details about throttle \(`X-Plan-QPS`\) and quota \(`X-Plan-Quota`\) rate limits: | ||||
|  | ||||
| ```text | ||||
| HTTP/1.1 200 OK | ||||
|  | ||||
| X-Plan-QPS-Allotted: 10 | ||||
| X-Plan-QPS-Current: 1 | ||||
| X-Plan-Quota-Allotted: 1000 | ||||
| X-Plan-Quota-Current: 2 | ||||
| X-Plan-Quota-Reset: Tuesday, June 6, 2017 12:00:00 AM GMT | ||||
| ``` | ||||
| > NOTE: The response header `Retry-After` gives a hint how long before the same request should be repeated \(in seconds\). | ||||
|  | ||||
|   | ||||
| @@ -10,7 +10,7 @@ The following must be available in the CI environment before testing: | ||||
|  | ||||
|    ```text | ||||
|     $ node -v | ||||
|     v12.16.0 | ||||
|     v14.15.5 | ||||
|    ``` | ||||
|  | ||||
| 3. [**Dredd**](https://github.com/apiaryio/dredd) MUST be installed globally in the CI environment: | ||||
| @@ -21,7 +21,7 @@ The following must be available in the CI environment before testing: | ||||
|  | ||||
|    ```text | ||||
|     $ dredd --version | ||||
|     dredd v13.0.1 | ||||
|     dredd v14.0.0 | ||||
|    ``` | ||||
|  | ||||
| ## Testing an API | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| # Complete API Development | ||||
|  | ||||
| > NOTE: The content of this file is outdated, refering to previous technologies used at adidas. It is kept for reference until its refresh | ||||
| 1-Design --> 2-Develop --> 3-Deploy --> 4-API Gateway --> 5-Use --> 6-Analyze --> 7-Update | ||||
|  | ||||
| 1. **Design the API** | ||||
|    1. Analyze business requirements | ||||
| @@ -16,23 +16,25 @@ | ||||
|  | ||||
|       > e.g.: User has many Orders via order relation, all of the required affordances should be mapped to relations. | ||||
|  | ||||
|    5. Formalize the design in the [Open API Specification](http://swagger.io/specification/) \(OAS, formerly known as "Swagger"\) format | ||||
|    5. Formalize the design in the [Open API Specification](http://swagger.io/specification/) \(OAS, formerly known as "Swagger"\) version 2.x or 3.0.x format. | ||||
|  | ||||
|       > Use **[SwaggerHub](https://design.api.3stripes.io/)** for the whole design process to the publication of the API specification. | ||||
|  | ||||
|    6. Follow the [adidas API guidelines](https://adidas.gitbook.io/api-guidelines/introduction/readme) | ||||
|    7. Put the OAS file into [Apiary adidas group](https://apiary.io) | ||||
|    8. Make sure the OAS file passes all adidas API Apiary style guide checks | ||||
|    9. Verify the design using Apiary Documentation and Apiary Mock Service | ||||
|    7. Publish the OAS file in SwaggerHub [under a specific project](https://design.api.3stripes.io/help/organizations/index) in the adidas organization.  | ||||
|    8. Verify the OAS file you have written passes the Spectral test. | ||||
|    9. Make sure the OAS file passes all adidas SwaggerHub style guide checks. A red banned will be showed at the bottom of the editor if something is wrong with the OAS content. | ||||
|    10. Review the API Design | ||||
|    11. Put the OAS file in a version control system \(VCS\) repository | ||||
|    12. Set up a CD pipeline to push OAS file from VCS to Apiary, whenever the file is changed | ||||
|    12. Set up a CD pipeline to push OAS file from VCS to SwaggerHub, whenever the file is changed | ||||
|  | ||||
| 2. **Develop the API** | ||||
|    1. Check out the VCS repository with the OAS file | ||||
|    2. Set up the [Dredd API testing tool](https://github.com/apiaryio/dredd) locally | ||||
|    3. Configure the Dredd for your project | ||||
|  | ||||
|       ```text | ||||
|        $ dredd init | ||||
|       ``` | ||||
|  | ||||
|    4. Run the Dredd test locally | ||||
|  | ||||
|       > Against locally running API implementation, Every test should fail. | ||||
| @@ -41,74 +43,88 @@ | ||||
|  | ||||
|       > Keep running the Dredd locally to see the progress. | ||||
|  | ||||
|    6. Set up a [CI/CD pipeline](https://adidas-group.gitbooks.io/api-guidelines/content/guides/api-testing-ci-environment.html) to execute the Dredd tests automatically | ||||
|    6. Set up a [CI/CD pipeline](https://adidas.gitbook.io/api-guidelines/rest-api-guidelines/guides/api-testing-ci-environment) to execute the Dredd tests automatically. | ||||
|  | ||||
|       > NOTE: Both TeamCity and Jenkins environments are available, contact adidas API Evangelist for details. | ||||
|  | ||||
|       > NOTE: Both TeamCity and Jenkins environments are available, contact adidas API evangelist for details. | ||||
| 3. **Deploy the API** | ||||
|    1. Deploy the service | ||||
|    2. Update the OAS file to add the deployment HOST | ||||
|    2. Update the OAS file to add the deployment host (OAS v2.x) or the deployment servers (OAS v3.0.x). For instance: | ||||
|  | ||||
|       > ```text | ||||
|       > host: adidas.api.mashery.com | ||||
|       > basePath: /demo-approval-api | ||||
|       > ``` | ||||
|       OAS Version 2.x | ||||
|       ```text | ||||
|       host: adidas.api.myapp.com | ||||
|       basePath: /demo-approval-api | ||||
|       ``` | ||||
|  | ||||
|       OAS Version 3.0.x | ||||
|       ```yaml | ||||
|       servers: | ||||
|          - url: https://adidas.api.myapp.com/ | ||||
|            description: Production cluster | ||||
|          - url: http://stg.adidas.api.myapp.com/ | ||||
|            description: Staging cluster | ||||
|          - url: http://dev.adidas.api.myapp.com/ | ||||
|            description: Development cluster | ||||
|       ``` | ||||
|  | ||||
|    3. Verify the deployment with Dredd | ||||
|  | ||||
|       > Use Dredd pointed towards the deployment host, be careful NOT to run it against the production OR using real production credentials. | ||||
|  | ||||
|    4. Monitor the API usage "From performance and technical standpoint." | ||||
| 4. **Expose the API using Mashery** | ||||
|    1. **API** | ||||
|       1. Create new API Definition in Mashery | ||||
|       2. Create a new API Endpoint the API Definition | ||||
| 4. **Expose the API using Kong** | ||||
|    > Ensure you have all the operational context information: | ||||
|       - Type of application | ||||
|       - Servers | ||||
|       - Detailed ownership information (Organiational unit, API Owner, Support contact, etc) | ||||
|  | ||||
|          > Set the "Your Endpoint Address" to the internal deployment HOST. | ||||
|    > Ensure you have all the Non-Functional Requirements for your API like: | ||||
|       - Caching strategy detailed for each endpoint | ||||
|       - Rate Limits information | ||||
|       - Scope (internal to adidas or public) | ||||
|       - List of consumers and ACLs | ||||
|       - Authentication & Authorization | ||||
|  | ||||
|       3. Create a new API Package in Mashery | ||||
|       4. Create a new API Plan within the API Package | ||||
|       5. Use Mashery API Designer to add the newly created API Definitions' API Endpoint to the API Plan | ||||
|       6. Revisit the API Plan's API key default settings | ||||
|       7. Revisit the API Plan's API default rate limits | ||||
|       8. Revisit the API Plan's access policy/authorization | ||||
|       9. **API Documentation** | ||||
|          1. Create new adidas API developer's portal page in the Mashery | ||||
|    Please read the [API On-Boarding Kong](https://tools.adidas-group.com/confluence/pages/viewpage.action?spaceKey=API2&title=Demand+-+API+Onboarding+in+Kong) to include your API in the adidas API Gateway if it is not done yet. | ||||
|     | ||||
|    Once all the information is ready create an [on-boarding request in JIRA](https://tools.adidas-group.com/jira/Secure/CreateIssueDetails!Init.jspa?issuetype=3&pid=28605&issueTemplateId=3701&summary=null&priority=2&labels=Kong-Onboarding). | ||||
|  | ||||
|             > Manage > Content > Documentation > APIs | ||||
|    > Read the [API Team Service Catalog](https://tools.adidas-group.com/confluence/pages/viewpage.action?spaceKey=API2&title=Service+catalog) to get more information. | ||||
|  | ||||
|          2. [Embed Apiary documentation](https://help.apiary.io/tools/embed/#apiary-embed-api-reference) on the newly created API Page | ||||
|          3. Revisit the API documentation access policy/authorization | ||||
| 5. **Use the API** | ||||
|  | ||||
|    > This step can be done at the same time as "Develop the API" thank Apiary hosted Mock, Inspector, and Documentation. | ||||
|    > This step can be done at the same time as "Develop the API" using [SwaggerHub auto-mock service](https://design.api.3stripes.io/help/integrations/api-auto-mocking) and the continuous inspection of the OAS file. | ||||
|  | ||||
|    1. Read API documentation at Apiary | ||||
|    2. Use API mock service provided by Apiary | ||||
|    3. Use API call inspector provided by Apiary | ||||
|    4. Obtain your API key | ||||
|    1. Read API documentation at SwaggerHub | ||||
|    2. Use an API implementation stub provided by SwaggerHub.  | ||||
|  | ||||
|       > The key is part of the API Plan created in Mashery and can be requested from your dashboard in the adidas API developer's portal. | ||||
|       > This is a good starting point for implementing the API, you can run and test it locally, implement the business logic for the API, and then deploy it to your server. | ||||
|     | ||||
|    3. Obtain your API key and other information to apply the authentication/authorization mode in your API | ||||
|  | ||||
|    5. When available use API implementation via Apiary proxy to debug the API calls | ||||
|    6. Use production deployment | ||||
|       > The key is part of the adidas API Gateway on-boarding process and can be requested from your dashboard in the adidas API developer's portal. | ||||
|  | ||||
|    4. Use production deployment | ||||
|  | ||||
| 6. **Analyze the API** | ||||
|    1. Examine the use of production API Using Mashery | ||||
|    1. Examine the use of production API Using Kong | ||||
|    2. Analyze the technical performance metrics | ||||
|    3. Collect the feedback from users | ||||
|  | ||||
| 7. **Update API Design** | ||||
|  | ||||
|    > Based on the analysis, new or changing business requirements | ||||
|  | ||||
|    1. Create a new branch in the VCS repository with OAS file | ||||
|    2. Create a new project \(alternative\) in Apiary | ||||
|    2. Create a new project \(alternative\) in SwaggerHub | ||||
|    3. Make sure the CI/CD pipeline is: | ||||
|       1. Set to push the OAS file to Apiary but make sure to modify the Apiary project name | ||||
|       1. Set to push the OAS file to SwaggerHub but make sure to modify the SwaggerHub project name under the adidas organization | ||||
|       2. Set to run Dredd test in the CI/CD | ||||
|    4. Modify the design \(OAS file\) accordingly, follow the "Design API" step | ||||
|    5. Follow the [**rules for extending**](https://adidas-group.gitbooks.io/api-guidelines/content/core-principles/rules-for-extending.html) and [**adidas API guidelines versioning policies**](https://adidas-group.gitbooks.io/api-guidelines/content/evolution/versioning.html) | ||||
|    5. Follow the adidas API Guidelines for [**changes and versioning**](https://adidas.gitbook.io/api-guidelines/rest-api-guidelines/evolution/versioning) | ||||
|    6. Use VCS pull request \(PR\) to propose the change to review | ||||
|    7. After the API Design change is verified, reviewed and approved, continue with the "Develop the API" phase | ||||
|    8. Eventually, when the updated design is ready to be deployed for production, merge the branch into the production branch | ||||
|    9. Follow this guide from "Expose the API using Mashery" step | ||||
|    9. Follow this guide from "Expose the API using Kong" step | ||||
|  | ||||
|   | ||||
| @@ -1,16 +1,20 @@ | ||||
| # HAL | ||||
|  | ||||
| The [`application/hal+json`](http://stateless.co/hal_specification.html) \(HAL\) **MUST** be used as the representation format of a resource. | ||||
| The Hypertext Application Language [`application/hal+json`](http://stateless.co/hal_specification.html) \(HAL\) **MUST** be used as the representation format of a resource. | ||||
|  | ||||
| ## Introduction to HAL | ||||
|  | ||||
| > _HAL is a simple format that gives a consistent and easy way to hyperlink between resources in your API._ | ||||
|  | ||||
| The HAL format is strictly coupled to [HATEOAS](https://en.wikipedia.org/wiki/HATEOAS). The main target of HATEOAS is to decouple the API Consumer from the paths used ion the API. The API Client uses the links generated by our API instead of building them from the documentation. This is less eror-prone for the API Consumer and it can allow making changes in the API without affecting the API Consumer code. | ||||
|  | ||||
| This document is an informal introduction to the HAL media type. For more details see [HAL - Hypertext Application Language Specification](http://stateless.co/hal_specification.html). | ||||
|  | ||||
| ## HAL Document Object Model | ||||
|  | ||||
| HAL document follow the object model defined in JSON-schema [here](https://supermodel.io/adidas/api/HAL). | ||||
| HAL document follow the object model defined in JSON-schema [here](https://supermodel.io/adidas/api/HAL).  | ||||
|  | ||||
| IANA created a list explaining the standard relationships for REST. Do not forget to have a look [here](http://www.iana.org/assignments/link-relations/link-relations.xhtml) to find the role of each type of relation.  | ||||
|  | ||||
| YAML code snippets are provided for [OpenAPI Specification 2.0/Swagger](https://github.com/adidas/api-guidelines/tree/4a033eb0cf8ec582102c09c1eb5ba1fa8a5597d9/rest-api-guidelines/functionality/message/HAL-snippet.yaml) and [OpenAPI Specification 3.x](https://github.com/adidas/api-guidelines/tree/4a033eb0cf8ec582102c09c1eb5ba1fa8a5597d9/rest-api-guidelines/functionality/message/HAL-snippet-full-OpenApi3.yaml). | ||||
|  | ||||
| @@ -119,9 +123,18 @@ Some APIs using HAL: | ||||
|  | ||||
| Refer to the [extensive list of libraries that work with HAL](https://github.com/mikekelly/hal_specification/wiki/Libraries). | ||||
|  | ||||
| For working with HAL and Node.js using [HALson npm package](https://www.npmjs.com/package/halson) is suggested. | ||||
| ### Java | ||||
|  | ||||
| ### Spring Framework | ||||
| #### Spring Framework | ||||
|  | ||||
| Spring framework supports HAL out of the box. More info can be found in [Spring Documentation](https://spring.io/guides/gs/rest-hateoas/) and [examples](https://github.com/spring-guides/gs-rest-hateoas). | ||||
|  | ||||
| #### Quarkus Framework | ||||
|  | ||||
| Quarkus framework supports HAL out of the box. More info can be found in [Quarkus Documentation](https://quarkus.io/guides/rest-data-panache). | ||||
|  | ||||
| ### NodeJS | ||||
|  | ||||
| For working with HAL and Node.js using [HALson npm package](https://www.npmjs.com/package/halson) is suggested. | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -8,3 +8,10 @@ | ||||
| ## Tools documentation | ||||
|  | ||||
| * [SwaggerHub Documentation](https://app.swaggerhub.com/help/index) | ||||
|  | ||||
|  | ||||
| ## Learning Path (adidas-Udemy) | ||||
|  | ||||
| * [Basic](https://adidas-itlearning.udemy.com/course/onboarding-16-api-development-management/) | ||||
| * [Deep Dive](https://adidas-itlearning.udemy.com/course/onboarding-21-api-development-management/) | ||||
| * [OpenAPI](https://adidas-itlearning.udemy.com/course/openapi-beginner-to-guru/learn/) | ||||
|   | ||||
| @@ -10,6 +10,8 @@ At a minimum everyone **MUST** be familiar with the semantics of ["Common" HTTP | ||||
|  | ||||
| ## Use Codes 4xx or 5xx to Communicate Errors | ||||
|  | ||||
| Remember the 4xx range concern to errors in the API Consumer/Client side while 5xx range concerns to the upstream/backend service, the API implementation. | ||||
|  | ||||
| A request: | ||||
|  | ||||
| ```text | ||||
|   | ||||
							
								
								
									
										648
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										648
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -2,29 +2,6 @@ | ||||
| # yarn lockfile v1 | ||||
|  | ||||
|  | ||||
| "@babel/code-frame@^7.0.0": | ||||
|   version "7.5.5" | ||||
|   resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.5.5.tgz#bc0782f6d69f7b7d49531219699b988f669a8f9d" | ||||
|   integrity sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw== | ||||
|   dependencies: | ||||
|     "@babel/highlight" "^7.0.0" | ||||
|  | ||||
| "@babel/highlight@^7.0.0": | ||||
|   version "7.5.0" | ||||
|   resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.5.0.tgz#56d11312bd9248fa619591d02472be6e8cb32540" | ||||
|   integrity sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ== | ||||
|   dependencies: | ||||
|     chalk "^2.0.0" | ||||
|     esutils "^2.0.2" | ||||
|     js-tokens "^4.0.0" | ||||
|  | ||||
| "@babel/runtime@^7.0.0": | ||||
|   version "7.7.4" | ||||
|   resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.7.4.tgz#b23a856751e4bf099262f867767889c0e3fe175b" | ||||
|   integrity sha512-r24eVUUr0QqNZa+qrImUk8fn5SPhHq+IfYvIoIMg0do3GdK9sMdiLKP3GYVVaxpPKORgm8KRKaNTEhAjgIpLMw== | ||||
|   dependencies: | ||||
|     regenerator-runtime "^0.13.2" | ||||
|  | ||||
| "@nodelib/fs.scandir@2.1.3": | ||||
|   version "2.1.3" | ||||
|   resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.3.tgz#3a582bdb53804c6ba6d146579c46e52130cf4a3b" | ||||
| @@ -46,85 +23,130 @@ | ||||
|     "@nodelib/fs.scandir" "2.1.3" | ||||
|     fastq "^1.6.0" | ||||
|  | ||||
| "@stoplight/json-ref-resolver@^2.2.0": | ||||
|   version "2.4.1" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/json-ref-resolver/-/json-ref-resolver-2.4.1.tgz#db54b0771226611e1beb2e908493903139f2a4a8" | ||||
|   integrity sha512-y9G0BybShiJ/1NaPPG1BPelL2zI8/0rKXRtUpD2JBHEb72L9n4Bin85+MfrHYoHeJxojDpewsJA3FVRnUVL1dw== | ||||
| "@stoplight/better-ajv-errors@0.0.3": | ||||
|   version "0.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/better-ajv-errors/-/better-ajv-errors-0.0.3.tgz#8d47a511aca89e0027cf748785910fbb25d7c54f" | ||||
|   integrity sha512-q3PoPiYZdzfJjQ+q6ifuLVFx3dBKRxW1OBGxnLAoDlamYb+GJUNiaSLB32L6OB4fi6h/TsY21lZB7y7aYFM7tQ== | ||||
|   dependencies: | ||||
|     "@stoplight/json" "^3.1.2" | ||||
|     "@stoplight/path" "^1.3.0" | ||||
|     "@stoplight/types" "^11.0.0" | ||||
|     "@types/urijs" "1.x.x" | ||||
|     jsonpointer "^4.0.1" | ||||
|     leven "^3.1.0" | ||||
|  | ||||
| "@stoplight/json-ref-readers@1.2.1": | ||||
|   version "1.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/json-ref-readers/-/json-ref-readers-1.2.1.tgz#45061659cf46b60a7d9422858c4cd4c2a5d5e7c7" | ||||
|   integrity sha512-fbh8sXRrwfOCx4EA2e6FGUwvu5zxCQ9xHZg3vYDFSb1HLTlrCeRTdx3VCmYjCSGAhpcwgpB4zMc8kiudujo8Yg== | ||||
|   dependencies: | ||||
|     node-fetch "^2.6.0" | ||||
|  | ||||
| "@stoplight/json-ref-resolver@3.1.0": | ||||
|   version "3.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/json-ref-resolver/-/json-ref-resolver-3.1.0.tgz#50753b49e650840247aede5734fabb7992eda87d" | ||||
|   integrity sha512-tEVlRi9sMVektCiPsnint0OD/2zzQOPb7GoWboBznDc3f/99SAjgL6TBWvuFCJXWLwhZP4GA55FggmtsF5OvQg== | ||||
|   dependencies: | ||||
|     "@stoplight/json" "^3.4.0" | ||||
|     "@stoplight/path" "^1.3.1" | ||||
|     "@stoplight/types" "^11.6.0" | ||||
|     "@types/urijs" "^1.19.9" | ||||
|     dependency-graph "~0.8.0" | ||||
|     fast-memoize "^2.5.1" | ||||
|     immer "^3.2.0" | ||||
|     immer "^5.3.2" | ||||
|     lodash "^4.17.15" | ||||
|     tslib "^1.10.0" | ||||
|     urijs "~1.19.1" | ||||
|     tslib "^1.13.0" | ||||
|     urijs "^1.19.2" | ||||
|  | ||||
| "@stoplight/json@^3.1.1", "@stoplight/json@^3.1.2": | ||||
|   version "3.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/json/-/json-3.2.1.tgz#cbc8080f4a55744beb89668d058e48ba52da141b" | ||||
|   integrity sha512-RnXApQlP6GEUHIK8JRianStXTc4dHARpNP8VVGL/BbctTTlA3BO+Z1eILu35JdqvMG5sw6Og3TkQyQ85w6sSoA== | ||||
| "@stoplight/json@3.9.0": | ||||
|   version "3.9.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/json/-/json-3.9.0.tgz#ade6c5a75bfc55a464d81e902c53a8862c98b462" | ||||
|   integrity sha512-jgEKIPMLbhaU5Nw9yw+VBw2OSfDxm8VQ/k5JNezAuDMjcmqCPz3rOQTVNOROStzi70l4DRxF7eBN9liYJq5Ojw== | ||||
|   dependencies: | ||||
|     "@stoplight/types" "^11.1.1" | ||||
|     jsonc-parser "~2.2.0" | ||||
|     "@stoplight/ordered-object-literal" "^1.0.1" | ||||
|     "@stoplight/types" "^11.9.0" | ||||
|     jsonc-parser "~2.2.1" | ||||
|     lodash "^4.17.15" | ||||
|     safe-stable-stringify "^1.1" | ||||
|  | ||||
| "@stoplight/path@^1.2.0", "@stoplight/path@^1.3.0": | ||||
|   version "1.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/path/-/path-1.3.0.tgz#da2282352a4eb23c09d5106b9d1650d30a9ca2ad" | ||||
|   integrity sha512-t74/MHMgmFVMQhdQ/2Q766GryNTIW8McH8+vB25oeoBhYKTOrJ/wPDt+OCxIWHPUlcSi2fTWa4FKQ8qgmP2jVA== | ||||
|  | ||||
| "@stoplight/spectral@^4.2.0": | ||||
|   version "4.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/spectral/-/spectral-4.2.0.tgz#e095f93b44ecdd7ca11d15f513efa5f49822f83e" | ||||
|   integrity sha512-td5vZ0W8cGMpElG0UcdzFrqbEuJR81D9oPLCJoEEXsN5a8k2HGNkMxVJ5alC31wxahKTDzVmVIkBacJW+DzKRQ== | ||||
| "@stoplight/json@^3.4.0": | ||||
|   version "3.10.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/json/-/json-3.10.0.tgz#bd1af55081e1a47e0d01552d2a7e756931f46a4b" | ||||
|   integrity sha512-Xb1kVQ0t5eqRDF24Y0a2A1o/CEaHjLeVehkBmphqEBkUo6X9L4z5oOUYBMzlAoR/ejhjVgWLzrDBxNOuzBFVDA== | ||||
|   dependencies: | ||||
|     "@stoplight/json" "^3.1.1" | ||||
|     "@stoplight/json-ref-resolver" "^2.2.0" | ||||
|     "@stoplight/path" "^1.2.0" | ||||
|     "@stoplight/types" "^11.0.0" | ||||
|     "@stoplight/yaml" "^3.1.0" | ||||
|     abort-controller "^3.0.0" | ||||
|     ajv "^6.7" | ||||
|     ajv-oai "^1.1.1" | ||||
|     better-ajv-errors "^0.6.7" | ||||
|     chalk "^2.4.2" | ||||
|     deprecated-decorator "^0.1.6" | ||||
|     fast-glob "^3.0.4" | ||||
|     jsonpath-plus "~1.0" | ||||
|     lodash ">=4.17.5" | ||||
|     nanoid "^2.0.3" | ||||
|     node-fetch "^2.6" | ||||
|     proxy-agent "^3.1.0" | ||||
|     strip-ansi "^5.2" | ||||
|     text-table "^0.2" | ||||
|     tslib "^1.10.0" | ||||
|     typescript-json-schema "~0.40" | ||||
|     yargs "^14.0.0" | ||||
|  | ||||
| "@stoplight/types@^11.0.0", "@stoplight/types@^11.1.1": | ||||
|   version "11.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/types/-/types-11.3.0.tgz#23d40cbf2c3c85e5612038b5cf0c003f82809318" | ||||
|   integrity sha512-m6N4Bv2O2bYJOXdIwtpLtfQY/3zHUgRuHx2D8ERydX8WE40nKoLqh4wN6nvRcSeGwxjhi0Q0KUAZIe9UsYj6fQ== | ||||
|   dependencies: | ||||
|     "@types/json-schema" "^7.0.3" | ||||
|  | ||||
| "@stoplight/yaml-ast-parser@0.0.44": | ||||
|   version "0.0.44" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/yaml-ast-parser/-/yaml-ast-parser-0.0.44.tgz#ed3c962564283e9983f7895a6effc3994286df5e" | ||||
|   integrity sha512-PdY8p2Ufgtorf4d2DbKMfknILMa8KwuyyMMR/2lgK1mLaU8F5PKWYc+h9hIzC+ar0bh7m9h2rINo32m7ADfVyA== | ||||
|  | ||||
| "@stoplight/yaml@^3.1.0": | ||||
|   version "3.3.2" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/yaml/-/yaml-3.3.2.tgz#001049ed4a8733fca43cc60efe6bcd046abef210" | ||||
|   integrity sha512-KfrEsl3bA8mtoIklVvS4Hg8OrOYYtqi+K0IsQ7lJbZLVaUA4wMwDGwz85a6YWeo1OuVe8tumM6OynrFIjFutNA== | ||||
|   dependencies: | ||||
|     "@stoplight/types" "^11.1.1" | ||||
|     "@stoplight/yaml-ast-parser" "0.0.44" | ||||
|     "@stoplight/ordered-object-literal" "^1.0.1" | ||||
|     "@stoplight/types" "^11.9.0" | ||||
|     jsonc-parser "~2.2.1" | ||||
|     lodash "^4.17.15" | ||||
|     safe-stable-stringify "^1.1" | ||||
|  | ||||
| "@stoplight/lifecycle@2.3.1": | ||||
|   version "2.3.1" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/lifecycle/-/lifecycle-2.3.1.tgz#9cb0b2e260e3d4a52a14f7a92403807ee2c2b53f" | ||||
|   integrity sha512-On7qGYPDG1sgx2AOuJp8Hmm6WdK8+1PpCs7DEYoJ1GWtruPij9Q/pW0AV9CuR8KbCrOnvYcBsplaanB+Q3g/7Q== | ||||
|   dependencies: | ||||
|     wolfy87-eventemitter "~5.2.8" | ||||
|  | ||||
| "@stoplight/ordered-object-literal@^1.0.1": | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/ordered-object-literal/-/ordered-object-literal-1.0.1.tgz#01ece81ba5dda199ca3dc5ec7464691efa5d5b76" | ||||
|   integrity sha512-kDcBIKwzAXZTkgzaiPXH2I0JXavBkOb3jFzYNFS5cBuvZS3s/K+knpk2wLVt0n8XrnRQsSffzN6XG9HqUhfq6Q== | ||||
|  | ||||
| "@stoplight/path@1.3.2", "@stoplight/path@^1.3.1": | ||||
|   version "1.3.2" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/path/-/path-1.3.2.tgz#96e591496b72fde0f0cdae01a61d64f065bd9ede" | ||||
|   integrity sha512-lyIc6JUlUA8Ve5ELywPC8I2Sdnh1zc1zmbYgVarhXIp9YeAB0ReeqmGEOWNtlHkbP2DAA1AL65Wfn2ncjK/jtQ== | ||||
|  | ||||
| "@stoplight/spectral@^5.3.0": | ||||
|   version "5.7.2" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/spectral/-/spectral-5.7.2.tgz#0177f5322d09f7e4f3eddee818513104bb1dd841" | ||||
|   integrity sha512-AeqhEup2kIA/Ib2QduHMYuRxGGwrJK05U8YsGXRg7vSnSoH2iOKUXBY0QXB2cezTvz0rYrFsT+0+clxRwBDinQ== | ||||
|   dependencies: | ||||
|     "@stoplight/better-ajv-errors" "0.0.3" | ||||
|     "@stoplight/json" "3.9.0" | ||||
|     "@stoplight/json-ref-readers" "1.2.1" | ||||
|     "@stoplight/json-ref-resolver" "3.1.0" | ||||
|     "@stoplight/lifecycle" "2.3.1" | ||||
|     "@stoplight/path" "1.3.2" | ||||
|     "@stoplight/types" "^11.9.0" | ||||
|     "@stoplight/yaml" "4.2.1" | ||||
|     abort-controller "3.0.0" | ||||
|     ajv "6.12.5" | ||||
|     ajv-oai "1.2.0" | ||||
|     blueimp-md5 "2.13.0" | ||||
|     chalk "4.0.0" | ||||
|     eol "0.9.1" | ||||
|     expression-eval "3.1.2" | ||||
|     fast-glob "3.2.4" | ||||
|     jsonpath-plus "4.0.0" | ||||
|     lodash "4.17.19" | ||||
|     nanoid "2.1.11" | ||||
|     nimma "0.0.0" | ||||
|     node-fetch "2.6" | ||||
|     proxy-agent "3.1.1" | ||||
|     strip-ansi "6.0" | ||||
|     text-table "0.2" | ||||
|     tslib "1.13.0" | ||||
|     yargs "15.3.1" | ||||
|  | ||||
| "@stoplight/types@^11.6.0", "@stoplight/types@^11.9.0": | ||||
|   version "11.9.0" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/types/-/types-11.9.0.tgz#ced7de2dd53439d2409a3cb390bf7d5b76382ac6" | ||||
|   integrity sha512-4bzPpWZobt0e+d0OtALCJyl1HGzKo6ur21qxnId9dTl8v3yeD+5HJKZ2h1mv7e94debH5QDtimMU80V6jbXM8Q== | ||||
|   dependencies: | ||||
|     "@types/json-schema" "^7.0.4" | ||||
|     utility-types "^3.10.0" | ||||
|  | ||||
| "@stoplight/yaml-ast-parser@0.0.48": | ||||
|   version "0.0.48" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/yaml-ast-parser/-/yaml-ast-parser-0.0.48.tgz#442b21f419427acaa8a3106ebc5d73351c407002" | ||||
|   integrity sha512-sV+51I7WYnLJnKPn2EMWgS4EUfoP4iWEbrWwbXsj0MZCB/xOK8j6+C9fntIdOM50kpx45ZLC3s6kwKivWuqvyg== | ||||
|  | ||||
| "@stoplight/yaml@4.2.1": | ||||
|   version "4.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/@stoplight/yaml/-/yaml-4.2.1.tgz#6ff5ca89c3c427bd5e08f819d28730bb53e16cc6" | ||||
|   integrity sha512-EnSdRgOv/wrdMtdXdTiP5VvChg8lugDmSZVuhcdK/V1pibWd4+r9S4XpJlCx+xgCzg1oLM8pIv/d9cPwHU8XtA== | ||||
|   dependencies: | ||||
|     "@stoplight/ordered-object-literal" "^1.0.1" | ||||
|     "@stoplight/types" "^11.9.0" | ||||
|     "@stoplight/yaml-ast-parser" "0.0.48" | ||||
|     tslib "^1.12.0" | ||||
|  | ||||
| "@supermodel/cli@^0.46.29": | ||||
|   version "0.46.29" | ||||
| @@ -166,17 +188,17 @@ | ||||
|     jsonpointer "4.0.1" | ||||
|     url "0.11.0" | ||||
|  | ||||
| "@types/json-schema@^7.0.3": | ||||
|   version "7.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.3.tgz#bdfd69d61e464dcc81b25159c270d75a73c1a636" | ||||
|   integrity sha512-Il2DtDVRGDcqjDtE+rF8iqg1CArehSK84HZJCT7AMITlyXRBpuPhqGLDQMowraqqu1coEaimg4ZOqggt6L6L+A== | ||||
| "@types/json-schema@^7.0.4": | ||||
|   version "7.0.6" | ||||
|   resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.6.tgz#f4c7ec43e81b319a9815115031709f26987891f0" | ||||
|   integrity sha512-3c+yGKvVP5Y9TYBEibGNR+kLtijnj7mYrXRg+WpFb2X9xm04g/DXYkfg4hmzJQosc9snFNUPkbYIhu+KAm6jJw== | ||||
|  | ||||
| "@types/urijs@1.x.x": | ||||
|   version "1.19.4" | ||||
|   resolved "https://registry.yarnpkg.com/@types/urijs/-/urijs-1.19.4.tgz#29c4a694d4842d7f95e359a26223fc1865f1ab13" | ||||
|   integrity sha512-uHUvuLfy4YkRHL4UH8J8oRsINhdEHd9ymag7KJZVT94CjAmY1njoUzhazJsZjwfy+IpWKQKGVyXCwzhZvg73Fg== | ||||
| "@types/urijs@^1.19.9": | ||||
|   version "1.19.13" | ||||
|   resolved "https://registry.yarnpkg.com/@types/urijs/-/urijs-1.19.13.tgz#0bd025b65df8ee5f038bbf6f1cb2e95160b49a56" | ||||
|   integrity sha512-Wg/E8Q+ylkR6JElTwOcjG7kM99/iJz28E9RKr8syOxssRs3gWchsziUkb+Nr254aUBWHY0QiScGAfIx4lKI3/g== | ||||
|  | ||||
| abort-controller@^3.0.0: | ||||
| abort-controller@3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" | ||||
|   integrity sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg== | ||||
| @@ -197,14 +219,24 @@ agent-base@~4.2.1: | ||||
|   dependencies: | ||||
|     es6-promisify "^5.0.0" | ||||
|  | ||||
| ajv-oai@^1.1.1: | ||||
|   version "1.1.5" | ||||
|   resolved "https://registry.yarnpkg.com/ajv-oai/-/ajv-oai-1.1.5.tgz#f6a3ffa6a84ee90234a296ef733e9e18c875365e" | ||||
|   integrity sha512-JSBfA99K9cI22qJ8rwCyJ7J15iEMFOeHL8LqH+PL47HzeN7YZc7ZazQNg9eLO6TuPLBCfkiuMNLulKTGMzp25w== | ||||
| ajv-oai@1.2.0: | ||||
|   version "1.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/ajv-oai/-/ajv-oai-1.2.0.tgz#93ba0d3c64edf55e575c9d9f52fe494251c5b6d0" | ||||
|   integrity sha512-BQ2HL/ZfiMm68Xdy7dkS49Vnnq+gSsxfOugJB4TA8Kmu4Ie9ZIa4K4VQYbcHxyW4ccg6l9VB57PjRA2RPh1elw== | ||||
|   dependencies: | ||||
|     decimal.js "^10.2.0" | ||||
|  | ||||
| ajv@^6.1.1, ajv@^6.4.0, ajv@^6.7: | ||||
| ajv@6.12.5: | ||||
|   version "6.12.5" | ||||
|   resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.5.tgz#19b0e8bae8f476e5ba666300387775fb1a00a4da" | ||||
|   integrity sha512-lRF8RORchjpKG50/WFf8xmg7sgCLFiYNNnqdKflk63whMQcWR5ngGjiSXkL9bjxy6B2npOK2HSMN49jEBMSkag== | ||||
|   dependencies: | ||||
|     fast-deep-equal "^3.1.1" | ||||
|     fast-json-stable-stringify "^2.0.0" | ||||
|     json-schema-traverse "^0.4.1" | ||||
|     uri-js "^4.2.2" | ||||
|  | ||||
| ajv@^6.1.1, ajv@^6.4.0: | ||||
|   version "6.10.2" | ||||
|   resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.10.2.tgz#d3cea04d6b017b2894ad69040fec8b623eb4bd52" | ||||
|   integrity sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw== | ||||
| @@ -224,18 +256,25 @@ ansi-regex@^3.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998" | ||||
|   integrity sha1-7QMXwyIGT3lGbAKWa922Bas32Zg= | ||||
|  | ||||
| ansi-regex@^4.1.0: | ||||
|   version "4.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz#8b9f8f08cf1acb843756a839ca8c7e3168c51997" | ||||
|   integrity sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg== | ||||
| ansi-regex@^5.0.0: | ||||
|   version "5.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" | ||||
|   integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== | ||||
|  | ||||
| ansi-styles@^3.2.0, ansi-styles@^3.2.1: | ||||
| ansi-styles@^3.2.1: | ||||
|   version "3.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" | ||||
|   integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== | ||||
|   dependencies: | ||||
|     color-convert "^1.9.0" | ||||
|  | ||||
| ansi-styles@^4.0.0, ansi-styles@^4.1.0: | ||||
|   version "4.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" | ||||
|   integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== | ||||
|   dependencies: | ||||
|     color-convert "^2.0.1" | ||||
|  | ||||
| argparse@^1.0.7: | ||||
|   version "1.0.10" | ||||
|   resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" | ||||
| @@ -248,6 +287,11 @@ ast-types@0.x.x: | ||||
|   resolved "https://registry.yarnpkg.com/ast-types/-/ast-types-0.13.2.tgz#df39b677a911a83f3a049644fb74fdded23cea48" | ||||
|   integrity sha512-uWMHxJxtfj/1oZClOxDEV1sQ1HCDkA4MG8Gr69KKeBjEVH0R84WlejZ0y2DcwyBlpAEMltmVYkVgqfLFb2oyiA== | ||||
|  | ||||
| astring@^1.4.3: | ||||
|   version "1.4.3" | ||||
|   resolved "https://registry.yarnpkg.com/astring/-/astring-1.4.3.tgz#b99d4b0349bc7b28934bb9f03f86ec34d69c3a09" | ||||
|   integrity sha512-yJlJU/bmN820vL+cbWShu2YQU87dBP5V7BH2N4wODapRv27A2dZtUD0LgjP9lZENvPe9XRoSyWx+pZR6qKqNBw== | ||||
|  | ||||
| asynckit@^0.4.0: | ||||
|   version "0.4.0" | ||||
|   resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" | ||||
| @@ -276,18 +320,10 @@ base64-js@^1.3.0: | ||||
|   resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.3.1.tgz#58ece8cb75dd07e71ed08c736abc5fac4dbf8df1" | ||||
|   integrity sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g== | ||||
|  | ||||
| better-ajv-errors@^0.6.7: | ||||
|   version "0.6.7" | ||||
|   resolved "https://registry.yarnpkg.com/better-ajv-errors/-/better-ajv-errors-0.6.7.tgz#b5344af1ce10f434fe02fc4390a5a9c811e470d1" | ||||
|   integrity sha512-PYgt/sCzR4aGpyNy5+ViSQ77ognMnWq7745zM+/flYO4/Yisdtp9wDQW2IKCyVYPUxQt3E/b5GBSwfhd1LPdlg== | ||||
|   dependencies: | ||||
|     "@babel/code-frame" "^7.0.0" | ||||
|     "@babel/runtime" "^7.0.0" | ||||
|     chalk "^2.4.1" | ||||
|     core-js "^3.2.1" | ||||
|     json-to-ast "^2.0.3" | ||||
|     jsonpointer "^4.0.1" | ||||
|     leven "^3.1.0" | ||||
| blueimp-md5@2.13.0: | ||||
|   version "2.13.0" | ||||
|   resolved "https://registry.yarnpkg.com/blueimp-md5/-/blueimp-md5-2.13.0.tgz#07314b0c64dda0bf1733f96ce40d5af94eb28965" | ||||
|   integrity sha512-lmp0m647R5e77ORduxLW5mISIDcvgJZa52vMBv5uVI3UmSWTQjkJsZVBfaFqQPw/QFogJwvY6e3Gl9nP+Loe+Q== | ||||
|  | ||||
| brace-expansion@^1.1.7: | ||||
|   version "1.1.11" | ||||
| @@ -319,7 +355,15 @@ casex@3.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/casex/-/casex-3.0.0.tgz#97104bfa93d6535cf4608f32aa80ba87d351b427" | ||||
|   integrity sha512-fBWw2Hur76NRY92xwgWKV2LoVc423HgxY625Tou+iG1SiZX3aNLT9oMgGz8FuStKv9kjpGxMeG5Kb9ybNnci3w== | ||||
|  | ||||
| chalk@^2.0.0, chalk@^2.4.1, chalk@^2.4.2: | ||||
| chalk@4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.0.0.tgz#6e98081ed2d17faab615eb52ac66ec1fe6209e72" | ||||
|   integrity sha512-N9oWFcegS0sFr9oh1oz2d7Npos6vNoWW9HvtCg5N1KRFpUhaAhvTv5Y58g880fZaEYSNm3qDz8SU1UrGvp+n7A== | ||||
|   dependencies: | ||||
|     ansi-styles "^4.1.0" | ||||
|     supports-color "^7.1.0" | ||||
|  | ||||
| chalk@^2.0.0: | ||||
|   version "2.4.2" | ||||
|   resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" | ||||
|   integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== | ||||
| @@ -345,25 +389,20 @@ cli-width@^2.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.0.tgz#ff19ede8a9a5e579324147b0c11f0fbcbabed639" | ||||
|   integrity sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk= | ||||
|  | ||||
| cliui@^5.0.0: | ||||
|   version "5.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/cliui/-/cliui-5.0.0.tgz#deefcfdb2e800784aa34f46fa08e06851c7bbbc5" | ||||
|   integrity sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA== | ||||
| cliui@^6.0.0: | ||||
|   version "6.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/cliui/-/cliui-6.0.0.tgz#511d702c0c4e41ca156d7d0e96021f23e13225b1" | ||||
|   integrity sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ== | ||||
|   dependencies: | ||||
|     string-width "^3.1.0" | ||||
|     strip-ansi "^5.2.0" | ||||
|     wrap-ansi "^5.1.0" | ||||
|     string-width "^4.2.0" | ||||
|     strip-ansi "^6.0.0" | ||||
|     wrap-ansi "^6.2.0" | ||||
|  | ||||
| co@^4.6.0: | ||||
|   version "4.6.0" | ||||
|   resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184" | ||||
|   integrity sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ= | ||||
|  | ||||
| code-error-fragment@0.0.230: | ||||
|   version "0.0.230" | ||||
|   resolved "https://registry.yarnpkg.com/code-error-fragment/-/code-error-fragment-0.0.230.tgz#d736d75c832445342eca1d1fedbf17d9618b14d7" | ||||
|   integrity sha512-cadkfKp6932H8UkhzE/gcUqhRMNf8jHzkAN7+5Myabswaghu4xABTgPHDCjW+dBAJxj/SpkTYokpzDqY4pCzQw== | ||||
|  | ||||
| color-convert@^1.9.0: | ||||
|   version "1.9.3" | ||||
|   resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" | ||||
| @@ -371,11 +410,23 @@ color-convert@^1.9.0: | ||||
|   dependencies: | ||||
|     color-name "1.1.3" | ||||
|  | ||||
| color-convert@^2.0.1: | ||||
|   version "2.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" | ||||
|   integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== | ||||
|   dependencies: | ||||
|     color-name "~1.1.4" | ||||
|  | ||||
| color-name@1.1.3: | ||||
|   version "1.1.3" | ||||
|   resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" | ||||
|   integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= | ||||
|  | ||||
| color-name@~1.1.4: | ||||
|   version "1.1.4" | ||||
|   resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" | ||||
|   integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== | ||||
|  | ||||
| combined-stream@^1.0.6: | ||||
|   version "1.0.8" | ||||
|   resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" | ||||
| @@ -403,11 +454,6 @@ cookiejar@^2.1.0: | ||||
|   resolved "https://registry.yarnpkg.com/cookiejar/-/cookiejar-2.1.2.tgz#dd8a235530752f988f9a0844f3fc589e3111125c" | ||||
|   integrity sha512-Mw+adcfzPxcPeI+0WlvRrr/3lGVO0bD75SxX6811cxSh1Wbxx7xZBGK1eVtDf6si8rg2lhnUjsVLMFMfbRIuwA== | ||||
|  | ||||
| core-js@^3.2.1: | ||||
|   version "3.4.2" | ||||
|   resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.4.2.tgz#ee2b1a60b50388d8ddcda8cdb44a92c7a9ea76df" | ||||
|   integrity sha512-bUTfqFWtNKWp73oNIfRkqwYZJeNT3lstzZcAkhhiuvDraRSgOH1/+F9ZklbpR4zpdKuo4cpXN8tKP7s61yjX+g== | ||||
|  | ||||
| core-util-is@~1.0.0: | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" | ||||
| @@ -490,20 +536,15 @@ dependency-graph@~0.8.0: | ||||
|   resolved "https://registry.yarnpkg.com/dependency-graph/-/dependency-graph-0.8.0.tgz#2da2d35ed852ecc24a5d6c17788ba57c3708755b" | ||||
|   integrity sha512-DCvzSq2UiMsuLnj/9AL484ummEgLtZIcRS7YvtO38QnpX3vqh9nJ8P+zhu8Ja+SmLrBHO2iDbva20jq38qvBkQ== | ||||
|  | ||||
| deprecated-decorator@^0.1.6: | ||||
|   version "0.1.6" | ||||
|   resolved "https://registry.yarnpkg.com/deprecated-decorator/-/deprecated-decorator-0.1.6.tgz#00966317b7a12fe92f3cc831f7583af329b86c37" | ||||
|   integrity sha1-AJZjF7ehL+kvPMgx91g68ym4bDc= | ||||
|  | ||||
| dotenv@5.0.1: | ||||
|   version "5.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-5.0.1.tgz#a5317459bd3d79ab88cff6e44057a6a3fbb1fcef" | ||||
|   integrity sha512-4As8uPrjfwb7VXC+WnLCbXK7y+Ueb2B3zgNCePYfhxS1PYeaO1YTeplffTEcbfLhvFNGLAz90VvJs9yomG7bow== | ||||
|  | ||||
| emoji-regex@^7.0.1: | ||||
|   version "7.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156" | ||||
|   integrity sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA== | ||||
| emoji-regex@^8.0.0: | ||||
|   version "8.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" | ||||
|   integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== | ||||
|  | ||||
| encoding@^0.1.11: | ||||
|   version "0.1.12" | ||||
| @@ -512,6 +553,11 @@ encoding@^0.1.11: | ||||
|   dependencies: | ||||
|     iconv-lite "~0.4.13" | ||||
|  | ||||
| eol@0.9.1: | ||||
|   version "0.9.1" | ||||
|   resolved "https://registry.yarnpkg.com/eol/-/eol-0.9.1.tgz#f701912f504074be35c6117a5c4ade49cd547acd" | ||||
|   integrity sha512-Ds/TEoZjwggRoz/Q2O7SE3i4Jm66mqTDfmdHdq/7DKVk3bro9Q8h6WdXKdPqFLMoqxrDK5SVRzHVPOS6uuGtrg== | ||||
|  | ||||
| es6-promise@^4.0.3, es6-promise@^4.2.8: | ||||
|   version "4.2.8" | ||||
|   resolved "https://registry.yarnpkg.com/es6-promise/-/es6-promise-4.2.8.tgz#4eb21594c972bc40553d276e510539143db53e0a" | ||||
| @@ -566,6 +612,13 @@ event-target-shim@^5.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/event-target-shim/-/event-target-shim-5.0.1.tgz#5d4d3ebdf9583d63a5333ce2deb7480ab2b05789" | ||||
|   integrity sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ== | ||||
|  | ||||
| expression-eval@3.1.2: | ||||
|   version "3.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/expression-eval/-/expression-eval-3.1.2.tgz#45ddf0b8fdb8bf0633d02f4061d6f25516eddb30" | ||||
|   integrity sha512-c8ZN8fuAz0TRYKoGsrIq5kLNHtm81KAqWSBORHIY0DpJmZZrwK/r2zFDOhFIAJDV47gJ6irV7dWf1TOFpKvULQ== | ||||
|   dependencies: | ||||
|     jsep "^0.3.0" | ||||
|  | ||||
| extend@^3.0.0, extend@~3.0.2: | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" | ||||
| @@ -585,16 +638,22 @@ fast-deep-equal@^2.0.1: | ||||
|   resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz#7b05218ddf9667bf7f370bf7fdb2cb15fdd0aa49" | ||||
|   integrity sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk= | ||||
|  | ||||
| fast-glob@^3.0.4: | ||||
|   version "3.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.1.0.tgz#77375a7e3e6f6fc9b18f061cddd28b8d1eec75ae" | ||||
|   integrity sha512-TrUz3THiq2Vy3bjfQUB2wNyPdGBeGmdjbzzBLhfHN4YFurYptCKwGq/TfiRavbGywFRzY6U2CdmQ1zmsY5yYaw== | ||||
| fast-deep-equal@^3.1.1: | ||||
|   version "3.1.3" | ||||
|   resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" | ||||
|   integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== | ||||
|  | ||||
| fast-glob@3.2.4: | ||||
|   version "3.2.4" | ||||
|   resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.4.tgz#d20aefbf99579383e7f3cc66529158c9b98554d3" | ||||
|   integrity sha512-kr/Oo6PX51265qeuCYsyGypiO5uJFgBS0jksyG7FUeCyQzNwYnzrNIMR1NXfkZXsMYXYLRAHgISHBz8gQcxKHQ== | ||||
|   dependencies: | ||||
|     "@nodelib/fs.stat" "^2.0.2" | ||||
|     "@nodelib/fs.walk" "^1.2.3" | ||||
|     glob-parent "^5.1.0" | ||||
|     merge2 "^1.3.0" | ||||
|     micromatch "^4.0.2" | ||||
|     picomatch "^2.2.1" | ||||
|  | ||||
| fast-json-stable-stringify@^2.0.0: | ||||
|   version "2.0.0" | ||||
| @@ -637,12 +696,13 @@ fill-range@^7.0.1: | ||||
|   dependencies: | ||||
|     to-regex-range "^5.0.1" | ||||
|  | ||||
| find-up@^3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" | ||||
|   integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== | ||||
| find-up@^4.1.0: | ||||
|   version "4.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" | ||||
|   integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== | ||||
|   dependencies: | ||||
|     locate-path "^3.0.0" | ||||
|     locate-path "^5.0.0" | ||||
|     path-exists "^4.0.0" | ||||
|  | ||||
| form-data@^2.3.1: | ||||
|   version "2.5.1" | ||||
| @@ -707,7 +767,7 @@ glob@7.1.3: | ||||
|     once "^1.3.0" | ||||
|     path-is-absolute "^1.0.0" | ||||
|  | ||||
| glob@^7.0.5, glob@~7.1.4: | ||||
| glob@^7.0.5: | ||||
|   version "7.1.6" | ||||
|   resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" | ||||
|   integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== | ||||
| @@ -719,11 +779,6 @@ glob@^7.0.5, glob@~7.1.4: | ||||
|     once "^1.3.0" | ||||
|     path-is-absolute "^1.0.0" | ||||
|  | ||||
| grapheme-splitter@^1.0.4: | ||||
|   version "1.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz#9cf3a665c6247479896834af35cf1dbb4400767e" | ||||
|   integrity sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ== | ||||
|  | ||||
| graphql@0.13.2: | ||||
|   version "0.13.2" | ||||
|   resolved "https://registry.yarnpkg.com/graphql/-/graphql-0.13.2.tgz#4c740ae3c222823e7004096f832e7b93b2108270" | ||||
| @@ -743,6 +798,11 @@ has-flag@^3.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" | ||||
|   integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= | ||||
|  | ||||
| has-flag@^4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" | ||||
|   integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== | ||||
|  | ||||
| http-errors@1.7.3: | ||||
|   version "1.7.3" | ||||
|   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" | ||||
| @@ -789,10 +849,10 @@ idtoken-verifier@^2.0.2: | ||||
|     unfetch "^4.1.0" | ||||
|     url-join "^4.0.1" | ||||
|  | ||||
| immer@^3.2.0: | ||||
|   version "3.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/immer/-/immer-3.3.0.tgz#ee7cf3a248d5dd2d4eedfbe7dfc1e9be8c72041d" | ||||
|   integrity sha512-vlWRjnZqoTHuEjadquVHK3GxsXe1gNoATffLEA8Qbrdd++Xb+wHEFiWtwAKTscMBoi1AsvEMXhYRzAXA8Ex9FQ== | ||||
| immer@^5.3.2: | ||||
|   version "5.3.6" | ||||
|   resolved "https://registry.yarnpkg.com/immer/-/immer-5.3.6.tgz#51eab8cbbeb13075fe2244250f221598818cac04" | ||||
|   integrity sha512-pqWQ6ozVfNOUDjrLfm4Pt7q4Q12cGw2HUZgry4Q5+Myxu9nmHRkWBpI0J4+MK0AxbdFtdMTwEGVl7Vd+vEiK+A== | ||||
|  | ||||
| inflight@^1.0.4: | ||||
|   version "1.0.6" | ||||
| @@ -841,6 +901,11 @@ is-fullwidth-code-point@^2.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" | ||||
|   integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8= | ||||
|  | ||||
| is-fullwidth-code-point@^3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" | ||||
|   integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== | ||||
|  | ||||
| is-glob@^4.0.1: | ||||
|   version "4.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" | ||||
| @@ -891,11 +956,6 @@ js-cookie@^2.2.0: | ||||
|   resolved "https://registry.yarnpkg.com/js-cookie/-/js-cookie-2.2.1.tgz#69e106dc5d5806894562902aa5baec3744e9b2b8" | ||||
|   integrity sha512-HvdH2LzI/EAZcUwA8+0nKNtWHqS+ZmijLA30RwZA0bo7ToCckjK5MkGhjED9KoRcXO6BaGI3I9UIzSA1FKFPOQ== | ||||
|  | ||||
| js-tokens@^4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" | ||||
|   integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== | ||||
|  | ||||
| js-yaml@^3.10.0, js-yaml@^3.11.0: | ||||
|   version "3.13.1" | ||||
|   resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.13.1.tgz#aff151b30bfdfa8e49e05da22e7415e9dfa37847" | ||||
| @@ -909,40 +969,25 @@ jsbn@^1.1.0: | ||||
|   resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-1.1.0.tgz#b01307cb29b618a1ed26ec79e911f803c4da0040" | ||||
|   integrity sha1-sBMHyym2GKHtJux56RH4A8TaAEA= | ||||
|  | ||||
| jsep@^0.3.0, jsep@^0.3.4: | ||||
|   version "0.3.5" | ||||
|   resolved "https://registry.yarnpkg.com/jsep/-/jsep-0.3.5.tgz#3fd79ebd92f6f434e4857d5272aaeef7d948264d" | ||||
|   integrity sha512-AoRLBDc6JNnKjNcmonituEABS5bcfqDhQAWWXNTFrqu6nVXBpBAGfcoTGZMFlIrh9FjmE1CQyX9CTNwZrXMMDA== | ||||
|  | ||||
| json-schema-traverse@^0.4.1: | ||||
|   version "0.4.1" | ||||
|   resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" | ||||
|   integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== | ||||
|  | ||||
| json-stable-stringify@^1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz#9a759d39c5f2ff503fd5300646ed445f88c4f9af" | ||||
|   integrity sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8= | ||||
|   dependencies: | ||||
|     jsonify "~0.0.0" | ||||
| jsonc-parser@~2.2.1: | ||||
|   version "2.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/jsonc-parser/-/jsonc-parser-2.2.1.tgz#db73cd59d78cce28723199466b2a03d1be1df2bc" | ||||
|   integrity sha512-o6/yDBYccGvTz1+QFevz6l6OBZ2+fMVu2JZ9CIhzsYRX4mjaK5IyX9eldUdCmga16zlgQxyrj5pt9kzuj2C02w== | ||||
|  | ||||
| json-to-ast@^2.0.3: | ||||
|   version "2.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/json-to-ast/-/json-to-ast-2.1.0.tgz#041a9fcd03c0845036acb670d29f425cea4faaf9" | ||||
|   integrity sha512-W9Lq347r8tA1DfMvAGn9QNcgYm4Wm7Yc+k8e6vezpMnRT+NHbtlxgNBXRVjXe9YM6eTn6+p/MKOlV/aABJcSnQ== | ||||
|   dependencies: | ||||
|     code-error-fragment "0.0.230" | ||||
|     grapheme-splitter "^1.0.4" | ||||
|  | ||||
| jsonc-parser@~2.2.0: | ||||
|   version "2.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/jsonc-parser/-/jsonc-parser-2.2.0.tgz#f206f87f9d49d644b7502052c04e82dd6392e9ef" | ||||
|   integrity sha512-4fLQxW1j/5fWj6p78vAlAafoCKtuBm6ghv+Ij5W2DrDx0qE+ZdEl2c6Ko1mgJNF5ftX1iEWQQ4Ap7+3GlhjkOA== | ||||
|  | ||||
| jsonify@~0.0.0: | ||||
|   version "0.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.0.tgz#2c74b6ee41d93ca51b7b5aaee8f503631d252a73" | ||||
|   integrity sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM= | ||||
|  | ||||
| jsonpath-plus@~1.0: | ||||
|   version "1.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/jsonpath-plus/-/jsonpath-plus-1.0.0.tgz#78fa5c4ae62968476268d505d9f78c65469d0e7c" | ||||
|   integrity sha512-CXQJ/tsgFogKYBuCRmnlChIw66JBXp8kAkT+R4mSB2cuzCSBi88lx2A+vHvo27RY4Wtj5xVVGu2/2O7NwZ79mg== | ||||
| jsonpath-plus@4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/jsonpath-plus/-/jsonpath-plus-4.0.0.tgz#954b69faa3d8b07f30ae2f9e601176a4b0d2806e" | ||||
|   integrity sha512-e0Jtg4KAzDJKKwzbLaUtinCn0RZseWBVRTRGihSpvFlM3wTR7ExSp+PTdeTsDrLNJUe7L7JYJe8mblHX5SCT6A== | ||||
|  | ||||
| jsonpointer@4.0.1, jsonpointer@^4.0.1: | ||||
|   version "4.0.1" | ||||
| @@ -962,15 +1007,19 @@ levn@~0.3.0: | ||||
|     prelude-ls "~1.1.2" | ||||
|     type-check "~0.3.2" | ||||
|  | ||||
| locate-path@^3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" | ||||
|   integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== | ||||
| locate-path@^5.0.0: | ||||
|   version "5.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" | ||||
|   integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== | ||||
|   dependencies: | ||||
|     p-locate "^3.0.0" | ||||
|     path-exists "^3.0.0" | ||||
|     p-locate "^4.1.0" | ||||
|  | ||||
| lodash@>=4.17.5, lodash@^4.17.15, lodash@^4.3.0: | ||||
| lodash@4.17.19: | ||||
|   version "4.17.19" | ||||
|   resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.19.tgz#e48ddedbe30b3321783c5b4301fbd353bc1e4a4b" | ||||
|   integrity sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ== | ||||
|  | ||||
| lodash@^4.17.15, lodash@^4.3.0: | ||||
|   version "4.17.15" | ||||
|   resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.15.tgz#b447f6670a0455bbfeedd11392eff330ea097548" | ||||
|   integrity sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A== | ||||
| @@ -1044,21 +1093,34 @@ mute-stream@0.0.7: | ||||
|   resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.7.tgz#3075ce93bc21b8fab43e1bc4da7e8115ed1e7bab" | ||||
|   integrity sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s= | ||||
|  | ||||
| nanoid@^2.0.3: | ||||
|   version "2.1.7" | ||||
|   resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-2.1.7.tgz#d775e3e7c6470bbaaae3da9a647a80e228e0abf7" | ||||
|   integrity sha512-fmS3qwDldm4bE01HCIRqNk+f255CNjnAoeV3Zzzv0KemObHKqYgirVaZA9DtKcjogicWjYcHkJs4D5A8CjnuVQ== | ||||
| nanoid@2.1.11: | ||||
|   version "2.1.11" | ||||
|   resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-2.1.11.tgz#ec24b8a758d591561531b4176a01e3ab4f0f0280" | ||||
|   integrity sha512-s/snB+WGm6uwi0WjsZdaVcuf3KJXlfGl2LcxgwkEwJF0D/BWzVWAZW/XY4bFaiR7s0Jk3FPvlnepg1H1b1UwlA== | ||||
|  | ||||
| netmask@^1.0.6: | ||||
|   version "1.0.6" | ||||
|   resolved "https://registry.yarnpkg.com/netmask/-/netmask-1.0.6.tgz#20297e89d86f6f6400f250d9f4f6b4c1945fcd35" | ||||
|   integrity sha1-ICl+idhvb2QA8lDZ9Pa0wZRfzTU= | ||||
|  | ||||
| nimma@0.0.0: | ||||
|   version "0.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/nimma/-/nimma-0.0.0.tgz#8fa61ab4ecdcb745c237bc70ddcc012c6cdf8127" | ||||
|   integrity sha512-if0VqyHpTMHKFORMiJ2WLWgoIF4xqwjybHZyvodQ/yCmiWag6RhLlMHeFukz4X31DanTBA26U+HwvXIrTaYQkQ== | ||||
|   dependencies: | ||||
|     astring "^1.4.3" | ||||
|     jsep "^0.3.4" | ||||
|  | ||||
| node-fetch@2.1.2: | ||||
|   version "2.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.1.2.tgz#ab884e8e7e57e38a944753cec706f788d1768bb5" | ||||
|   integrity sha1-q4hOjn5X44qUR1POxwb3iNF2i7U= | ||||
|  | ||||
| node-fetch@2.6, node-fetch@^2.6.0: | ||||
|   version "2.6.1" | ||||
|   resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.1.tgz#045bd323631f76ed2e2b55573394416b639a0052" | ||||
|   integrity sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw== | ||||
|  | ||||
| node-fetch@^1.0.1: | ||||
|   version "1.7.3" | ||||
|   resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-1.7.3.tgz#980f6f72d85211a5347c6b2bc18c5b84c3eb47ef" | ||||
| @@ -1067,7 +1129,7 @@ node-fetch@^1.0.1: | ||||
|     encoding "^0.1.11" | ||||
|     is-stream "^1.0.1" | ||||
|  | ||||
| node-fetch@^2.2.0, node-fetch@^2.6: | ||||
| node-fetch@^2.2.0: | ||||
|   version "2.6.0" | ||||
|   resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.0.tgz#e633456386d4aa55863f676a7ab0daa8fdecb0fd" | ||||
|   integrity sha512-8dG4H5ujfvFiqDmVu9fQ5bOHUC15JMjMY/Zumv26oOvvVJjM67KF8koCWIabKQ1GJIa9r2mMZscBq/TbdOcmNA== | ||||
| @@ -1103,19 +1165,19 @@ os-tmpdir@~1.0.2: | ||||
|   resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" | ||||
|   integrity sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ= | ||||
|  | ||||
| p-limit@^2.0.0: | ||||
|   version "2.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.2.1.tgz#aa07a788cc3151c939b5131f63570f0dd2009537" | ||||
|   integrity sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg== | ||||
| p-limit@^2.2.0: | ||||
|   version "2.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" | ||||
|   integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== | ||||
|   dependencies: | ||||
|     p-try "^2.0.0" | ||||
|  | ||||
| p-locate@^3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" | ||||
|   integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== | ||||
| p-locate@^4.1.0: | ||||
|   version "4.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" | ||||
|   integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== | ||||
|   dependencies: | ||||
|     p-limit "^2.0.0" | ||||
|     p-limit "^2.2.0" | ||||
|  | ||||
| p-try@^2.0.0: | ||||
|   version "2.2.0" | ||||
| @@ -1147,10 +1209,10 @@ pac-resolver@^3.0.0: | ||||
|     netmask "^1.0.6" | ||||
|     thunkify "^2.1.2" | ||||
|  | ||||
| path-exists@^3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" | ||||
|   integrity sha1-zg6+ql94yxiSXqfYENe1mwEP1RU= | ||||
| path-exists@^4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" | ||||
|   integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== | ||||
|  | ||||
| path-is-absolute@^1.0.0: | ||||
|   version "1.0.1" | ||||
| @@ -1162,6 +1224,11 @@ picomatch@^2.0.5: | ||||
|   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.1.1.tgz#ecdfbea7704adb5fe6fb47f9866c4c0e15e905c5" | ||||
|   integrity sha512-OYMyqkKzK7blWO/+XZYP6w8hH0LDvkBvdvKukti+7kqYFCiEAk+gI3DWnryapc0Dau05ugGTy0foQ6mqn4AHYA== | ||||
|  | ||||
| picomatch@^2.2.1: | ||||
|   version "2.2.2" | ||||
|   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" | ||||
|   integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== | ||||
|  | ||||
| prelude-ls@~1.1.2: | ||||
|   version "1.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" | ||||
| @@ -1172,7 +1239,7 @@ process-nextick-args@~2.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" | ||||
|   integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== | ||||
|  | ||||
| proxy-agent@^3.1.0: | ||||
| proxy-agent@3.1.1: | ||||
|   version "3.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/proxy-agent/-/proxy-agent-3.1.1.tgz#7e04e06bf36afa624a1540be247b47c970bd3014" | ||||
|   integrity sha512-WudaR0eTsDx33O3EJE16PjBRZWcX8GqCEeERw1W3hZJgH/F2a46g7jty6UGty6NeJ4CKQy8ds2CJPMiyeqaTvw== | ||||
| @@ -1257,11 +1324,6 @@ readable-stream@^2.3.5: | ||||
|     string_decoder "~1.1.1" | ||||
|     util-deprecate "~1.0.1" | ||||
|  | ||||
| regenerator-runtime@^0.13.2: | ||||
|   version "0.13.3" | ||||
|   resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.3.tgz#7cf6a77d8f5c6f60eb73c5fc1955b2ceb01e6bf5" | ||||
|   integrity sha512-naKIZz2GQ8JWh///G7L3X6LaQUAMp2lvb1rvwwsURe/VXwD6VMfr+/1NuNw3ag8v2kY1aQ/go5SNn79O9JU7yw== | ||||
|  | ||||
| require-directory@^2.1.1: | ||||
|   version "2.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" | ||||
| @@ -1385,14 +1447,14 @@ string-width@^2.1.0: | ||||
|     is-fullwidth-code-point "^2.0.0" | ||||
|     strip-ansi "^4.0.0" | ||||
|  | ||||
| string-width@^3.0.0, string-width@^3.1.0: | ||||
|   version "3.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961" | ||||
|   integrity sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w== | ||||
| string-width@^4.1.0, string-width@^4.2.0: | ||||
|   version "4.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.0.tgz#952182c46cc7b2c313d1596e623992bd163b72b5" | ||||
|   integrity sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg== | ||||
|   dependencies: | ||||
|     emoji-regex "^7.0.1" | ||||
|     is-fullwidth-code-point "^2.0.0" | ||||
|     strip-ansi "^5.1.0" | ||||
|     emoji-regex "^8.0.0" | ||||
|     is-fullwidth-code-point "^3.0.0" | ||||
|     strip-ansi "^6.0.0" | ||||
|  | ||||
| string_decoder@~0.10.x: | ||||
|   version "0.10.31" | ||||
| @@ -1406,6 +1468,13 @@ string_decoder@~1.1.1: | ||||
|   dependencies: | ||||
|     safe-buffer "~5.1.0" | ||||
|  | ||||
| strip-ansi@6.0, strip-ansi@^6.0.0: | ||||
|   version "6.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" | ||||
|   integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== | ||||
|   dependencies: | ||||
|     ansi-regex "^5.0.0" | ||||
|  | ||||
| strip-ansi@^4.0.0: | ||||
|   version "4.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" | ||||
| @@ -1413,13 +1482,6 @@ strip-ansi@^4.0.0: | ||||
|   dependencies: | ||||
|     ansi-regex "^3.0.0" | ||||
|  | ||||
| strip-ansi@^5.0.0, strip-ansi@^5.1.0, strip-ansi@^5.2, strip-ansi@^5.2.0: | ||||
|   version "5.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" | ||||
|   integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== | ||||
|   dependencies: | ||||
|     ansi-regex "^4.1.0" | ||||
|  | ||||
| superagent@^3.8.3: | ||||
|   version "3.8.3" | ||||
|   resolved "https://registry.yarnpkg.com/superagent/-/superagent-3.8.3.tgz#460ea0dbdb7d5b11bc4f78deba565f86a178e128" | ||||
| @@ -1443,12 +1505,19 @@ supports-color@^5.3.0: | ||||
|   dependencies: | ||||
|     has-flag "^3.0.0" | ||||
|  | ||||
| supports-color@^7.1.0: | ||||
|   version "7.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" | ||||
|   integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== | ||||
|   dependencies: | ||||
|     has-flag "^4.0.0" | ||||
|  | ||||
| symbol-observable@1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.0.1.tgz#8340fc4702c3122df5d22288f88283f513d3fdd4" | ||||
|   integrity sha1-g0D8RwLDEi310iKI+IKD9RPT/dQ= | ||||
|  | ||||
| text-table@^0.2: | ||||
| text-table@0.2: | ||||
|   version "0.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" | ||||
|   integrity sha1-f17oI66AUgfACvLfSoTsP8+lcLQ= | ||||
| @@ -1482,10 +1551,15 @@ toidentifier@1.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" | ||||
|   integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== | ||||
|  | ||||
| tslib@^1.10.0: | ||||
|   version "1.10.0" | ||||
|   resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.10.0.tgz#c3c19f95973fb0a62973fb09d90d961ee43e5c8a" | ||||
|   integrity sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ== | ||||
| tslib@1.13.0: | ||||
|   version "1.13.0" | ||||
|   resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.13.0.tgz#c881e13cc7015894ed914862d276436fa9a47043" | ||||
|   integrity sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q== | ||||
|  | ||||
| tslib@^1.12.0, tslib@^1.13.0: | ||||
|   version "1.14.1" | ||||
|   resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" | ||||
|   integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== | ||||
|  | ||||
| type-check@~0.3.2: | ||||
|   version "0.3.2" | ||||
| @@ -1494,22 +1568,6 @@ type-check@~0.3.2: | ||||
|   dependencies: | ||||
|     prelude-ls "~1.1.2" | ||||
|  | ||||
| typescript-json-schema@~0.40: | ||||
|   version "0.40.0" | ||||
|   resolved "https://registry.yarnpkg.com/typescript-json-schema/-/typescript-json-schema-0.40.0.tgz#4815092e5acf1662a94aa140924809ff5922da7c" | ||||
|   integrity sha512-C8D3Ca6+1x3caWOR+u45Shn3KqkRZi5M3+E8ePpEmYMqOh3xhhLdq+39pqT0Bf8+fCgAmpTFSJMT6Xwqbm0Tkw== | ||||
|   dependencies: | ||||
|     "@types/json-schema" "^7.0.3" | ||||
|     glob "~7.1.4" | ||||
|     json-stable-stringify "^1.0.1" | ||||
|     typescript "^3.5.3" | ||||
|     yargs "^14.0.0" | ||||
|  | ||||
| typescript@^3.5.3: | ||||
|   version "3.7.2" | ||||
|   resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.7.2.tgz#27e489b95fa5909445e9fef5ee48d81697ad18fb" | ||||
|   integrity sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ== | ||||
|  | ||||
| unfetch@^4.1.0: | ||||
|   version "4.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/unfetch/-/unfetch-4.1.0.tgz#6ec2dd0de887e58a4dee83a050ded80ffc4137db" | ||||
| @@ -1527,10 +1585,10 @@ uri-js@^4.2.2: | ||||
|   dependencies: | ||||
|     punycode "^2.1.0" | ||||
|  | ||||
| urijs@~1.19.1: | ||||
|   version "1.19.2" | ||||
|   resolved "https://registry.yarnpkg.com/urijs/-/urijs-1.19.2.tgz#f9be09f00c4c5134b7cb3cf475c1dd394526265a" | ||||
|   integrity sha512-s/UIq9ap4JPZ7H1EB5ULo/aOUbWqfDi7FKzMC2Nz+0Si8GiT1rIEaprt8hy3Vy2Ex2aJPpOQv4P4DuOZ+K1c6w== | ||||
| urijs@^1.19.2: | ||||
|   version "1.19.5" | ||||
|   resolved "https://registry.yarnpkg.com/urijs/-/urijs-1.19.5.tgz#119683ab4b2fb0bd637e5ea6dd9117bcac68d3e4" | ||||
|   integrity sha512-48z9VGWwdCV5KfizHsE05DWS5fhK6gFlx5MjO7xu0Krc5FGPWzjlXEVV0nPMrdVuP7xmMHiPZ2HoYZwKOFTZOg== | ||||
|  | ||||
| url-join@^4.0.1: | ||||
|   version "4.0.1" | ||||
| @@ -1550,6 +1608,11 @@ util-deprecate@~1.0.1: | ||||
|   resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" | ||||
|   integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= | ||||
|  | ||||
| utility-types@^3.10.0: | ||||
|   version "3.10.0" | ||||
|   resolved "https://registry.yarnpkg.com/utility-types/-/utility-types-3.10.0.tgz#ea4148f9a741015f05ed74fd615e1d20e6bed82b" | ||||
|   integrity sha512-O11mqxmi7wMKCo6HKFt5AhO4BwY3VV68YU07tgxfz8zJTIxr4BpsezN49Ffwy9j3ZpwwJp4fkRwjRzq3uWE6Rg== | ||||
|  | ||||
| whatwg-fetch@>=0.10.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.0.0.tgz#fc804e458cc460009b1a2b966bc8817d2578aefb" | ||||
| @@ -1565,19 +1628,24 @@ winchan@^0.2.2: | ||||
|   resolved "https://registry.yarnpkg.com/winchan/-/winchan-0.2.2.tgz#6766917b88e5e1cb75f455ffc7cc13f51e5c834e" | ||||
|   integrity sha512-pvN+IFAbRP74n/6mc6phNyCH8oVkzXsto4KCHPJ2AScniAnA1AmeLI03I2BzjePpaClGSI4GUMowzsD3qz5PRQ== | ||||
|  | ||||
| wolfy87-eventemitter@~5.2.8: | ||||
|   version "5.2.9" | ||||
|   resolved "https://registry.yarnpkg.com/wolfy87-eventemitter/-/wolfy87-eventemitter-5.2.9.tgz#e879f770b30fbb6512a8afbb330c388591099c2a" | ||||
|   integrity sha512-P+6vtWyuDw+MB01X7UeF8TaHBvbCovf4HPEMF/SV7BdDc1SMTiBy13SRD71lQh4ExFTG1d/WNzDGDCyOKSMblw== | ||||
|  | ||||
| word-wrap@~1.2.3: | ||||
|   version "1.2.3" | ||||
|   resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" | ||||
|   integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== | ||||
|  | ||||
| wrap-ansi@^5.1.0: | ||||
|   version "5.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-5.1.0.tgz#1fd1f67235d5b6d0fee781056001bfb694c03b09" | ||||
|   integrity sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q== | ||||
| wrap-ansi@^6.2.0: | ||||
|   version "6.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-6.2.0.tgz#e9393ba07102e6c91a3b221478f0257cd2856e53" | ||||
|   integrity sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA== | ||||
|   dependencies: | ||||
|     ansi-styles "^3.2.0" | ||||
|     string-width "^3.0.0" | ||||
|     strip-ansi "^5.0.0" | ||||
|     ansi-styles "^4.0.0" | ||||
|     string-width "^4.1.0" | ||||
|     strip-ansi "^6.0.0" | ||||
|  | ||||
| wrappy@1: | ||||
|   version "1.0.2" | ||||
| @@ -1599,27 +1667,27 @@ yallist@^3.0.2: | ||||
|   resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" | ||||
|   integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== | ||||
|  | ||||
| yargs-parser@^15.0.0: | ||||
|   version "15.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-15.0.0.tgz#cdd7a97490ec836195f59f3f4dbe5ea9e8f75f08" | ||||
|   integrity sha512-xLTUnCMc4JhxrPEPUYD5IBR1mWCK/aT6+RJ/K29JY2y1vD+FhtgKK0AXRWvI262q3QSffAQuTouFIKUuHX89wQ== | ||||
| yargs-parser@^18.1.1: | ||||
|   version "18.1.3" | ||||
|   resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-18.1.3.tgz#be68c4975c6b2abf469236b0c870362fab09a7b0" | ||||
|   integrity sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ== | ||||
|   dependencies: | ||||
|     camelcase "^5.0.0" | ||||
|     decamelize "^1.2.0" | ||||
|  | ||||
| yargs@^14.0.0: | ||||
|   version "14.2.2" | ||||
|   resolved "https://registry.yarnpkg.com/yargs/-/yargs-14.2.2.tgz#2769564379009ff8597cdd38fba09da9b493c4b5" | ||||
|   integrity sha512-/4ld+4VV5RnrynMhPZJ/ZpOCGSCeghMykZ3BhdFBDa9Wy/RH6uEGNWDJog+aUlq+9OM1CFTgtYRW5Is1Po9NOA== | ||||
| yargs@15.3.1: | ||||
|   version "15.3.1" | ||||
|   resolved "https://registry.yarnpkg.com/yargs/-/yargs-15.3.1.tgz#9505b472763963e54afe60148ad27a330818e98b" | ||||
|   integrity sha512-92O1HWEjw27sBfgmXiixJWT5hRBp2eobqXicLtPBIDBhYB+1HpwZlXmbW2luivBJHBzki+7VyCLRtAkScbTBQA== | ||||
|   dependencies: | ||||
|     cliui "^5.0.0" | ||||
|     cliui "^6.0.0" | ||||
|     decamelize "^1.2.0" | ||||
|     find-up "^3.0.0" | ||||
|     find-up "^4.1.0" | ||||
|     get-caller-file "^2.0.1" | ||||
|     require-directory "^2.1.1" | ||||
|     require-main-filename "^2.0.0" | ||||
|     set-blocking "^2.0.0" | ||||
|     string-width "^3.0.0" | ||||
|     string-width "^4.2.0" | ||||
|     which-module "^2.0.0" | ||||
|     y18n "^4.0.0" | ||||
|     yargs-parser "^15.0.0" | ||||
|     yargs-parser "^18.1.1" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user