 3772132579
			
		
	
	3772132579
	
	
	
		
			
			Update allocations, reshaper and usage APIs to accept and present consumer_type in microversion 1.38. ensure_consumer in placement/handlers/util.py is updated to be consumer type aware. allocation, usage and reshaper schema and handlers are updated gabbits/consumer-types-1.38.yaml adds tests across the various URIs A TODO is left in placement/handlers/allocation.py where the database is being accessed in a way that is not ideal. This will be cleared up in a followup patch (to add use of an AttributeCache). Co-Authored-By: Surya Seetharaman <suryaseetharaman.9@gmail.com> Co-Authored-By: melanie witt <melwittt@gmail.com> Story: 2005473 Task: 36421 Change-Id: I24c2315093e07dbf25c4fb53152e6a4de7477a51
		
			
				
	
	
		
			234 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			234 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| ===========
 | |
| Allocations
 | |
| ===========
 | |
| 
 | |
| Allocations are records representing resources that have been assigned
 | |
| and used by some consumer of that resource. They indicate the amount
 | |
| of a particular resource that has been allocated to a given consumer
 | |
| of that resource from a particular resource provider.
 | |
| 
 | |
| Manage allocations
 | |
| ==================
 | |
| 
 | |
| Create, update or delete allocations for multiple consumers in a single
 | |
| request. This allows a client to atomically set or swap allocations for
 | |
| multiple consumers as may be required during a migration or move type
 | |
| operation.
 | |
| 
 | |
| The allocations for an individual consumer uuid mentioned in the request
 | |
| can be removed by setting the `allocations` to an empty object (see the
 | |
| example below).
 | |
| 
 | |
| **Available as of microversion 1.13.**
 | |
| 
 | |
| .. rest_method:: POST /allocations
 | |
| 
 | |
| Normal response codes: 204
 | |
| 
 | |
| Error response codes: badRequest(400), conflict(409)
 | |
| 
 | |
| * `409 Conflict` if there is no available inventory in any of the
 | |
|   resource providers for any specified resource classes.
 | |
| * `409 Conflict` with `error code <error_codes_>`_
 | |
|   ``placement.concurrent_update`` if inventories are updated by another request
 | |
|   while attempting the operation. See :ref:`generations`.
 | |
| * `409 Conflict`  with `error code <error_codes_>`_
 | |
|   ``placement.concurrent_update`` at microversion 1.28 or higher if allocations
 | |
|   for a specified consumer have been created, updated, or removed by another
 | |
|   request while attempting the operation. See :ref:`generations`.
 | |
| 
 | |
| Request
 | |
| -------
 | |
| 
 | |
| .. rest_parameters:: parameters.yaml
 | |
| 
 | |
|   - consumer_uuid: consumer_uuid_body
 | |
|   - consumer_generation: consumer_generation_min
 | |
|   - consumer_type: consumer_type
 | |
|   - project_id: project_id_body
 | |
|   - user_id: user_id_body
 | |
|   - allocations: allocations_dict_empty
 | |
|   - generation: resource_provider_generation_optional
 | |
|   - resources: resources
 | |
|   - mappings: mappings_in_allocations
 | |
| 
 | |
| Request example (microversions 1.38 - )
 | |
| ---------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/manage-allocations-request-1.38.json
 | |
|    :language: javascript
 | |
| 
 | |
| Request example (microversions 1.28 - 1.36)
 | |
| -------------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/manage-allocations-request-1.28.json
 | |
|    :language: javascript
 | |
| 
 | |
| Request example (microversions 1.13 - 1.27)
 | |
| -------------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/manage-allocations-request.json
 | |
|    :language: javascript
 | |
| 
 | |
| Response
 | |
| --------
 | |
| 
 | |
| No body content is returned after a successful request
 | |
| 
 | |
| List allocations
 | |
| ================
 | |
| 
 | |
| List all allocation records for the consumer identified by
 | |
| `{consumer_uuid}` on all the resource providers it is consuming.
 | |
| 
 | |
| .. note:: When listing allocations for a consumer uuid that has no
 | |
|           allocations a dict with an empty value is returned
 | |
|           ``{"allocations": {}}``.
 | |
| 
 | |
| .. rest_method:: GET /allocations/{consumer_uuid}
 | |
| 
 | |
| Normal Response Codes: 200
 | |
| 
 | |
| Request
 | |
| -------
 | |
| 
 | |
| .. rest_parameters:: parameters.yaml
 | |
| 
 | |
|   - consumer_uuid: consumer_uuid
 | |
| 
 | |
| Response
 | |
| --------
 | |
| 
 | |
| .. rest_parameters:: parameters.yaml
 | |
| 
 | |
|   - allocations: allocations_by_resource_provider
 | |
|   - generation: resource_provider_generation
 | |
