Skip to content

REST: Environments related API

bugzmanov edited this page Jan 22, 2013 · 29 revisions

List existing environments

Path: /rest/projects/(projectId)/envs
Type: GET
Path parameters

Parameter Type Description
projectId Number project id of the project envs belong to

Request parameters

Parameter Type Mandatory Description
filter String N Sets filter's values. Currently possible filtering on the status of the environment.

Example: filter=statuses[Destroyed,Broken]

sorting String N Sorting by entity field value. By default ordering direction is ascending. Use prefix '~' to produce result in descending order. Example: sorting=~name

Example results

[
    {
        "id" : 1,
        "name":"test",
        "status":"Ready",
        "creator":"genesis",
        "templateName":"ErlangAmazon",
        "templateVersion":"0.1"
    }
]

Create a new environment

Path: /rest/projects/(projectId)/envs

Type: POST

Parameter Type Description
projectId Number project id the created env should belong to


Request body structure
Request body consists form a single JSON map contains the following entries:

Entry name Type Description
envName String Environment name
creator String Environment creator name. Parameter is optional. Service uses current user identity to set creator.
templateName String Name of the Environment template to use
templateVersion String Version of the Environment template to use
configId Integer Configuration (environment) id. Optional parameter. If omitted, default environment is used.
variables Map of String pairs Creation workflow variable values customized by user
timeToLive Integer time to live of the environment (in minutes). optional

Example request :

{
  "envName" : "erlt",
  "templateName" : "Erlang",
  "templateVersion" : "2.0",
  "variables":{"nodesCount": 4}
}

Example results

Sucessful environment creation

{
    "serviceErrors":{},
    "variablesErrors":{},
    "compoundServiceErrors":[],
    "compoundVariablesErrors":[],
    "isSuccess":true
}

Environment creation failed, environment with the same name already exists

{
    "serviceErrors":{
        "envName":"Environment with the same name already exists"
    },
    "variablesErrors":{},
    "compoundServiceErrors":[],
    "compoundVariablesErrors":[],
    "isSuccess":false
}

Environment creation failed, required variable is not set

{
    "serviceErrors":{},
    "variablesErrors":{
        "nodesCount":"Variable 'nodesCount' is not set"
    },
    "compoundServiceErrors":[],
    "compoundVariablesErrors":[],
    "isSuccess":false
}

Delete existing environment

Path: /rest/projects/(projectId)/envs/(environment id)
Type: DELETE

Path parameters:

Parameter Type Description
projectId Number project id the created env should belong to
environment id Number Identifier of the environment to be deleted


Example results: see example results for environment creation

Get environment details

Path: /rest/projects/(projectId)/envs/(environment id)
Type: GET

Path parameters:

Parameter Type Description
projectId Number project id the env belong to
environment id Number Identifier of the environment

**Example results**
{
    "id" : 1,
    "name":"test",
    "status":"Ready",
    "creator":"genesis",
    "templateName":"ErlangAmazon",
    "templateVersion":"0.1",
    "workflows":[
        {
            "name":"create",
            "variables":[
                {
                    "name":"nodesCount",
                    "description":"Erlang worker nodes count"
                }
            ]
        },
        {
            "name":"destroy",
            "variables":[]
        },
        {
            "name":"scale-up",
            "variables":[
                {
                    "name":"nodesCount",
                    "description":"Erlang worker nodes count"
                }
            ]
        }
    ],
    "createWorkflowName":"create",
    "destroyWorkflowName":"destroy",
    "vms":[
        {
            "envName":"test",
            "roleName":"erlangNode",
            "hostNumber":1,
            "instanceId":"eu-west-1/i-aa838edc",
            "hardwareId":"m1.small",
            "imageId":"eu-west-1/ami-359ea941",
            "publicIp":"46.137.40.65",
            "privateIp":"10.226.106.227",
            "status":"Ready"
        }
    ],
    "historyCount":1,
    "workflowCompleted":0.23
}

