Jump to: navigation, search

Heat/GrizzlySummit/HeatApiDraftDiscussion

< Heat‎ | GrizzlySummit
Revision as of 14:40, 11 October 2012 by ZaneB (talk) (Add current API docs)

Session Lead: Steven Dake

Session Title: Heat Orchestration API draft design session

Session Description:

Overview of the template format currently implemented in heat. Overview of the API heat provides for operating on templates.

In this design session, expect 75% of time spent in open community design session on improvements to API and template model.

Heat OpenStack API Reference

See https://github.com/heat-api/heat/blob/master/docs/api.md for the latest version.

List Stacks

GET /v1/{tenant_id}/stacks


Parameters:

  • `tenant_id` The unique identifier of the tenant or account

Create Stack

POST /v1/{tenant_id}/stacks

{
    "stack_name": "{stack_name}",
    "template_url": "{template_url}",
    "parameters": {
        "{key1}": "{value1}",
        "{key2}": "{value2}"
    },
    "timeout_mins": {timeout_mins}
}


Parameters:

  • `tenant_id` The unique identifier of the tenant or account
  • `stack_name` The name of the stack to create
  • `template_url` The URL of the template to instantiate
  • `template` A JSON template to instantiate - this takes precendence over the `template_url` if both are supplied
  • `keyn`, `valuen` User-defined parameters to pass to the Template
  • `timeout_mins` The timeout for stack creation in minutes

Result:


HTTP/1.1 201 Created
Location: http://heat.example.com:8004/v1/{tenant_id}/stacks/{stack_name}/{stack_id}


Find Stack ID

GET /v1/{tenant_id}/stacks/{stack_name}


Parameters:

  • `stack_name` The name of the stack to look up

Result:


HTTP/1.1 302 Found
Location: http://heat.example.com:8004/v1/{tenant_id}/stacks/{stack_name}/{stack_id}


This operation also works with verbs other than `GET`, so you can also use it to perform `PUT` and `DELETE` operations on a current stack. Just set your client to follow redirects. Note that when redirecting, the request method should **not** change, as defined in [RFC2626](http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html#sec10.3.3). However, in many clients the default behaviour is to change the method to `GET` when receiving a 302 because this behaviour is ubiquitous in web browsers.

Get Stack Data

GET /v1/{tenant_id}/stacks/{stack_name}/{stack_id}


Parameters:

  • `stack_name` The name of the stack to look up
  • `stack_id` The unique identifier of the stack to look up

Retrieve Stack Template

GET /v1/{tenant_id}/stacks/{stack_name}/{stack_id}/template


Parameters:

  • `stack_name` The name of the stack to look up
  • `stack_id` The unique identifier of the stack to look up

Update Stack

PUT /v1/{tenant_id}/stacks/{stack_name}/{stack_id}

{
    "template_url": "{template_url}",
    "parameters": {
        "{key1}": "{value1}",
        "{key2}": "{value2}"
    },
    "timeout_mins": {timeout_mins}
}


Parameters:

  • `tenant_id` The unique identifier of the tenant or account
  • `stack_name` The name of the stack to create
  • `stack_id` The unique identifier of the stack to look up
  • `template_url` The URL of the updated template
  • `template` An updated JSON template - this takes precendence over the `template_url` if both are supplied
  • `keyn`, `valuen` User-defined parameters to pass to the Template
  • `timeout_mins` The timeout for stack creation in minutes

Result:


HTTP/1.1 202 Accepted


Delete Stack

DELETE /v1/{tenant_id}/stacks/{stack_name}/{stack_id}


Parameters:

  • `tenant_id` The unique identifier of the tenant or account
  • `stack_name` The name of the stack to create
  • `stack_id` The unique identifier of the stack to look up

Result:


HTTP/1.1 204 No Content


Validate Template

POST /v1/{tenant_id}/validate

{
    "template_url": "{template_url}",
    "parameters": {
        "{key1}": "{value1}",
        "{key2}": "{value2}"
    }
}


Parameters:

  • `tenant_id` The unique identifier of the tenant or account
  • `template_url` The URL of the template to validate
  • `template` A JSON template to validate - this takes precendence over the `template_url` if both are supplied.
  • `keyn`, `valuen` User-defined parameters to pass to the Template