ImageList

From Hostway API Documentation
(Difference between revisions)
Jump to: navigation, search
(JSON)
m (1 revision: Release 86)
 
(12 intermediate revisions by 3 users not shown)
Line 1: Line 1:
This operation will list all images.
+
= GET /accounts/''{accountId}''/flexcloud/images?name=''{imageName}''&status=''{imageStatus}''&type=''{imageType}''&zone=''{zoneId}'' =
 +
Lists all images.
 +
__TOC__
 +
== Request ==
 +
<code>GET /accounts/''{accountId}''/flexcloud/images?name=''{imageName}''&status=''{imageStatus}''&type=''{imageType}''&zone=''{zoneId}''</code>
  
'''GET''' /images
+
=== Parameters ===
 +
; accountId - ''string''
 +
: The selected account Id.
  
== Parameters ==
+
; name - ''string''
No parameters
+
: ''Optional'' image name to search for.
  
== Result ==
+
; status - ''string''
=== JSON ===
+
: ''Optional'' Image status to search for. Values: '''ACTIVE''', '''SAVING''', '''DELETED'''.
<big><source lang="javascript">
+
{
+
  "images":[
+
      {
+
        "name":"{display_image_name}",
+
        "links":[
+
            {
+
              "href":"http://{api_server}/images/{image_id}/",
+
              "rel":"self"
+
            },
+
            {
+
              "href":"http://{api_server}/images/{image_id}/",
+
              "rel":"bookmark"
+
            }
+
        ],
+
        "id":"{image_id}"
+
      },
+
      {
+
        "name":"{display_image_name}",
+
        "links":[
+
            {
+
              "href":"http://{api_server}/images/{image_id}/",
+
              "rel":"self"
+
            },
+
            {
+
              "href":"http://{api_server}/images/{image_id}/",
+
              "rel":"bookmark"
+
            }
+
        ],
+
        "id":"{image_id}"
+
      }
+
  ]
+
}
+
</source></big>
+
  
 +
; 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 53: Line 68:
 
: Display name for this image.
 
: Display name for this image.
  
== Response Codes ==
+
; zones - ''string''
; Success: HTTP/1.1 200 OK
+
: Zones where the image is available.
 
+
; Failure: HTTP/1.1 401 Unauthorized - 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.
+
  
 
== Examples ==
 
== Examples ==
'''List images'''
 
:'''GET''' {api_server}/images
 
  
''Request Headers:''
+
=== Successfully list images ===
    Content-Type:application/json
+
'''Request'''
    Charset=UTF-8
+
<nowiki>
    Authorization:Base64-encoded username & password string
+
GET /accounts/{accountId}/flexcloud/images
 +
Authorization: Basic {Base64-encoded username:password string} </nowiki>
  
''Response Code:''
+
'''Response'''
<pre>HTTP/1.1 200 OK</pre>
+
<nowiki>
 +
200 OK
  
''Response Body:''
+
{
<big><source lang="javascript">
+
  "images": [
    {
+
    {
      "images": [
+
      "name": "test_public_image",  
          {
+
      "links": [
            "name": "dimitrov_public_image",  
+
        {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/123/", "rel": "self"},
            "links": [
+
        {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/123/", "rel": "bookmark"}
                {
+
      ],  
                  "href": "http://{api_server}/images/vmi2011Nov08_2D2fLloqt/",  
+
      "id": "123",
                  "rel": "self"
+
      "zones": ["AUS001"]
                },  
+
    },  
                {
+
    {
                  "href": "http://{api_server}/images/vmi2011Nov08_2D2fLloqt/",  
+
      "name": "test_debian_image",  
                  "rel": "bookmark"
+
      "links": [
                }
+
        {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/290/", "rel": "self"},
            ],  
+
        {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/290/", "rel": "bookmark"}
            "id": "vmi2011Nov08_2D2fLloqt"
+
      ],  
          },  
+
      "id": "290",
          {
+
      "zones": ["AUS001"]
            "name": "debian",  
+
    },
            "links": [
+
    {
                {
+
      "name": "test_private_image",  
                    "href": "http://{api_server}/images/debian_lenny_template/",  
+
      "links":  [
                    "rel": "self"
+
        {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/233/", "rel": "self"},
                },  
+
        {"href": "</nowiki>{{APIBaseURL}}<nowiki>/accounts/{accountId}/flexcloud/images/233/", "rel": "bookmark"}
                {
+
      ],  
                    "href": "http://{api_server}/images/debian_lenny_template/",  
+
      "id": "233",
                    "rel": "bookmark"
+
      "zones": ["AUS001"]
                }
+
              ],  
+
              "id": "debian_lenny_template"
+
          },  
+
          {
+
            "name": "test by shimde",
+
            "links": [
+
                {
+
                    "href": "http://{api_server}/images/vmi2011Dec26_2C7D8Dbur/",
+
                    "rel": "self"
+
                },
+
                {
+
                    "href": "http://{api_server}/images/vmi2011Dec26_2C7D8Dbur/",
+
                    "rel": "bookmark"
+
                }
+
              ],
+
              "id": "vmi2011Dec26_2C7D8Dbur"
+
          },  
+
          {
+
              "name": "jello_private_image",  
+
              "links":  [
+
                  {
+
                    "href": "http://{api_server}/images/vmi2011Nov08_xBHzvNEy8/",  
+
                    "rel": "self"
+
                  },
+
                  {
+
                    "href": "http://{api_server}/images/vmi2011Nov08_xBHzvNEy8/",  
+
                    "rel": "bookmark"}],  
+
              "id": "vmi2011Nov08_xBHzvNEy8"
+
          }
+
      ]
+
 
     }
 
     }
</source></big>
+
  ]
 +
}</nowiki>
  
 +
=== Failure while trying to make an unauthorized request ===
 +
'''Request'''
 +
<nowiki>
 +
GET /accounts/{accountId}/flexcloud/images
 +
Authorization: Basic {invalid authorization} </nowiki>
  
'''Unauthorized request'''
+
'''Response'''
:'''GET''' {server_name}/images
+
<nowiki>
 +
401 Unauthorized </nowiki>
  
''Request Headers:''
 
    Content-Type:application/json
 
  
''Response Code:''
+
=== Account Number not found ===
<pre>HTTP/1.1 401 Unauthorized</pre>
+
'''Request'''
 +
<nowiki>
 +
GET /accounts/fake/flexcloud/images
 +
Authorization: Basic {Base64-encoded username:password string}</nowiki>
  
''Response Body:''
+
'''Response'''
    401 Unauthorized
+
<nowiki>
    This server could not verify that you are authorized to
+
{
    access the document you requested.  Either you supplied the
+
    "itemNotFound": {
    wrong credentials (e.g., bad password), or your browser
+
        "guid": "23684df5-0532-4794-802d-fdc82e4e7e7c",
    does not understand how to supply the credentials required.
+
        "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]].
  
<!--  THIS CODE ENABLES DISQUS COMMENTS ON THE PAGE - DELETE TO DISABLE COMMENTING-->
+
<code>GET /images</code>
  
{{#widget:DISQUS
+
== See also ==
|id=hostway
+
* [[FlexCloud Server|FlexCloud Server API]]
|uniqid={{PAGENAME}}
+
* [[Common Features]]
|url={{fullurl:{{PAGENAME}}}}
+
}}
+
  
<!--  ########################################################################### -->
+
{{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


blog comments powered by Disqus

Personal tools
Namespaces
Variants
Actions
APIs
Navigation
Toolbox