Change status of environment from 'Broken' to 'Ready'

Path: /rest/projects/(projectId)/envs/(environment id)/actions
Type: POST

Path parameters:

Parameter Type Description
projectId Number project id the env belong to
environment id Number Identifier of the environment

Request body structure

Request body consists form a single JSON object that contains single key with predefined value:

Entry name Entry value Type Description
action resetEnvStatus String key with specific value

Example request:

{
    "action": "resetEnvStatus"
}

Example results: see examples of common result object

Get workflows history

Path: /rest/projects/(projectId)/envs/(environment id)/history?page_offset=(number)&page_length=(number)
Type: GET

Path parameters:

Parameter Type Description
projectId Number project id the env belong to
environment id Number Identifier of the environment

Request parameters:

Parameter Type Description
page_offset Number number of the first record in a selection
page_length Number count of the records in a selection

Example results

{
    "history":[
        {
            "name":"destroy",
            "status":"Failed",
            "stepsCompleted":0.0,
            "steps":[
                {
                    "stepId":"52",
                    "phase":"destroy",
                    "status":"Failed",
                    "details":"Chef environment destruction"
                },
                {
                    "stepId":"53",
                    "phase":"destroy",
                    "status":"Succeed",
                    "details":"Environment destruction"
                }
            ],
            "executionStartedTimestamp":1341311242607
        },
        {
            "name":"create",
            "status":"Failed",
            "stepsCompleted":0.43,
            "steps":[
                {
                   "stepId":"41",
                   "phase":"provision",
                   "status":"Succeed",
                   "details":"Virtual machine(s) provisioning { quantity = 1, role = dbnode, image id = 45, hardware id = 3, ip address = unspecified, security group = unspecified, instance id = unspecified }"
                },
                {
                   "stepId":"42",
                   "phase":"provision",
                   "status":"Succeed",
                   "details":"Virtual machine(s) provisioning { quantity = 1, role = xwikinode, image id = 45, hardware id = 3, ip address = unspecified, security group = unspecified, instance id = unspecified }"
                },
                {
                   "stepId":"43",
                   "phase":"provision",
                   "status":"Succeed",
                   "details":"Virtual machine(s) provisioning { quantity = 1, role = lbnode, image id = 45, hardware id = 3, ip address = unspecified, security group = unspecified, instance id = unspecified }"
                },
                {
                   "stepId":"44",
                   "phase":"createdatabag",
                   "status":"Failed",
                   "details":"Chef databag creation { databag = xwiki }"
                },
                {
                   "stepId":"45",
                   "phase":"deploydb",
                   "status":"Requested",
                   "details":"Chef recipe execution { receipes = [ recipe[xwiki::db] ] }"
                },
                {
                   "stepId":"46",
                   "phase":"deployxwiki",
                   "status":"Requested",
                   "details":"Chef recipe execution { receipes = [ recipe[xwiki::app] ] }"
                },
                {
                   "stepId":"47",
                   "phase":"deploylb",
                   "status":"Requested",
                   "details":"Chef recipe execution { receipes = [ recipe[xwiki::lb] ] }"
                }
            ],
            "executionStartedTimestamp":1341310956532
        }
    ],
    "totalCount":2,
}

Set new time to live (time period before automatic destruction) for environment

Path: /rest/projects/(projectId)/envs/(environment id)/timeToLive
Type: PUT

Path parameters:

Parameter Type Description
projectId Number project id the env belong to
environment id Number Identifier of the environment

Request body structure

Request body consists form a single JSON object that contains single key with predefined value:

Entry name Type Description
value Number New time to live value in minutes

Example request

{
  "value": 5
}

Remove time to live restrictions (time frame before automatic destruction) from environment

Path: /rest/projects/(projectId)/envs/(environment id)/timeToLive
Method Type: DELETE

Path parameters:

Parameter Type Description
projectId Number project id the env belong to
environment id Number Identifier of the environment
Clone this wiki locally