|   - resources: resources
 | |
|   - consumer_generation: consumer_generation_get
 | |
|   - consumer_type: consumer_type
 | |
|   - project_id: project_id_body_1_12
 | |
|   - user_id: user_id_body_1_12
 | |
| 
 | |
| Response Example (1.38 - )
 | |
| --------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/get-allocations-1.38.json
 | |
|    :language: javascript
 | |
| 
 | |
| Response Example (1.28 - 1.36)
 | |
| ------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/get-allocations-1.28.json
 | |
|    :language: javascript
 | |
| 
 | |
| Response Example (1.12 - 1.27)
 | |
| ------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/get-allocations.json
 | |
|    :language: javascript
 | |
| 
 | |
| Update allocations
 | |
| ==================
 | |
| 
 | |
| Create or update one or more allocation records representing the consumption of
 | |
| one or more classes of resources from one or more resource providers by
 | |
| the consumer identified by `{consumer_uuid}`.
 | |
| If allocations already exist for this consumer, they are replaced.
 | |
| 
 | |
| .. rest_method:: PUT /allocations/{consumer_uuid}
 | |
| 
 | |
| Normal Response Codes: 204
 | |
| 
 | |
| Error response codes: badRequest(400), itemNotFound(404), conflict(409)
 | |
| 
 | |
| * `409 Conflict` if there is no available inventory in any of the
 | |
|   resource providers for any specified resource classes.
 | |
| * `409 Conflict` with `error code <error_codes_>`_
 | |
|   ``placement.concurrent_update`` if inventories are updated by another request
 | |
|   while attempting the operation. See :ref:`generations`.
 | |
| * `409 Conflict`  with `error code <error_codes_>`_
 | |
|   ``placement.concurrent_update`` at microversion 1.28 or higher if allocations
 | |
|   for the specified consumer have been created, updated, or removed by another
 | |
|   request while attempting the operation. See :ref:`generations`.
 | |
| 
 | |
| Request (microversions 1.12 - )
 | |
| -------------------------------
 | |
| 
 | |
| .. rest_parameters:: parameters.yaml
 | |
| 
 | |
|   - consumer_uuid: consumer_uuid
 | |
|   - allocations: allocations_dict
 | |
|   - resources: resources
 | |
|   - consumer_generation: consumer_generation_min
 | |
|   - consumer_type: consumer_type
 | |
|   - project_id: project_id_body
 | |
|   - user_id: user_id_body
 | |
|   - generation: resource_provider_generation_optional
 | |
|   - mappings: mappings_in_allocations
 | |
| 
 | |
| Request example (microversions 1.38 - )
 | |
| ---------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/update-allocations-request-1.38.json
 | |
|    :language: javascript
 | |
| 
 | |
| Request example (microversions 1.28 - 1.36)
 | |
| -------------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/update-allocations-request-1.28.json
 | |
|    :language: javascript
 | |
| 
 | |
| Request example (microversions 1.12 - 1.27)
 | |
| -------------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/update-allocations-request-1.12.json
 | |
|    :language: javascript
 | |
| 
 | |
| Request (microversions 1.0 - 1.11)
 | |
| ----------------------------------
 | |
| 
 | |
| .. rest_parameters:: parameters.yaml
 | |
| 
 | |
|   - consumer_uuid: consumer_uuid
 | |
|   - allocations: allocations_array
 | |
|   - resources: resources
 | |
|   - resource_provider: resource_provider_object
 | |
|   - uuid: resource_provider_uuid
 | |
|   - project_id: project_id_body_1_8
 | |
|   - user_id: user_id_body_1_8
 | |
| 
 | |
| Request example (microversions 1.0 - 1.11)
 | |
| ------------------------------------------
 | |
| 
 | |
| .. literalinclude:: ./samples/allocations/update-allocations-request.json
 | |
|    :language: javascript
 | |
| 
 | |
| Response
 | |
| --------
 | |
| 
 | |
| No body content is returned on a successful PUT.
 | |
| 
 | |
| Delete allocations
 | |
| ==================
 | |
| 
 | |
| Delete all allocation records for the consumer identified by
 | |
| `{consumer_uuid}` on all resource providers it is consuming.
 | |
| 
 | |
| .. rest_method:: DELETE /allocations/{consumer_uuid}
 | |
| 
 | |
| Normal Response Codes: 204
 | |
| 
 | |
| Error response codes: itemNotFound(404)
 | |
| 
 | |
| Request
 | |
| -------
 | |
| 
 | |
| .. rest_parameters:: parameters.yaml
 | |
| 
 | |
|   - consumer_uuid: consumer_uuid
 | |
| 
 | |
| Response
 | |
| --------
 | |
| 
 | |
| No body content is returned on a successful DELETE.
 |