2015-10-16 21:23:24 +00:00
|
|
|
***********************
|
|
|
|
Orders API - User Guide
|
|
|
|
***********************
|
|
|
|
|
2016-03-04 20:56:45 +00:00
|
|
|
The orders resource allows the user to request barbican to generate a secret.
|
2017-05-04 05:02:23 +00:00
|
|
|
This is also very helpful for requesting the creation of public/private key pairs.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
The orders resource supports the following types:
|
|
|
|
* symmetric keys
|
|
|
|
* asymmetric keys
|
2016-11-03 01:24:22 +00:00
|
|
|
|
2015-10-16 21:23:24 +00:00
|
|
|
This user guide provides high level examples of the orders resource.
|
2016-03-04 20:56:45 +00:00
|
|
|
It will assume you will be using a local running development environment of barbican.
|
2016-02-24 19:24:32 +00:00
|
|
|
If you need assistance with getting set up, please reference the
|
2017-07-21 07:50:11 +00:00
|
|
|
`development guide <https://docs.openstack.org/barbican/latest/contributor/dev.html>`__.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
.. _create_order:
|
|
|
|
|
|
|
|
Creating an Order
|
|
|
|
#################
|
|
|
|
|
2016-03-04 20:56:45 +00:00
|
|
|
When you want barbican to generate a secret you need to create an order.
|
2017-01-30 19:25:58 +00:00
|
|
|
For an order to be processed correctly the parameters mode,
|
|
|
|
bit_length, and algorithm must be valid. Otherwise the order will fail and
|
2015-10-16 21:23:24 +00:00
|
|
|
the secret will not be generated. The example below shows a valid order for
|
|
|
|
generating a symmetric key. You can find a more detailed explanation about
|
2016-02-24 19:24:32 +00:00
|
|
|
the parameters in the
|
2017-07-21 07:50:11 +00:00
|
|
|
`Orders API <https://docs.openstack.org/barbican/latest/api/reference/orders.html>`__
|
2016-02-24 19:24:32 +00:00
|
|
|
documentation.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
curl -X POST -H "X-Auth-Token: $TOKEN" -H "content-type:application/json" -d '{
|
|
|
|
"type":"key", "meta": { "name": "secretname", "algorithm": "aes",
|
|
|
|
"bit_length": 256, "mode": "cbc", "payload_content_type": "application/octet-stream"}
|
|
|
|
}' http://localhost:9311/v1/orders
|
|
|
|
|
2017-01-30 19:25:58 +00:00
|
|
|
You should receive an order reference after placing your order with barbican.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
2017-01-30 19:25:58 +00:00
|
|
|
{"order_ref": "http://localhost:9311/v1/orders/3a5c6748-44de-4c1c-9e54-085c3f79e942"}
|
2015-10-16 21:23:24 +00:00
|
|
|
|
2017-01-30 19:25:58 +00:00
|
|
|
The order reference is used to retrieve the metadata for the order you placed
|
2015-10-16 21:23:24 +00:00
|
|
|
which can then be used to retrieve your secret.
|
|
|
|
|
|
|
|
.. _retrieve_order:
|
|
|
|
|
|
|
|
Retrieving an Order
|
|
|
|
###################
|
|
|
|
|
|
|
|
In order to retrieve the order we will use the reference returned during
|
|
|
|
the initial creation. (See :ref:`Creating an Order <create_order>`.)
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
curl -H "X-Auth-Token: $TOKEN" -H 'Accept:application/json' \
|
|
|
|
http://localhost:9311/v1/orders/3a5c6748-44de-4c1c-9e54-085c3f79e942
|
|
|
|
|
|
|
|
The typical response is below:
|
|
|
|
|
|
|
|
.. code-block:: json
|
|
|
|
|
|
|
|
{
|
|
|
|
"created": "2015-10-15T18:15:10",
|
|
|
|
"creator_id": "40540f978fbd45c1af18910e3e02b63f",
|
|
|
|
"meta": {
|
|
|
|
"algorithm": "AES",
|
|
|
|
"bit_length": 256,
|
|
|
|
"expiration": null,
|
|
|
|
"mode": "cbc",
|
|
|
|
"name": "secretname",
|
|
|
|
"payload_content_type": "application/octet-stream"
|
|
|
|
},
|
|
|
|
"order_ref": "http://localhost:9311/v1/orders/3a5c6748-44de-4c1c-9e54-085c3f79e942",
|
|
|
|
"secret_ref": "http://localhost:9311/v1/secrets/bcd1b853-edeb-4509-9f12-019b8c8dfb5f",
|
|
|
|
"status": "ACTIVE",
|
|
|
|
"sub_status": "Unknown",
|
|
|
|
"sub_status_message": "Unknown",
|
|
|
|
"type": "key",
|
|
|
|
"updated": "2015-10-15T18:15:10"
|
|
|
|
}
|
|
|
|
|
|
|
|
This is the metadata associated with the order.
|
|
|
|
To retrieve the secret generated by the order, refer to the :doc:`Secrets User Guide <secrets>`.
|
|
|
|
The order metadata is very useful for determining if your order was processed
|
|
|
|
correctly. Since orders are processed asynchronously, you can use the metadata
|
|
|
|
returned for the order to verify a successful secret creation.
|
2016-02-24 19:24:32 +00:00
|
|
|
The parameters of the response are explained in more detail
|
2017-07-21 07:50:11 +00:00
|
|
|
`here <https://docs.openstack.org/barbican/latest/api/reference/orders.html#get-unique-order-response-attributes>`__.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
.. _retrieve_order_list:
|
|
|
|
|
|
|
|
Retrieving All Orders
|
|
|
|
#####################
|
|
|
|
|
|
|
|
It is also possible to retrieve all orders for a project.
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
curl -H "X-Auth-Token: $TOKEN" -H 'Accept:application/json' http://localhost:9311/v1/orders
|
|
|
|
|
|
|
|
.. code-block:: json
|
|
|
|
|
|
|
|
{
|
|
|
|
"orders": [
|
|
|
|
{
|
|
|
|
"created": "2015-10-15T18:15:10",
|
|
|
|
"creator_id": "40540f978fbd45c1af18910e3e02b63f",
|
|
|
|
"meta": {
|
|
|
|
"algorithm": "AES",
|
|
|
|
"bit_length": 256,
|
|
|
|
"expiration": null,
|
|
|
|
"mode": "cbc",
|
|
|
|
"name": "secretname",
|
|
|
|
"payload_content_type": "application/octet-stream"
|
|
|
|
},
|
|
|
|
"order_ref": "http://localhost:9311/v1/orders/3a5c6748-44de-4c1c-9e54-085c3f79e942",
|
|
|
|
"secret_ref": "http://localhost:9311/v1/secrets/bcd1b853-edeb-4509-9f12-019b8c8dfb5f",
|
|
|
|
"status": "ACTIVE",
|
|
|
|
"sub_status": "Unknown",
|
|
|
|
"sub_status_message": "Unknown",
|
|
|
|
"type": "key",
|
|
|
|
"updated": "2015-10-15T18:15:10"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"created": "2015-10-15T18:51:35",
|
|
|
|
"creator_id": "40540f978fbd45c1af18910e3e02b63f",
|
|
|
|
"meta": {
|
|
|
|
"algorithm": "AES",
|
|
|
|
"bit_length": 256,
|
|
|
|
"mode": "cbc",
|
|
|
|
"expiration": null,
|
|
|
|
"name": null
|
|
|
|
},
|
|
|
|
"order_ref": "http://localhost:9311/v1/orders/d99ced51-ea7a-4c14-8e11-0dda0f49c5be",
|
|
|
|
"secret_ref": "http://localhost:9311/v1/secrets/abadd306-8235-4f6b-984a-cc48ad039def",
|
|
|
|
"status": "ACTIVE",
|
|
|
|
"sub_status": "Unknown",
|
|
|
|
"sub_status_message": "Unknown",
|
|
|
|
"type": "key",
|
|
|
|
"updated": "2015-10-15T18:51:35"
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"total": 2
|
|
|
|
}
|
|
|
|
|
2016-02-24 19:24:32 +00:00
|
|
|
You can refer to the
|
2017-07-21 07:50:11 +00:00
|
|
|
`orders parameters <https://docs.openstack.org/barbican/latest/api/reference/orders.html#get-order-parameters>`__
|
2016-02-24 19:24:32 +00:00
|
|
|
section of the
|
2017-07-21 07:50:11 +00:00
|
|
|
`Orders API <https://docs.openstack.org/barbican/latest/api/reference/orders.html>`__
|
2016-02-24 19:24:32 +00:00
|
|
|
documentation in order to refine your search among orders.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
.. _delete_order:
|
|
|
|
|
|
|
|
Deleting an Order
|
|
|
|
#################
|
|
|
|
|
2016-03-04 20:56:45 +00:00
|
|
|
It is also possible to delete an order from barbican.
|
2015-10-16 21:23:24 +00:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
curl -X DELETE -H "X-Auth-Token: $TOKEN" -H 'Accept:application/json' http://localhost:9311/v1/orders/fbdd845f-4a5e-43e3-8f68-64e8f106c486
|
|
|
|
|
|
|
|
Nothing will be returned when you delete an order.
|
|
|
|
If something was returned there was most likely an error while deleting
|
2016-03-04 20:56:45 +00:00
|
|
|
the order.
|