-
Notifications
You must be signed in to change notification settings - Fork 4
Home
A bluebird
Promise based vSphere client. Allows you to search managed objects and execute methods. More functionality will be provided in future releases.
var connect = require('vsphere-connect');
// create a client and automatically log in
connect.createClient({
host: 'vcenter.mydomain.com',
username: 'administrator@vsphere.local',
password: 'vmware1',
ignoreSSL: true,
autoLogin: true
})
.then(function(client) {
// retrieve 2 virtual machines by id
return client.retrieve({
type: 'VirtualMachine',
id: ['vm-1234', 'vm-5678'],
properties: ['name', 'config.version']
})
.then(function(results) {
// process results
});
})
.caught(function(err) {
// handle error
});
Creates a new vSphere client
Parameters
-
args
{Object}
- Arguments hash-
host
{string}
- viServer DNS name or IP -
[
username
]{string}
- User name to log in with. Optional if using a session id to login -
[
password
]{string}
- Password. Required if using username to log in -
[
sessionId
]{string}
- Session Id to authenticate with -
[
ignoreSSL=false
]{boolean}
- Ignore invalid SSL certificates during login -
[
autoLogin=false
]{boolean}
- If true, automatically log in after client creation -
[
exclusive=false
]{boolean}
- If true, terminate all other sessions from the same user and IP keeping the current. Useful for service crash and restart -
[
maxRetry=1
]{number}
- Number of times to try reconnecting after receiving aNotAuthenticatedFault
-
[
events
]{Object | boolean}
- Query the viServer for events and emit those events as javascript events from the client-
[
interval=60000
]{number}
- Time in milliseconds between Event queries
-
[
-
Returns
{Promise}
- Returns a Promise that resolves to a viClient instance
Log into vSphere. Not necessary if autoLogin=true
was passed to createClient()
Parameters
-
args
{Object}
- Arguments hash-
[
username
]{string}
- User name to log in with. Optional if using a session id to login -
[
password
]{string}
- Password. Required if using username to log in -
[
sessionId
]{string}
- Session Id to authenticate with -
[
exclusive=false
]{boolean}
- If true, terminate all other sessions from the same user and IP keeping the current. Useful for service crash and restart -
[
maxRetry=1
]{number}
- Number of times to try reconnecting after receiving aNotAuthenticatedFault
-
[
Returns
{Promise}
- Returns a Promise that resolves to a session object
Events
- login
Log out of vSphere
Returns
{Promise}
- Returns a Promise
Events
- logout
Executes a vSphere method
Parameters
-
name
{string}
- Method name -
args
{Object}
- Arguments for the method
Returns
{Promise}
- Returns a Promise that resolves to the method output
Creates a new vSphere client
Parameters
-
args
{Object}
- Arguments hash-
type
{string}
- Managed Object type -
[
id
]{string | string[]}
- Id or array of Ids to retrieve -
[
container=rootFolder
]{ManagedObjectReference}
- Container to start search from -
[
recursive=true
]{boolean}
- Recursive search -
[
properties
]{string | string[]}
- if "all" all properties retrieved. Otherwise array of dot notation properties
-
Returns
{Promise}
- Returns a Promise that resolves to the results of the retrieval
Destroy a Managed Object
Parameters
-
args
{Object}
- Arguments hash-
type
{string}
- Managed Object type -
id
{string}
- Id of object to destroy -
[
async=true
]{boolean}
- Iffalse
, the task generated will be monitored to completion and returned -
[
delay=250
]{number}
- Delay in milliseconds between monitor queries forasync=false
-
[
timeout=0
]{number}
- Time in milliseconds before the monitor operation should timeout, 0 for never
-
Returns
{Promise}
- Returns a Promise that resolves to the destroy task
Destroy a Managed Object
Parameters
-
args
{Object}
- Arguments hash-
type
{string}
- Managed Object type -
id
{string}
- Id of object to rename -
name
{string}
- New Name -
[
async=true
]{boolean}
- Iffalse
, the task generated will be monitored to completion and returned -
[
delay=250
]{number}
- Delay in milliseconds between monitor queries forasync=false
-
[
timeout=0
]{number}
- Time in milliseconds before the monitor operation should timeout, 0 for never
-
Returns
{Promise}
- Returns a Promise that resolves to the rename task
Returns the server time
Returns
{Promise}
- Returns a Promise that resolves to the server time
Creates a ManagedObjectReference
-
type
{string}
- Managed Object type -
id
{string}
- Id of object
Returns
{ManagedObjectReference}
- Returns a ManagedObjectReference that can be used with client.method()
vsphere-connect
has the option to periodically query the viServer for recent events. These events are then emitted from the client. This means that events are not real time but may still be useful. A user defined interval for polling can be set when creating the client to allow for more frequent event queries. The event monitor also emits an emitlog
event after every interval so it can also be used to track the status of the event monitor.
var connect = require('vsphere-connect');
var util = connect.util;
// create a client and automatically log in
connect.createClient({
host: 'vcenter.mydomain.com',
username: 'administrator@vsphere.local',
password: 'vmware1',
ignoreSSL: true,
autoLogin: true
})
.then(function(client) {
// create a destroy task to remove a vm
return client.method('Destroy_Task', {
_this: util.moRef('VirtualMachine', 'vm-123')
})
.then(function(result) {
// process the results
});
});
var connect = require('vsphere-connect');
var util = connect.util;
// create a client and automatically log in
connect.createClient({
host: 'vcenter.mydomain.com',
username: 'administrator@vsphere.local',
password: 'vmware1',
ignoreSSL: true,
autoLogin: true,
events: {
interval: 10000 // every 10 seconds
}
})
.then(function(client) {
// add event listener
client.on('TaskEvent', function(task) {
// process task
});
});