To create a new Virtual Machine, send a POST request to /v2/vm. The attribute values that must be set to successfully create a Virtual Machine are marked with a in the following table:
Attribute | Description | Type | Ref URI | Options | Default | Required |
---|
admin_email | Administrator's email | string | - | - | User's email number submitting the request | - |
admin_name | Administrator's name | string | - | - | User's name number submitting the request | - |
admin_phone | Administrator's phone number | string | - | - | User's phone number submitting the request | - |
bill_deptclient | Billing Client Department | string | - | - | - | |
built_from | Build process. If you are installing OS from scratch use os_install. Clone when deploying a VM from a running or powered off virtual Machine. Template gives the ability to deploy multiple VMs at the same time. | string | - | os_install clone template image contentlib | - |
|
cpu | CPU count and core per sockets: Code Block |
---|
{
"count": 4,
"cpu_per_socket": 2
} |
| integer or object | - | - | {"count": 1, "cpu_per_socket": 1} | - |
description | Short description of the service or application. This will be part of the annotations field. | string | - | - | - | | disks | Disks in GigaBytes. | array |
scsi | SCSI controllers layout. Info |
---|
Introduced in v2021.6.0. |
| array of strings or array of objects | - | - | [ | 40"paravirtual", "lsilogic"] | - |
high_io | If set to true,VM will be created with a VMware Paravirtual SCSIController. PVSCSI controllers are best suited for environments, especially SAN environments, running I/O-intensive applications. | boolean | - | True False | False | - |
domain | Fault domain moId (Managed Object Identifier) | string | /v2/domain | - | Fault Domain 3 | - |
folder | Folder moId (Managed Object Identifier) | string | /v2/folder | - | - | |
inform | Informational comma separated emails | string | - | - | User's email submitting the request | - |
iso | ISO image path to be mounted after creation | string | /v2/iso | - | [ {"type": "lsilogic", "bus": 0}, {"type": "paravirtual", "bus": 1} ] | - |
disks | Disks in Gigabytes. | array of strings or array of objects | - | - | [40] [ {"capacity_gb": 40, "backing_mode": "persistent", "backing_sharing": "nosharing", "scsi": 0}, {"capacity_gb": 200, "backing_mode": "persistent", "backing_sharing": "nosharing", "scsi": 1} ] | - |
high_io | If set to true,VM will be created with a VMware Paravirtual SCSIController. PVSCSI controllers are best suited for environments, especially SAN environments, running I/O-intensive applications. Warning |
---|
Deprecated in v2021.6.0. |
| boolean | - | True False | False | - |
domain | Fault domain moId (Managed Object Identifier) | string | /v2/domain | - | Fault Domain | - |
folder | Folder moId (Managed Object Identifier) | string | /v2/folder | - | - | |
inform | Informational comma separated emails or list of email addresses. | string or list of strings | - | - | User's email submitting the request | - |
iso | ISO image path to be mounted after creation | string | /v2/iso | - | None | - |
memory | Memory in GB | integer | - | - | 1 | - |
name | Human readable name without the VSS Prefix. This prefix will be added before creation. | string | - | - | Randomly generated | - |
networks | Managed Object Identifier (moId) array.interface controller object. Code Block |
---|
[{"network": "moref-or-name", "type": "valid-type"}] |
Each network will be attached to a Network Adapter VMXNET3NIC type specified or if not, vmxnet3, the most recent virtual network device from VMware, and was designed from scratch for high performance and to support new features. | array | /v2/network | - | Unaccessible VLAN | - |
os | Supported guest operating system identifier. | string | /v2/os | - | - | |
usage | Virtual Machine usage. Prod for Production, Test for testing, QA for Quality Assurance, and Dev for Development. | string | - | Prod Test QA Dev | Test | - |
notes | Custom Notes in key value format to store Client notes to be stored in the Virtual Machine annotation as meta-dataannotation field. | dictstring | - | - | - | - |
source_vm | Source Virtual Machine Moref or Uuid. | string | /v2/vm
| - | - | only with clone |
source_vm_template | Source Virtual Machine Template Uuid. | stringsnap_id | Clone virtual machine from source snapshot | integer | /v2/vm/<id>/ | templatesnapshot | - | - | only with templateclone |
source_imageclib | Source OVA/OVF Virtual Machine file stored in VSKEY-STORDeployable (VM or OVF) Content Library item name or ID. | string | /v2/contentlib/ | image- | - | item |
|
| only with contentlib |
source_template | Source Virtual Machine Template Moref or UUID. | string | /v2/template | - | - | only with template |
source_image | Source OVA/OVF Virtual Machine file stored in VSKEY-STOR | string | /v2/image | - | - | only with image |
user_data | Cloud-init user_data to preconfigure the guest os upon first boot. Note: Experimental feature and currently tested with Ubuntu Cloud Images and VMware Photon OS. Only supported on OVA/OVF deployments. | string | - | - | - | - |
extra_config | Allows to set VMware to Set VMware guestinfo interface properties which are available to the VM at boot timeguest operating system via VMware Tools. These properties are stored within in the VMX file prefixed with "guestinfo.Only supported on OVA/OVF deployments". | dictarray of objects | - | - | - | - |
A new virtual machine can be created with as few as the following attributes in JSON format:
Code Block |
---|
language | py |
---|
title | Request Body |
---|
|
{"usage": "Prod",
"os": "ubuntu64Guest",
"built_from": "os_install",
"bill_dept": "EIS",
"description": "Java web application.",
"folder": "group-v4122",
"networks": ["dvportgroup-95",
"dvportgroup-92"],
"disks": [40, 100]
} |
HTTPie
Code Block |
---|
http POST "https://vss-api.eis.utoronto.ca:8001/v2/vm" "Authorization: Bearer $TK" usage='Prod' os='ubuntu64Guest' built_from='os_install' bill_dept='EIS' description='Java web application.' folder='group-v4122' networks:='["dvportgroup-95", "dvportgroup-92"]' disks:='[40, 20]' |
CURL
Code Block |
curl -H "Content-Type: application/json" -H "Authorization: Bearer $TK" -X POST "https://vss-api.eis.utoronto.ca:8001/v2/vm" -d ' |
custom_spec | Customize a guest operating system to prevent conflicts if virtual machines are identical after deployed. To customize the guest operating system, you must configure the virtual machine and guest to meet VMware Tools and virtual disk requirements. | dict | - | - | - | recommended with clone and template deployment |
|
|
|
|
|
|
|
power_on | Power on virtual machine after successful deployment | boolean | - | False | - | - |
template | Convert virtual machine to template once deployed. | boolean | - | False | - | - |
ha_group | Create high availability group metadata (based on morefs) | array or string | /v2/vm | - | - | - |
vss_options | Sets available VSS Options to virtual machine metadata. | array or string | /v2/vss/options | - | - | - |
vss_service | Tags Virtual Machine with a specific predefined service. | string | /v2/vss/service | - | - | only for ITS users |
retirement | Create a Retirement request for the virtual machine. The retirement request allows to set a retirement date for a virtual machine. There are currently two types: - timedelta: days, months and hours from now until retirement.
- datetime: specific timestamp to retire vm.
Code Block |
---|
| {
"value": {"type": "timedelta", "days": 4, "months": 6, "hours": 0},
"warning": {"days": 15}
} |
Code Block |
---|
| {
"value": {"type": "datetime", "datetime": "2021-10-20 10:00"},
"warning": {"days": 15}
} |
Note |
---|
warning is optional but if not set, no notification will be sent to confirm or cancel retirement. |
| object | - | - | - | - |
A new virtual machine can be created with as few as the following attributes in JSON format:
Code Block |
---|
language | py |
---|
title | Request Body |
---|
|
{"usage": "Prod",
"os": "ubuntu64Guest",
"built_from": "os_install",
"bill_deptclient": "EIS",
"description": "Java web application.",
"folder": "group-v4122",
"networks": [{"network": "dvportgroup-95", "type": "e1000"}, {"network": "dvportgroup-92"}],
"disks": [40, 100]}' |
If the request was successfully submitted and all parameters were accepted, the following Response Status, Headers and body will be received:
Code Block |
---|
language | text |
---|
title | Response Headers |
---|
|
HTTP/1.0 202 ACCEPTED
Allow: HEAD, POST, OPTIONS, GET
Content-Length: 364
Content-Type: application/json
Date: Tue, 26 Apr 2016 18:24:23 GMT
Location: ,
"power_on": true
} |
HTTPie
Code Block |
---|
http POST "https://vss-api.eis.utoronto.ca:8001/v2/request/task/fa276e28-a876-477a-ab40-0d2d84df9234
X-RateLimit-Limit: 7200
X-RateLimit-Remaining: 7190
X-RateLimit-Reset: 1461697200 |
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"data": {
"_links": {
"request": "https://vss-api.eis.utoronto.ca:8001/v2/request/new/8",
"task":vm" "Authorization: Bearer $TK" usage='Prod' os='ubuntu64Guest' built_from='os_install' client='EIS' description='Java web application.' folder='group-v4122' networks:='[{"network": "dvportgroup-95", "type": "e1000"}, {"network": "dvportgroup-92"}]' disks:='[40, 20]' power_on:=true |
CURL
Code Block |
---|
curl -H "Content-Type: application/json" -H "Authorization: Bearer $TK" -X POST "https://vss-api.eis.utoronto.ca:8001/v2/request/task/fa276e28-a876-477a-ab40-0d2d84df9234vm" -d '{"usage": "Prod", "os": "ubuntu64Guest", "built_from": "os_install", },
"message"client": "EIS", "description": "NewJava VM Request has been accepted for processingweb application.",
"name"folder": "Acceptedgroup-v4122",
"status"networks": 202
},
"meta[{"network": {
"time"dvportgroup-95", "type": "0.08575se1000"},
"user{"network": "jm"
}
} |
Note |
---|
Note that you will receive as well additional Hypermedia links contained in the _links attribute. Request object is the new virtual machine creation request which stores all parameters previously submitted and Task, is the unique task in charged of processing your request. Request and Task are both related, in terms of status, errors and warnings. Request will store any status or errors caught by the task, also it will pass the recently created VM Uuid. |
Task
Request processing is almost instantaneous, however you could check the task progress by making a HTTP GET request to any given /v2/request/task/<task_id> endpoint.
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"_links": {
"request": "https://vss-api.eis.utoronto.ca:8001/v2/request",
"self": "dvportgroup-92"}], "disks": [40, 100], "power_on": true}' |
If the request was successfully submitted and all parameters were accepted, the following Response Status, Headers and body will be received:
Code Block |
---|
language | text |
---|
title | Response Headers |
---|
|
HTTP/1.0 202 ACCEPTED
Allow: HEAD, POST, OPTIONS, GET
Content-Length: 364
Content-Type: application/json
Date: Tue, 26 Apr 2016 18:24:23 GMT
Location: https://vss-api.eis.utoronto.ca:8001/v2/request/task/a57a3d4afa276e28-9e94a876-4822477a-a1d3ab40-f99db1005dbd"
},
"data": {
0d2d84df9234
X-RateLimit-Limit: 7200
X-RateLimit-Remaining: 7190
X-RateLimit-Reset: 1461697200 |
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"resultdata": {
"_links": {
"currentrequest": 100"https://vss-api.eis.utoronto.ca/v2/request/new/8",
"task": "https://vss-api.eis.utoronto.ca/v2/request/task/fa276e28-a876-477a-ab40-0d2d84df9234"
"result": { },
"message": "Request has been accepted for processing",
"errorsname": []"Accepted",
"request": {
"warningsid": [8,
"Fault Domain: FD3 "status": "Submitted",
"Created in: VSS > Sandbox > jm",
"Network adapter 1: 00:50:56:92:50:6d: VL-1102-UTCS","task_id": "fa276e28-a876-477a-ab40-0d2d84df9234"
},
"status": 202
"Network adapter 2: 00:50:56:92:3f:91: VL-1072-VSGAN"
]
},
"status": "1604P-desperate_thompson Processed",
"total": 100
}
} |
Note |
---|
Note that you will receive as well additional Hypermedia links contained in the _links attribute. Request object is the new virtual machine creation request which stores all parameters previously submitted and Task, is the unique task in charged of processing your request. Request and Task are both related, in terms of status, errors and warnings. Request will store any status or errors caught by the task, also it will pass the recently created VM Uuid. |
Task
Request processing is almost instantaneous, however you could check the task progress by making a HTTP GET request to any given /v2/request/task/<task_id> endpoint.
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"_links": {
}, "status"request": "SUCCESS"
https://vss-api.eis.utoronto.ca/v2/request",
}, "meta": {self": "https://vss-api.eis.utoronto.ca/v2/request/task/a57a3d4a-9e94-4822-a1d3-f99db1005dbd"
},
"countdata": 2, {
"timeresult": "0.00028s", {
"usercurrent": "jm" 100,
} } |
Request
Checking the overall status of the request and also the resulting Uuid can be done by making a HTTP GET request to /v2/request/new/8 endpoint:
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{ "_linkresult": {
"request": "https://vss-api.eis.utoronto.ca:8001/v2/request/new",
"errors": [],
"self": "https://vss-api.eis.utoronto.ca:8001/v2/request/new/180" }, "datawarnings": {[
"_links": { "Fault "task": "https://vss-api.eis.utoronto.ca:8001/v2/request/task/6f642f4b-6be1-4fba-aabd-eab7f6366912",Domain: FD3 ",
"user_data": "https://vss-api.eis.utoronto.ca:8001/v2/request/new/180/user_dataCreated in: VSS > Sandbox > jm",
"vm": "https://vss-api.eis.utoronto.ca:8001/v2/vm/501219a5-a563-787c-f334-e7b65e829dca" "Network adapter 1: }00:50:56:92:50:6d: VL-1102-UTCS",
"annotation": [ "Network adapter "VM Name: 1608T-sw-node2",2: 00:50:56:92:3f:91: VL-1072-VSGAN"
"UTvssAdmin: Jose Manuel Lopez Lujan:416-577-7061:jm.lopez@utoronto.ca", ]
"UTvssClient: EIS"},
"UTvssPurpose: Testing",
"UTvssRequested: 2016-08-26 15:03:50 "status": "1604P-desperate_thompson Processed",
"UTvssInformtotal": jm.lopez@utoronto.ca",100
},
"Description: deploying the new docker swarm cluster"status",: "SUCCESS"
},
"meta": {
"count": ]2,
"built_fromtime": "image0.00028s",
"cpuuser": "1jm",
"created_on": "2016-08-26 15:03:50 EDT",
}
} |
Request
Checking the overall status of the request and also the resulting Uuid can be done by making a HTTP GET request to /v2/request/new/8 endpoint:
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"_link": {
"disksrequest": ["https://vss-api.eis.utoronto.ca/v2/request/new",
"self": "https://vss-api.eis.utoronto.ca/v2/request/new/180"
10, },
"data": {
40, "_links": {
40, "task": "https://vss-api.eis.utoronto.ca/v2/request/task/6f642f4b-6be1-4fba-aabd-eab7f6366912",
40 "user_data": ],"https://vss-api.eis.utoronto.ca/v2/request/new/180/user_data",
"domainvm": "domain-c5877",https://vss-api.eis.utoronto.ca/v2/vm/501219a5-a563-787c-f334-e7b65e829dca"
"dvd_cd": ""},
"folderannotation": "group-v7505",[
"guest_os": "ubuntu64Guest",VM Name: 1608T-sw-node2",
"high_io": false, "UTvssAdmin: Jose Manuel Lopez Lujan:416-577-7061:jm.lopez@utoronto.ca",
"id": 180, "memory"UTvssClient: EIS"1",
"message" "UTvssPurpose: {Testing",
"errors": []UTvssRequested: 2016-08-26 15:03:50 ",
"warnings": nullUTvssInform: jm.lopez@utoronto.ca",
}, "Description: deploying the new docker swarm cluster"networks": [,
"dvportgroup-77"
],
"sourcebuilt_imagefrom": "images/wily-server-cloudimg-amd64.ovaimage",
"statuscpu": "Processed1",
"task_id": "6f642f4b-6be1-4fba-aabd-eab7f6366912",
"updatedcreated_on": "2016-08-26 15:0403:4250 EDT",
"userdisks": [
{ 10,
"_links": { 40,
"self": "https://vss-api.eis.utoronto.ca:8001/v2/user" 40,
}, 40
"username": "josem"],
}"domain": "domain-c5877",
"vmdvd_namecd": "1608T-sw-node2",
"folder"vm_uuid": "501219a5-a563-787c-f334-e7b65e829dcagroup-v7505",
"workdirguest_os": "/data/imports/5279a6a4-87bc-4d5d-89a6-8458912d1b53"ubuntu64Guest",
}, "metaid": {180,
"countmemory": 23"1",
"timemessage": "0.00968s"{
"errors": [],
"userwarnings": null
"josem" },
"networks": [
}
} |
Multiple Virtual Machines
To create multiple Virtual Machines, send a POST request to /v2/vm. Creating multiple VMs is quite similar to creating a single VM, but instead of sending name as a string, send names as an array and select the right built process, either clone or template. The following request body is used to deploy three VM from a VM template:
Code Block |
---|
language | py |
---|
title | Request Body |
---|
|
{"bill_dept": "EIS",
"built_from": "template",
"description": "Ubuntu cluster",
"os": "ubuntu64Guest",
"folder": "group-v4122",
"source_template": "50123c4c-c810-5c0f-6203-eac67f0cb7e8",
"names": ["Ubuntu1 {"network": "dvportgroup-95", "type": "e1000"},
{"network": "dvportgroup-92", "type": "vmxnet3"}
],
"source_image": "images/wily-server-cloudimg-amd64.ova",
"Ubuntu2"status": "Processed",
"task_id": "6f642f4b-6be1-4fba-aabd-eab7f6366912",
"Ubuntu3"], "networksupdated_on": ["dvportgroup-952016-08-26 15:04:42 EDT",
"user": {
"dvportgroup-92"], "disks_links": [40, 100]} |
Warning |
---|
The main difference between selecting clone or template as built process is that a source VM Template can deploy multiple instances concurrently, whereas a VM Clone can only be deployed concurrently when the source Virtual Machine is powered off. If VM is powered On, it can only be cloned one at a time. |
HTTPie
Code Block |
---|
http POST {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vmuser"
"Authorization: Bearer $TK" os='ubuntu64Guest' built_from='template' bill_dept='EIS' description='Ubuntu cluster' folder='group-v4122' networks:='["dvportgroup-95", "dvportgroup-92"]' disks:='[40, 100]' names:='["Ubuntu1", "Ubuntu2", "Ubuntu3"]' source_template=50123c4c-c810-5c0f-6203-eac67f0cb7e8 |
CURL
Code Block |
---|
|
curl -H "Content-Type: application/json" -H "Authorization: Bearer $TK" -X POST "https://vss-api.eis.utoronto.ca:8001/v2/vm" -d '{"bill_dept": "EIS", "built_from": "template", "description": "Ubuntu cluster", "os": "ubuntu64Guest", "folder": "group-v4122", "source_template": "50123c4c-c810-5c0f-6203-eac67f0cb7e8", "names": ["Ubuntu1", "Ubuntu2", "Ubuntu3"], "networks": ["dvportgroup-95", "dvportgroup-92"], "disks": [40, 100]}' |
If the request was successfully submitted and all parameters were accepted, the following Response Status, Headers and body will be received:
Code Block |
---|
language | text |
---|
title | Response Headers |
---|
|
HTTP/1.0 202 ACCEPTED
Allow: HEAD, POST, OPTIONS, GET
Content-Length: 682
Content-Type: application/json
Date: Wed, 27 Apr 2016 14:16:42 GMT
X-RateLimit-Limit: 7200
X-RateLimit-Remaining: 7191
X-RateLimit-Reset: 1461769200 |
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"data": {
"_links": { },
"username": "josem"
},
"vm_name": "1608T-sw-node2",
"vm_uuid": "501219a5-a563-787c-f334-e7b65e829dca",
"workdir": "/data/imports/5279a6a4-87bc-4d5d-89a6-8458912d1b53"
},
"meta": {
"count": 23,
"time": "0.00968s",
"user": "josem"
}
} |
Multiple Virtual Machines
To create multiple Virtual Machines, send a POST request to /v2/vm. Creating multiple VMs is quite similar to creating a single VM, but instead of sending name as a string, send names as an array and select the right built process, either clone or template. The following request body is used to deploy three VM from a VM template:
Code Block |
---|
language | py |
---|
title | Request Body |
---|
|
{"": "EIS",
"built_from": "template",
"description": "Ubuntu cluster",
"os": "ubuntu64Guest",
"folder": "group-v4122",
"source_template": "50123c4c-c810-5c0f-6203-eac67f0cb7e8",
"names": ["Ubuntu1",
"Ubuntu2",
"Ubuntu3"],
"networks": [
{"network": "dvportgroup-95", "requeststype": "e1000"},
[ {"https://vss-api.eis.utoronto.ca:8001/v2/request/new/26",
network": "dvportgroup-92", "type": "vmxnet3"}
],
"disks": "https://vss-api.eis.utoronto.ca:8001/v2/request/new/27",
[40, 100]} |
Warning |
---|
The main difference between selecting clone or template as built process is that a source VM Template can deploy multiple instances concurrently, whereas a VM Clone can only be deployed concurrently when the source Virtual Machine is powered off. If VM is powered On, it can only be cloned one at a time. |
HTTPie
Code Block |
---|
http POST "https://vss-api.eis.utoronto.ca:8001/v2/request/new/28vm" "Authorization: Bearer $TK" os='ubuntu64Guest' built_from='template' client='EIS' description='Ubuntu ],
"tasks": [
cluster' folder='group-v4122' networks:='[{"network": "dvportgroup-95", "type": "e1000"}, {"network": "dvportgroup-92"}]' disks:='[40, 100]' names:='["Ubuntu1", "Ubuntu2", "Ubuntu3"]' source_template=50123c4c-c810-5c0f-6203-eac67f0cb7e8 |
CURL
Code Block |
---|
curl -H "Content-Type: application/json" -H "Authorization: Bearer $TK" -X POST "https://vss-api.eis.utoronto.ca:8001/v2/request/task/aa1cc5fa-94fc-473f-b29c-47f022745eb2",
"https://vss-api.eis.utoronto.ca:8001/v2/request/task/97d1f968-dec5-4249-b23c-226b46258483",
"https://vss-api.eis.utoronto.ca:8001/v2/request/task/0ec62b83-6c7f-47ae-8670-588449c3a2cb"
]
},
"message": "New VM Requests have been accepted for processing",
"name": "Accepted",
"status": 202
},
"meta": {
"time": "0.10215s",
"user": "jm"
}
} |
Note |
---|
The main difference between single and multiple vm creation/deployment is the number of requests and tasks returned by the API. In this case, since we required three VMs, we get the same number of requests and tasks as a result of the POST request, which can be queried individually to verify its progress or result. |
Task
Request processing is almost instantaneous, however you could check the task progress by making a HTTP GET request to any given /v2/request/task/<task_id> endpoint.
Code Block |
---|
vm" -d '{"client": "EIS", "built_from": "template", "description": "Ubuntu cluster", "os": "ubuntu64Guest", "folder": "group-v4122", "source_template": "50123c4c-c810-5c0f-6203-eac67f0cb7e8", "names": ["Ubuntu1", "Ubuntu2", "Ubuntu3"], "networks": [{"network": "dvportgroup-95", "type": "e1000"}, {"network": "dvportgroup-92"}], "disks": [40, 100]}' |
If the request was successfully submitted and all parameters were accepted, the following Response Status, Headers and body will be received:
Code Block |
---|
language | text |
---|
title | Response Headers |
---|
|
HTTP/1.0 202 ACCEPTED
Allow: HEAD, POST, OPTIONS, GET
Content-Length: 682
Content-Type: application/json
Date: Wed, 27 Apr 2016 14:16:42 GMT
X-RateLimit-Limit: 7200
X-RateLimit-Remaining: 7191
X-RateLimit-Reset: 1461769200 |
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{{
"data": {
"_links": {
"requestrequests": "https: [
"https://vss-api.eis.utoronto.ca:8001/v2/request/new/26",
"self": "https://vss-api.eis.utoronto.ca:8001/v2/request/task/aa1cc5fa-94fc-473f-b29c-47f022745eb2"new/27",
},
"data": { "result": {https://vss-api.eis.utoronto.ca/v2/request/new/28"
"current": 100],
"resulttasks": {[
"errors": []https://vss-api.eis.utoronto.ca/v2/request/task/aa1cc5fa-94fc-473f-b29c-47f022745eb2",
"warnings": [https://vss-api.eis.utoronto.ca/v2/request/task/97d1f968-dec5-4249-b23c-226b46258483",
"https://vss-api.eis.utoronto.ca/v2/request/task/0ec62b83-6c7f-47ae-8670-588449c3a2cb"
"Hard disk 1 capacity is the same. No change need]
to be done.", },
"message": "New VM Requests have been "Faultaccepted Domain:for FD3 processing",
"name": "Accepted",
"status"Created: in:202
VSS > Sandbox > jm"},
"meta": {
"Network adapter 1: 00:50:56:92:08:08: VL-1102-UTCS",
"Network adapter 2: 00:50:56:92:14:fe: VL-1072-VSGAN"
]
},
"time": "0.10215s",
"statususer": "1604T-Ubuntu1 Processedjm",
}
} |
Note |
---|
The main difference between single and multiple vm creation/deployment is the number of requests and tasks returned by the API. In this case, since we required three VMs, we get the same number of requests and tasks as a result of the POST request, which can be queried individually to verify its progress or result. |
Task
Request processing is almost instantaneous, however you could check the task progress by making a HTTP GET request to any given /v2/request/task/<task_id> endpoint.
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"total_links": 100{
}, "request": "https://vss-api.eis.utoronto.ca/v2/request/",
"statusself": "SUCCESShttps://vss-api.eis.utoronto.ca/v2/request/task/aa1cc5fa-94fc-473f-b29c-47f022745eb2"
},
"meta"data": {
"result": {
"countcurrent": 2100,
"timeresult": {
"0.00597s", "errors": [],
"userwarnings": [
"jm" } } |
Requests
Checking the overall status of the requests and also the resulting Uuid can be done by making a HTTP GET request to /v2/request/new/26 - 28 endpoint:
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"_link": { "request": "https://vss-api.eis.utoronto.ca:8001/v2/request/new",
"self": "https://vss-api.eis.utoronto.ca:8001/v2/request/new/26"Hard disk 1 capacity is the same. No change need to be done.",
}, "data": { "_links": {Fault Domain: FD3 ",
"task": "https://vss-api.eis.utoronto.ca:8001/v2/request/task/aa1cc5fa-94fc-473f-b29c-47f022745eb2", "Created in: VSS > Sandbox > "vm": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012826a-6a1a-815a-249d-7d6eb640f020"jm",
}, "annotation": [Network adapter 1: 00:50:56:92:08:08: VL-1102-UTCS",
"VM Name: 1604T-Ubuntu1", "Network adapter "UTvssAdmin: JM Lopez Lujan:416-123-1234:jm.lopez@utoronto.ca",2: 00:50:56:92:14:fe: VL-1072-VSGAN"
"UTvssClient: EIS", ]
"UTvssPurpose: Test"},
"status"UTvssRequested: 2016-04-27 10:16:42 "1604T-Ubuntu1 Processed",
"total"UTvssInform: jm.lopez@utoronto.ca",100
},
"Description: Ubuntu cluster", "status": "SUCCESS"
},
"meta": {
"count": ]2,
"built_fromtime": "template0.00597s",
"cpuuser": "1jm",
}
} |
Requests
Checking the overall status of the requests and also the resulting Uuid can be done by making a HTTP GET request to /v2/request/new/26 - 28 endpoint:
Code Block |
---|
language | py |
---|
title | Response Body |
---|
collapse | true |
---|
|
{
"created_onlink": "2016-04-27 10:16:42 EDT",
{
"disks": [
40request": "https://vss-api.eis.utoronto.ca/v2/request/new",
100"self": "https://vss-api.eis.utoronto.ca/v2/request/new/26"
},
], "data": {
"domain_links": "domain-c5877", {
"dvd_cdtask": "https://vss-api.eis.utoronto.ca/v2/request/task/aa1cc5fa-94fc-473f-b29c-47f022745eb2",
"foldervm": "group-v4122",https://vss-api.eis.utoronto.ca/v2/vm/5012826a-6a1a-815a-249d-7d6eb640f020"
"guest_os": "ubuntu64Guest"},
"high_ioannotation": [
false, "id" "VM Name: 261604T-Ubuntu1",
"memory": "1", "UTvssAdmin: JM "message": {Lopez Lujan:416-123-1234:jm.lopez@utoronto.ca",
"errors"UTvssClient: []EIS",
"warnings"UTvssPurpose: [Test",
"UTvssRequested: 2016-04-27 10:16:42 "Hard,
disk 1 capacity is the same. No change need to be done."UTvssInform: jm.lopez@utoronto.ca",
"Fault Domain"Description: FD3Ubuntu cluster",
""
"Created in: VSS > Sandbox > jm"],
"built_from": "template",
"Network adapter 1: 00:50:56:92:08:08: VL-1102-UTCS "cpu": "1",
"Network adapter 2: 00:50:56:92:14:fe: VL-1072-VSGAN"
]
}"created_on": "2016-04-27 10:16:42 EDT",
"networksdisks": [
"dvportgroup-95"40,
"dvportgroup-92"100
],
"source_templatedomain": "50123c4c-c810-5c0f-6203-eac67f0cb7e8domain-c5877",
"sourcedvd_vmcd": null"",
"statusfolder": "Processedgroup-v4122",
"taskguest_idos": "aa1cc5fa-94fc-473f-b29c-47f022745eb2ubuntu64Guest",
"updated_onid": 26,
"2016-04-27 10:26:00 EDT "memory": "1",
"usermessage": {
"_linkserrors": {
[],
"selfwarnings": "https://vss-api.eis.utoronto.ca:8001/v2/user"[
}, "Hard disk 1 capacity is the same. No change need to be "id": 1,done.",
"username":Fault Domain: FD3 "jm"
,
}, "vm_name": "1604T-Ubuntu1",Created in: VSS > Sandbox > jm",
"vm_uuid": "5012826a-6a1a-815a-249d-7d6eb640f020"Network adapter 1: 00:50:56:92:08:08: VL-1102-UTCS",
}, "meta": {Network adapter 2: 00:50:56:92:14:fe: VL-1072-VSGAN"
"count": 23, ]
"time": "0.00541s" },
"usernetworks": "jm" [
} } |
List
Virtual machines
In order to list all your Virtual Machines you should make a HTTP GET request to the endpoint /v2/vm:
The following examples use HTTPie and CURL to request ALL Virtual Machine managed by given user without filters:
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm" "Authorization: Bearer $TK"
curl -H "Authorization: Bearer $TK" -X GET "https://vss-api.eis.utoronto.ca:8001/v2/vm" |
HTTP response data would look something like:
Code Block |
---|
language | py |
---|
title | Response |
---|
collapse | true |
---|
|
{
"_links": {dvportgroup-95",
"dvportgroup-92"
],
"apisource_template": "https://vss-api.eis.utoronto.ca:8001/v2/",50123c4c-c810-5c0f-6203-eac67f0cb7e8",
"selfsource_vm": "https://vss-api.eis.utoronto.ca:8001/v2/vm"null,
}, "datastatus": ["Processed",
{ "task_id": "aa1cc5fa-94fc-473f-b29c-47f022745eb2",
"updated_linkson": {
"2016-04-27 10:26:00 EDT",
"user": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012bbfb-137e-c4f5-7a85-c837351f786buser"
},
"nameid": "1608T-ubuntu-15.10_x64"1,
"uuidusername": "5012bbfb-137e-c4f5-7a85-c837351f786bjm"
},
{ "vm_name": "1604T-Ubuntu1",
"vm_linksuuid": {
"5012826a-6a1a-815a-249d-7d6eb640f020"
},
"meta": {
"selfcount": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012aa6d-6e6b-e5c7-87a5-713853308880"
},
23,
"nametime": "1608T-ubuntu-15.04_x640.00541s",
"uuiduser": "5012aa6d-6e6b-e5c7-87a5-713853308880jm"
}
{
"_links": {
"self": }
} |
List
Virtual machines
In order to list all your Virtual Machines you should make a HTTP GET request to the endpoint /v2/vm:
The following examples use HTTPie and CURL to request ALL Virtual Machine managed by given user without filters:
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca/v2/vm" "Authorization: Bearer $TK"
curl -H "Authorization: Bearer $TK" -X GET "https://vss-api.eis.utoronto.ca:8001/v2/vm/501264bc-5d2d-3330-e0d9-562309e33331"" |
HTTP response data would look something like:
Code Block |
---|
language | py |
---|
title | Response |
---|
collapse | true |
---|
|
{
"_links": {
}, "self": "https://vss-api.eis.utoronto.ca/v2/vm?short=1&per_page=5"
},
"namedata": "CentOS-7-x86_64-VMware",[
{
"uuid": "501264bc-5d2d-3330-e0d9-562309e33331" }"hostName": "HOTH",
{ "ipAddress": "",
"_links": { "moref": "vm-4210",
"selfname": "https://vss-api.eis.utoronto.ca:8001/v2/vm/50123967-ab62-e8af-1c1a-9e43683ac208"1409P-hoth",
},
"powerState": "poweredOff",
"nameuuid": "1608T-tender_mccarthy",50127974-aa4a-c215-f9f0-e1ab8a4ef050"
},
{
"uuid "hostName": "50123967-ab62-e8af-1c1a-9e43683ac208"glog-app01.eis.utoronto.ca",
} ],
"ipAddress": "192.168.2.222",
"meta": { "countmoref": 4,"vm-12178",
"timename": "0.00713s1803D-graylog-app-0",
"userpowerState": "jm"poweredOn",
}
} |
If you wish to display a quick summary in your main VM list, just include summary=1 in the query string as follows:
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?summary=1" "Authorization: Bearer $TK"
curl -H "Authorization: Bearer $TK" -X GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?summary=1" |
Code Block |
---|
language | py |
---|
title | Response |
---|
collapse | true |
---|
|
{
"_links": { "uuid": "5012f72a-f9c7-366f-5cf0-e1ac6afe4466"
},
{
"api "hostName": "https://vss-apiglog-app02.eis.utoronto.ca:8001/v2/",
"selfipAddress": "https://vss-api.eis.utoronto.ca:8001/v2/vm"192.168.2.122",
}, "datamoref": ["vm-12075",
{ "name": "1803D-graylog-es1",
"_links": { "powerState": "poweredOn",
"selfuuid": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510"
50129e9f-38c5-ba9a-14d1-a1023fbc3aeb"
},
{
"cpuCount": 2, "folder": {"hostName": "gpu-dh-108",
"ipAddress": "192.168.1.155",
"_links": { "moref": "vm-15854",
"selfname": "https://vss-api.eis.utoronto.ca:8001/v2/folder/group-v6736"1811D-ubuntu",
},
"powerState": "poweredOn",
"morefuuid": "group-v6736",501257e0-81f5-9c2a-84e5-e900212fef76"
},
"name": "APIDemo", {
"parenthostName": "jmubuntu",
}"ipAddress": "",
"guestFullNamemoref": "Other 3.x or later Linux (64-bit)vm-13053",
"ipAddressname": null"1807P-Ubuntu-18.04-server-tmpl",
"memoryGBpowerState": 2.0"poweredOff",
"nameuuid": "1608T-stoic_carson",50120242-3ea3-d7ba-b6a5-14ffa8565b65"
}
"overallStatus": "green" ],
"meta": {
"powerStatecount": "poweredOff"5,
"provisionedGBpages": 12.25,{
"uuidfirst_url": "5012689b-071a-145b-584a-9a9b49873510"
}
...
],
"meta": {https://vss-api.eis.utoronto.ca/v2/vm?per_page=5&page=1&expand=True",
"countlast_url": 1,"https://vss-api.eis.utoronto.ca/v2/vm?per_page=5&page=5&expand=True",
"time "next_url": "0.78135s",https://vss-api.eis.utoronto.ca/v2/vm?per_page=5&page=2&expand=True",
"userpage": 1,
"jmpages": 5,
}
} "per_page": 5,
"prev_url": null,
"total": 25
},
"time": "0.03134s",
"user": "jm"
}
} |
Included attributes are described in the following table:
Name | Type | Description |
---|
uuid | string | 128-bit UUID of a virtual machine, represented as a hexademical string. This identifier is used by VirtualCenter to uniquely identify all virtual machine instances, including those that may share the same SMBIOS UUID. |
moref | string | Managed object reference of the vm |
name | string | Virtual Machine name including VSS prefix. |
guestFullNameguest_full_name | string | This is the The full name of the guest operating system for the virtual machine. For example: Windows 2000 Professional. |
ipAddressguest_id | string | The guest operating system identifier. |
ip_address | string | Primary IP address assigned to the guest operating system, if known. |
hostname | string | Guest hostname. Provided only when VMware Tools is running. |
memoryGB | integer | Memory size of the virtual machine, in Gigabytes. |
cpuCountcpu_count | integer | Number of processors in the virtual machine. |
overallStatusoverall_status | string | VM general "health" value: - gray: The status is unknown.
- green: The entity is OK.
- red: The entity definitely has a problem.
- yellow: The entity might have a problem.
|
powerStatepower_state | string | The current power state of the virtual machine. provisionedGBThe state could be: poweredOff or poweredOn |
provisioned_gb | integer | Sum of Committed and Uncommitted storage. |
folder | object | Folder object which contains current VM |
Filters
The main Virtual Machine resource has three main filters to reduce the number of VMs shown in the result or to locate a VM by hostname or ip address.
Name | Description |
---|
name | Virtual Machine name string to filter VMs |
ip | Primary IP address assigned to the Guest operating system. |
dns | Hostname of the guest operating system. |
path | Inventory path in the following format EIS-DCB/vm/Public/jm/APIDemo/1605T-VMTest_1 |
summary | Enables VM summary in results. |
The following examples show how to implement a GET request with the first three parameters shown below. The result is similar to the previous section.
Code Block |
---|
|
http GET "https: |
folder_moref | string | Folder managed object reference |
tools_running_status | string | VMware Tools running status. |
tools_version | string | VMware Tools version. |
tools_version_status | string | VMware Tools version status. |
version | string | Virtual hardware version. |
Paging
All requests to the /vm URL are paginated. The response body includes a 'meta.pages' key with everything to navigate through the results, for instance:
Key | Description |
---|
first_url | Contain the URLs to navigate through results. |
last_url |
prev_url |
next_url |
page | Current page |
pages | Total number of pages |
per_page | Results per page. Maximum 250; Default 10. |
total | Total number of results |
Results per page can be set by including the parameter in the URL query, so we can get the desired number of elements per page, for example:
Code Block |
---|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?name=Test"per_page=200" "Authorization: Bearer $TK"
curl -H "Authorization: Bearer $TK" http-X GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?ip=10.2.1.2" "Authorization: Bearer $TK"
per_page=1500" |
Sorting
The resource provides also attribute sorting by adding the sort parameter in the URL query string in the following format:
Code Block |
---|
sort=<field_name>,<asc|desc> |
For example:
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?dns=wiki.eis.utoronto.casort=name,desc" "Authorization: Bearer $TK"
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?path=EIS-DCB/vm/Public/jm/APIDemo/1605T-VMTest_1sort=uuid,asc" "Authorization: Bearer $TK" |
Filtering
by name can be done as follows: Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?name=Test" "Authorization: Bearer $TK" |
HTTP response data would look something like:
Code Block |
---|
language | bash |
---|
title | HTTP Response |
---|
collapse | true |
---|
|
{
"_links": {
"api": "Virtual Machines can be filtered by adding the filter argument to the query string in the following format:
Code Block |
---|
filter=<field_name>,<operator>,<value> |
Operators can be:
Operator | Description |
---|
eq | Equals |
ne | Not equal |
lt | Lower than |
le | Lower equal |
gt | Greater than |
ge | Greater equal |
like | Matching pattern |
in | Match value in many items separated by commas |
Filter Virtual Machine resource by any of the following
Attribute | Filter |
---|
name | name |
ipAddress | ip_address |
hostname | hostname |
powerState | power_state |
cpuCount | cpu_count |
overallStatus | overall_status |
toolsVersion | tools_version |
toolsVersionStatus | tools_version_status |
version | version |
The following examples show how to implement a GET request with the first three parameters shown below. The result is similar to the previous section.
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/",
"self": vm?filter=name,like,%Test%" "Authorization: Bearer $TK"
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm?filter=ip_address,eq,10.2.1.2" "Authorization: Bearer $TK"
http },
"data": [
{
"_links": {
"self":GET "https://vss-api.eis.utoronto.ca/v2/vm?filter=hostname,like,wiki.eis.utoronto.ca" "Authorization: Bearer $TK" |
Filtering by name can be done as follows:
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db"
?filter=name,like,%Test%" "Authorization: Bearer $TK" |
HTTP response data would look something like:
Code Block |
---|
language | bash |
---|
title | HTTP Response |
---|
collapse | true |
---|
|
{
"_links": {
}, "api": "https://vss-api.eis.utoronto.ca/v2/",
"nameself": "1604Q-VMTest_1",https://vss-api.eis.utoronto.ca/v2/vm"
},
"uuiddata": "5012bd15-c20c-a971-aa68-af1a3cf3d0db" [
{
} ], "meta_links": {
"count": 1, "timeself": "1.86220s",https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db"
},
"username": "jm"1604Q-VMTest_1",
}
} |
Note |
---|
From now on, you will need the UUID of any virtual machine, provided by the either the uuid attribute or in the "_links" section, to get further information "uuid": "5012bd15-c20c-a971-aa68-af1a3cf3d0db"
}
],
"meta": {
"count": 1,
"time": "1.86220s",
"user": "jm"
}
} |
Note |
---|
From now on, you will need the UUID of any virtual machine, provided by the either the uuid attribute or in the "_links" section, to get further information and eventually to modify its configuration. |
Specific virtual machine info
Some of the attributes will have an object value. Such is the case of guest, hardware, network, config and vss.
Name | Type | Description |
---|
uuid | string | VirtualCenter-specific 128-bit UUID of a virtual machine, represented as a hexademical string. This identifier is used by VirtualCenter to uniquely identify all virtual machine instances, including those that may share the same SMBIOS UUID. |
name | string | Virtual Machine name including VSS prefix. |
Config | VM Configuration |
bootdelayboot.delay_ms | integer | Delay in milliseconds before starting the boot sequence. The boot delay specifies a time interval between virtual machine power on or restart and the beginning of the boot sequence. |
os.guest_id | string | Operating system configured in the virtual machine |
Folder | Logical Folder |
name | string | Immediate folder holding VM |
parent | string | Parent folder holding the VM |
path | string | Full path to immediate folder |
moref | string | Managed object reference to parent folder |
Guest | Guest status and configuration |
guestFullNameguest_full_name | string | This is the full name of the guest operating system for the virtual machine. For example: Windows 2000 Professional. |
guestIdguest_id | string | Guest operating system configured on a virtual machine. |
hostNamehostname | string | Hostname of the guest operating system, if known. |
ipAddressip_address | string | List of IP address assigned to the guest operating system, if known. |
toolsStatustools_status | string | Current running status of VMware Tools in the guest operating system, if known. |
Note | Virtual Machine Metadata |
note | string | Virtual Machine full annotation |
client | string | List of client notes in key-value formatClient notes |
Name | |
|
full_name | string | VM full name including VSS prefix. |
Hardware | Virtual Machine Hardware configuration |
cpuCountcpu_count | integer | Number of processors in the virtual machine. |
coresPerSocketcores_per_socket | integer | Number of cores used to distribute virtual CPUs among sockets in this virtual machine. If the value is unset it implies to numCoresPerSocket = 1. |
memoryMBmemory_mb | integer | Memory size of the virtual machine, in megabytes. |
devices | string | List of strings holding controllers, cd/dvd, disks and nics configured in the VM |
version | string | The version string for this virtual machine. |
Storage | Storage summary |
provisionedGB | integer | Sum of Committed and Uncommitted storage. |
uncommittedGB | integer | Additional storage space, in bytes, potentially used by this virtual machine on all datastores. |
committedGB | integer | Total storage space, in bytes, committed to this virtual machine across all datastores. |
unsharedGB | integer | Total storage space, in bytes, occupied by the virtual machine across all datastores, that is not shared with any other virtual machine. |
State | Runtime status related attributes |
overallStatus | string | VM general "health" value: - gray: The status is unknown.
- green: The entity is OK.
- red: The entity definitely has a problem.
- yellow: The entity might have a problem.
|
powerState | string | The current power state of the virtual machine. |
alarms | boolean | Whether the VM has triggered alarms. |
Snapshot | Virtual Machine Snapshot information |
exist | boolean | Whether the current virtual machine has Snapshots |
VSS | VSS Metadata |
Admin | string | Admin responsible of this VM. |
Client | string | Custom client key-value notes. |
The following example, requests information about a particular VM using its base resource /v2/vm and appending the UUID to get the URI /vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/.
Code Block |
---|
|
http GETvirtual machine. |
Storage | Storage summary |
provisioned_gb | integer | Sum of Committed and Uncommitted storage. |
uncommitted_gb | integer | Additional storage space, in bytes, potentially used by this virtual machine on all datastores. |
committed_gb | integer | Total storage space, in bytes, committed to this virtual machine across all datastores. |
unshared_gb | integer | Total storage space, in bytes, occupied by the virtual machine across all datastores, that is not shared with any other virtual machine. |
State | Runtime status related attributes |
overall_status | string | VM general "health" value: - gray: The status is unknown.
- green: The entity is OK.
- red: The entity definitely has a problem.
- yellow: The entity might have a problem.
|
power_state | string | The current power state of the virtual machine. |
alarms | boolean | Whether the VM has triggered alarms. |
Snapshot | Virtual Machine Snapshot information |
exist | boolean | Whether the current virtual machine has Snapshots |
VSS | VSS Metadata |
admin | string | Admin responsible of this VM. |
client | string | Custom client key-value notes. |
The following example, requests information about a particular VM using its base resource /v2/vm and appending the UUID to get the URI /vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/.
Code Block |
---|
|
http GET "https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db" "Authorization: Bearer $TK" |
HTTP response data would look something like:
Code Block |
---|
language | py |
---|
title | Response |
---|
collapse | true |
---|
|
{
"config": {
"boot": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/boot"
},
"delay_ms": 5000
},
"os": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/os"
},
"guest_id": "centos7_64Guest"
},
"template": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/template"
},
"is_template": false
}
},
"folder": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca/v2/folder-vc/group-v759"
},
"moref": "group-v759",
"name": "Dev",
"parent": "Public",
"path": "Public > Dev"
},
"guest": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/guest"
},
"guest_full_name": "CentOS 6 (64-bit)",
"guest_id": "centos6_64Guest",
"hostname": "pi-lab.dcb.eis.utoronto.ca",
"ip_address": [
"fe80::1b5b:c11b:dbff:37b8",
"128.100.111.0",
"fe80::250:56ff:feb0:3be0"
],
"tools_running_status": "guestToolsRunning",
"tools_status": "guestToolsUnmanaged",
"tools_version": "10309"
},
"hardware": {
"cpu": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/cpu"
},
"cpu_count": 1
},
"devices": {
"cds": [
{
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/cd/1"
"Authorization: Bearer $TK" |
HTTP response data would look something like:
Code Block |
---|
language | py |
---|
title | Response |
---|
collapse | true |
---|
|
{
"data": { },
"backing": "client",
"unit": 1
"vss": { }
"admin": "JM Lopez Lujan:416-577-7061:jm@eis.utoronto.ca" ],
"clientdisks": "EIS", [
{
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/disk/vss1"
},
"capacity_gb": 8.0,
} }, "hardwareunit": {1
"version": "vmx-10", },
"cpu": { {
"cpuCount": 2, "_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/disk/cpu2"
} },
}, "devicescapacity_gb": {1.0,
"nics": [ "unit": 2
{ },
"macAddress": "00:50:56:92:28:7a", {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510/nic/1"af1a3cf3d0db/disk/3"
},
}, "capacity_gb": 1.0,
"networkunit": { 3
}
],
"moreffloppies": "dvportgroup-95",[
{
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/network/dvportgroup-95vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/floppy/1"
},
} }, "backing": "client",
"unit": "1"
}
],
"disksnics": [
{
"capacityGB": 10.0,
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/disknic/1"
},
"unitconnected": "1"
true,
} ],
"floppies": ["mac_address": "00:50:56:b0:3b:e0",
{ "backing"network": {
"client", "_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vmnetwork-vc/5012689b-071a-145b-584a-9a9b49873510/floppy/1"dvportgroup-1094"
},
"labelmoref": "Floppydvportgroup-1094"
drive 1" },
],"type": "vmxnet3",
"cdsunit": [1
{
},
"backing": "client", {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/cdnic/12"
},
"unitconnected": "1"true,
} "mac_address": "00:50:56:b0:3f:4c",
] }, "network": {
"memory": { "_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vmnetwork-vc/5012689b-071a-145b-584a-9a9b49873510/memorydvportgroup-1083"
},
"moref": "dvportgroup-1083"
},
"memoryGB "type": "vmxnet3",
"unit": 2.0
} }
}, "guest": { ]
"toolsStatus": "guestToolsUnmanaged", },
"hostNamememory": {
null, "_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/guestmemory"
},
"guestIdmemory_gb": null,1.0
"ipAddress": []},
"guestFullNameversion": null
},
"vmx-13"
"uuid": "5012689b-071a-145b-584a-9a9b49873510" },
"storagename": {
"uncommittedGB_links": {
11.64, "provisionedGBself": 12.25,"https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/name"
"committedGB": 0.6, },
"unsharedGBfull_name": 0.6"1904T-Pi-Lab"
},
"note": {
"nameclient": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/note/nameclient"
},
"full_namevalue": "1608T-stoic_carson"
}, "note": {},
"note": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/note"
}
},
},
"clientpermission": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/note/clientpermission"
},
},
"tagssnapshot": []{
}
"_links": {
}, "stateself": {"https://vss-api.eis.utoronto.ca/v2/vm/5012bd15-c20c-a971-aa68-af1a3cf3d0db/snapshot"
"alarms": false, },
"powerStateexist": "poweredOff"true,
"overallStatusrequireDiskConsolidation": "green", false
},
"_linksstate": {
"alarm": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510/alarm", _links": {
"selfalarm": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/statealarm",
"event": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/event",
"domainself": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/domainstate"
},
}, "alarms": false,
"snapshotdomain": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/snapshotdomain"
},
"exist": false
}, "foldermoref": {"domain-c63",
"pathname": "Cluster1"VSS
> Sandbox > jm > APIDemo"},
"morefoverall_status": "group-v6736green",
"power_linksstate": {"poweredOn"
},
"selfstorage": "https://vss-api.eis.utoronto.ca:8001/v2/folder/group-v6736"{
},
"name"committed_gb": "APIDemo", 5.65,
"parentprovisioned_gb": "jm"
},15.65,
"configuncommitted_gb": {10.0,
"os": {unshared_gb": 5.53
},
"guestIduuid": "other3xLinux64Guest5012bd15-c20c-a971-aa68-af1a3cf3d0db",
"vss": {
"_links": {
"self": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b5012bd15-071ac20c-145ba971-584aaa68-9a9b49873510af1a3cf3d0db/osvss"
}
},
"bootadmin": {"JM Lopez "delayMs": 0L:416-577-7062:jm.lopez utoronto.ca",
"_linksclient": {
"EIS2",
"selfdescription": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510/boot"This is a test VM",
"inform": [
} }
"jm.lopez utoronto.ca"
} }],
"metaoptions": [
{ "count": 11,reset_on_restore",
"user": "jm"reboot_on_restore"
],
"timeservice": "0.54539s"{
}, "_linksdescription": { "Not Applicable",
"exportid": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510/export",112,
"selfname": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510N/A",
"console": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510/console", "service_group_id": 15
"template": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510/template" },
"performance": "https://vss-api.eis.utoronto.ca:8001/v2/vm/5012689b-071a-145b-584a-9a9b49873510/performance" "usage": "Test"
}
} |
Request processing is almost instantaneous, however you could check the task progress by making a HTTP GET request to any given /v2/request/task/<task_id> endpoint.