Appliance manager template API upload and download

Abiquo uploads templates using the Appliance Manager (AM) Remote Service. To enable API template upload, Abiquo exposes a resource from the private AM API. The authentication for the use of this resource is performed through the Abiquo API.

This section describes how to upload:

  • a standard template to the Appliance Manager using the Appliance Manager API

  • an OVA file to the Appliance Manager using the Appliance Manager API


Template files

To upload a standard template you will need:

  • diskFile

    • one virtual machine disk file, e.g. .vmdk file

  • diskInfo

    • JSON or XML representation of the template metadata

To upload an OVA file you will need:

  • diskFile

    • OVA format with a filename extension of ".ova"

    • can contain multiple disks

    • no need to provide template metadata, e.g. disk capacity, because this is in the OVF descriptor file


Preparatory steps

Step 1. Retrieve the appliance manager base URI

curl -X GET https://myabiquo/api/admin/datacenters/1/remoteservices

 

{ "id": 3, "links": [ { "href": "https://myabiquo:443/api/admin/remoteservices/3", "rel": "edit", "title": "APPLIANCEMANAGER", "type": "application/vnd.abiquo.remoteservice+json" }, { "href": "https://myabiquo:443/api/admin/remoteservices/3/action/check", "rel": "check", "title": "check", "type": "" }, { "href": "https://myabiquo:443/api/admin/datacenters/1", "rel": "datacenter", "title": "BCDC", "type": "application/vnd.abiquo.datacenter+json" } ], "status": 1, "type": "APPLIANCE_MANAGER", "uri": "https://myabiquo:443/am", "uuid": "Abiquo" },

Step 2. For a standard template, specify the template meta-data in JSON or XML

Sample JSON template

{ "name":"a new template", "description":"this is a test", "categoryName":"simpaticos", "diskFileFormat":"VMDK_FLAT", "requiredCpu":1, "requiredHDInMB":2, "requiredRamInMB":256 }

Sample XML template

 

TIP: use qemu-img to determine the diskFileFormat and requiredHDInMB (=capacity for compressed formats)


Upload standard template example

The following example shows how to upload a single disk file named 'disk.vmdk' and metadata stored in file 'template.json' for the enterprise with id '1'

In the returned 'Location' header there is a link to reference the template that was created.


Check the upload

Get the metadata:

Get the template content:


Identify your template in the API

The relative path (1/10.60.1.223/1fc06416-6696-4b55-9d7c-d58bc51aaf5a/disk.vmdk) should be used to identify the virtual machine template you created in the abiquo API


Upload OVA template example

To upload an OVA template, start by reading the above sections that describe the #Template Files and the #Preparatory Steps.

The following example shows how to upload an OVA file, which may have multiple VM disk files. Include the template and disk details in the OVF descriptor file inside the OVA. Do not supply a diskInfo file for the template because this information is included in the OVA file. Supply the OVA file with the filename extension of ".ova". 

Use the same link as for standard template upload.

In the response 'Location' header there is a link to reference the template that was created.

Copyright © 2006-2024, Abiquo Holdings SL. All rights reserved