0.3.11 • Published 6 years ago
ts-vcenter v0.3.11
TS-vCenter
TS-vCenter is a NodeJS module for interacting with a vCenter Server via the Automation REST API
TypeDoc Documentation
Working
- Combo method of Content Library, Items, and Info
- VM Templates - List, Deployment
- VMs
- Hosts
- Datastores
- Most Content Library Stuff
- Folders
- Datacenters
- Clusters
Usage
First you need to get a session token
import { loginVCSA, vCenter } from 'ts-vcenter';
const Start = async () => {
  const token = await loginVCSA({
    username: 'Administrator@vsphere.local',
    url: 'https://vsphere.local',
    password: 'password',
  });
  const vcsa = new vCenter({ url: 'https://vsphere.local', token });
  const VMs = await vcsa.getVMs();
  console.log(VMs);
}
Start()
};Get Hosts
const getHosts = async () => {
  const Hosts = await vcsa.getHosts();
  Hosts.map(host => console.log(host.name, host.connection_state, host.power_state));
};For more examples checkout the JSDoc/TSDoc defs on each method.
Extras
If you need any more methods added just open an issue on the GitHub repo and I'll have it added within a day. Or open a PR if you would like.
All requests are done with the internal this.vCenterGetRequest or this.vCenterPostRequest methods in the vCenter class
Example
  public getHosts = async (filter?: HostsFilter): Promise<Hosts[]> => this.vCenterGetRequest('/vcenter/host', filter);