ImageList
From Hostway API Documentation
				
								
				(Difference between revisions)
				
																
				
				
								
				|  (→JSON) | Mike.robski  (Talk | contribs)  m (1 revision: Release 86) | ||
| (16 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
| + | = GET /accounts/''{accountId}''/flexcloud/images?name=''{imageName}''&status=''{imageStatus}''&type=''{imageType}''&zone=''{zoneId}'' = | ||
| Lists all images. | Lists all images. | ||
| + | __TOC__ | ||
| + | == Request == | ||
| + | <code>GET /accounts/''{accountId}''/flexcloud/images?name=''{imageName}''&status=''{imageStatus}''&type=''{imageType}''&zone=''{zoneId}''</code> | ||
| − | ''' | + | === Parameters === | 
| + | ; accountId - ''string'' | ||
| + | : The selected account Id. | ||
| − | + | ; name - ''string'' | |
| + | : ''Optional'' image name to search for. | ||
| − | + | ; status - ''string'' | |
| − | + | : ''Optional'' Image status to search for. Values: '''ACTIVE''', '''SAVING''', '''DELETED'''. | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| + | ; type - ''string'' | ||
| + | : ''Optional'' type of the image to search for. Values: '''BASE''', '''SERVER'''. | ||
| + | ; zone - ''string'' | ||
| + | : ''Optional'' the zone where the image is available. | ||
| + | |||
| + | == Response == | ||
| + | |||
| + | === Status Code === | ||
| + | ; 200 OK | ||
| + | : Success | ||
| + | |||
| + | ; 401 Unauthorized | ||
| + | : Failure - This server could not verify that you are authorized to access the document you requested.  Either you supplied the wrong credentials (e.g., bad password), or your browser does not understand how to supply the credentials required. | ||
| + | |||
| + | ; 404 Not Found | ||
| + | : Failure - The Resource does not exist | ||
| + | |||
| + | === Response Body === | ||
| + |  <nowiki> | ||
| + | { | ||
| + |   "images":[ | ||
| + |     { | ||
| + |       "name":"{display_image_name}", | ||
| + |       "links":[ | ||
| + |         {"href":"</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"self"}, | ||
| + |         {"href":"</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"bookmark"} | ||
| + |       ], | ||
| + |       "id": "{image_id}", | ||
| + |       "zones": ["{zone_id_1}", "{zone_id_2}"] | ||
| + |     }, | ||
| + |     { | ||
| + |       "name":"{display_image_name}", | ||
| + |       "links":[ | ||
| + |         {"href":"</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"self"}, | ||
| + |         {"href":"</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"bookmark"} | ||
| + |       ], | ||
| + |       "id":"{image_id}", | ||
| + |       "zones": ["{zone_id}"] | ||
| + |     } | ||
| + |   ] | ||
| + | }</nowiki> | ||
| + | |||
| + | ==== Parameters ==== | ||
| ; id - ''string'' | ; id - ''string'' | ||
| : Unique identifier for this image. | : Unique identifier for this image. | ||
| Line 49: | Line 66: | ||
| ; name - ''string'' | ; name - ''string'' | ||
| − | :  | + | : Display name for this image. | 
| + | |||
| + | ; zones - ''string'' | ||
| + | : Zones where the image is available. | ||
| + | |||
| + | == Examples == | ||
| + | |||
| + | === Successfully list images === | ||
| + | '''Request''' | ||
| + |  <nowiki> | ||
| + | GET /accounts/{accountId}/flexcloud/images | ||
| + | Authorization: Basic {Base64-encoded username:password string} </nowiki> | ||
| + | |||
| + | '''Response''' | ||
| + |  <nowiki> | ||
| + | 200 OK | ||
| + | |||
| + | { | ||
| + |   "images": [ | ||
| + |     { | ||
| + |       "name": "test_public_image",  | ||
| + |       "links": [ | ||
| + |         {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/123/", "rel": "self"}, | ||
| + |         {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/123/", "rel": "bookmark"} | ||
| + |       ],  | ||
| + |       "id": "123", | ||
| + |       "zones": ["AUS001"] | ||
| + |     },  | ||
| + |     { | ||
| + |       "name": "test_debian_image",  | ||
| + |       "links": [ | ||
| + |         {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/290/", "rel": "self"}, | ||
| + |         {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/290/", "rel": "bookmark"} | ||
| + |       ],  | ||
| + |       "id": "290", | ||
| + |       "zones": ["AUS001"] | ||
| + |     }, | ||
| + |     { | ||
| + |       "name": "test_private_image",  | ||
| + |       "links":  [ | ||
| + |         {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/233/", "rel": "self"}, | ||
| + |         {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/233/", "rel": "bookmark"} | ||
| + |       ],  | ||
| + |       "id": "233", | ||
| + |       "zones": ["AUS001"] | ||
| + |     } | ||
| + |   ] | ||
| + | }</nowiki> | ||
| + | |||
| + | === Failure while trying to make an unauthorized request === | ||
| + | '''Request''' | ||
| + |  <nowiki> | ||
| + | GET /accounts/{accountId}/flexcloud/images | ||
| + | Authorization: Basic {invalid authorization} </nowiki> | ||
| + | |||
| + | '''Response''' | ||
| + |  <nowiki> | ||
| + | 401 Unauthorized </nowiki> | ||
| + | |||
| + | |||
| + | === Account Number not found === | ||
| + | '''Request''' | ||
| + |  <nowiki> | ||
| + | GET /accounts/fake/flexcloud/images | ||
| + | Authorization: Basic {Base64-encoded username:password string}</nowiki> | ||
| + | |||
| + | '''Response''' | ||
| + |  <nowiki> | ||
| + | { | ||
| + |     "itemNotFound": { | ||
| + |         "guid": "23684df5-0532-4794-802d-fdc82e4e7e7c", | ||
| + |         "message": "Resource not found", | ||
| + |         "code": 404, | ||
| + |         "details": "" | ||
| + |     } | ||
| + | }</nowiki> | ||
| + | |||
| + | == Alternative URI /images == | ||
| + | An alternative way to execute this call is to omit the ''accountId'' portion of the URI. In this case the system assumes the request is executed for the account identified in the [[Authentication|authorization header]]. | ||
| − | < | + | <code>GET /images</code> | 
| − | + | == See also == | |
| − | + | * [[FlexCloud Server|FlexCloud Server API]] | |
| − | + | * [[Common Features]] | |
| − | | | + | |
| − | + | ||
| − | + | {{disqus}} | |
| + | [[Category:Hostway API]] | ||
| + | [[Category:FlexCloud Server API]] | ||
Latest revision as of 12:00, 11 October 2013
[edit] GET /accounts/{accountId}/flexcloud/images?name={imageName}&status={imageStatus}&type={imageType}&zone={zoneId}
Lists all images.
| Contents | 
[edit] Request
GET /accounts/{accountId}/flexcloud/images?name={imageName}&status={imageStatus}&type={imageType}&zone={zoneId}
[edit] Parameters
- accountId - string
- The selected account Id.
- name - string
- Optional image name to search for.
- status - string
- Optional Image status to search for. Values: ACTIVE, SAVING, DELETED.
- type - string
- Optional type of the image to search for. Values: BASE, SERVER.
- zone - string
- Optional the zone where the image is available.
[edit] Response
[edit] Status Code
- 200 OK
- Success
- 401 Unauthorized
- Failure - This server could not verify that you are authorized to access the document you requested. Either you supplied the wrong credentials (e.g., bad password), or your browser does not understand how to supply the credentials required.
- 404 Not Found
- Failure - The Resource does not exist
[edit] Response Body
{
  "images":[
    {
      "name":"{display_image_name}",
      "links":[
        {"href":"https://api.hostway.com/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"self"},
        {"href":"https://api.hostway.com/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"bookmark"}
      ],
      "id": "{image_id}",
      "zones": ["{zone_id_1}", "{zone_id_2}"]
    },
    {
      "name":"{display_image_name}",
      "links":[
        {"href":"https://api.hostway.com/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"self"},
        {"href":"https://api.hostway.com/accounts/{accountId}/flexcloud/images/{image_id}/", "rel":"bookmark"}
      ],
      "id":"{image_id}",
      "zones": ["{zone_id}"]
    }
  ]
}
[edit] Parameters
- id - string
- Unique identifier for this image.
- links - array
- Hypermedia for this resource.
- name - string
- Display name for this image.
- zones - string
- Zones where the image is available.
[edit] Examples
[edit] Successfully list images
Request
GET /accounts/{accountId}/flexcloud/images
Authorization: Basic {Base64-encoded username:password string} 
Response
200 OK
{
  "images": [
    {
      "name": "test_public_image", 
      "links": [
        {"href": "https://api.hostway.com/accounts/{accountId}/flexcloud/images/123/", "rel": "self"},
        {"href": "https://api.hostway.com/accounts/{accountId}/flexcloud/images/123/", "rel": "bookmark"}
      ], 
      "id": "123",
      "zones": ["AUS001"]
    }, 
    {
      "name": "test_debian_image", 
      "links": [
        {"href": "https://api.hostway.com/accounts/{accountId}/flexcloud/images/290/", "rel": "self"},
        {"href": "https://api.hostway.com/accounts/{accountId}/flexcloud/images/290/", "rel": "bookmark"}
      ], 
      "id": "290",
      "zones": ["AUS001"]
    },
    {
      "name": "test_private_image", 
      "links":  [
        {"href": "https://api.hostway.com/accounts/{accountId}/flexcloud/images/233/", "rel": "self"},
        {"href": "https://api.hostway.com/accounts/{accountId}/flexcloud/images/233/", "rel": "bookmark"}
      ], 
      "id": "233",
      "zones": ["AUS001"]
    }
  ]
}
[edit] Failure while trying to make an unauthorized request
Request
GET /accounts/{accountId}/flexcloud/images
Authorization: Basic {invalid authorization} 
Response
401 Unauthorized
[edit] Account Number not found
Request
GET /accounts/fake/flexcloud/images
Authorization: Basic {Base64-encoded username:password string}
Response
{
    "itemNotFound": {
        "guid": "23684df5-0532-4794-802d-fdc82e4e7e7c",
        "message": "Resource not found",
        "code": 404,
        "details": ""
    }
}
[edit] Alternative URI /images
An alternative way to execute this call is to omit the accountId portion of the URI. In this case the system assumes the request is executed for the account identified in the authorization header.
GET /images
[edit] See also
