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