xen-orchestra/packages/xen-api
2024-02-02 12:52:11 +01:00
..
examples feat: technical release (#7266) 2023-12-27 16:07:51 +01:00
transports chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_debug.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_getTaskResult.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_isGetAllRecordsMethod.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_isReadOnlyCall.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_makeCallSetting.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_parseUrl.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_parseUrl.spec.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_Ref.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_replaceSensitiveValues.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
_XapiError.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
.npmignore feat: unified .npmignore for all packages 2021-04-07 13:58:14 +02:00
.USAGE.md chore: hide USAGE.md 2022-02-18 17:11:52 +01:00
cli-lib.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
cli.mjs chore(xen-api): convert to ESM (#7181) 2023-11-20 14:32:44 +01:00
index.mjs fix(xen-api/setFieldEntry): avoid unnecessary MAP_DUPLICATE_KEY error 2024-01-09 15:10:37 +01:00
package.json chore: update to tap@18 2024-02-02 12:52:11 +01:00
README.md docs: uniformize code blocks 2023-02-06 11:25:12 +01:00

xen-api

Package Version License PackagePhobia Node compatibility

Connector to the Xen API

Install

Installation of the npm package:

npm install --save xen-api

Usage

Tested with:

  • XenServer 7.6
  • XenServer 7.5
  • XenServer 7.4
  • XenServer 7.3
  • XenServer 7.2
  • XenServer 7.1
  • XenServer 7
  • XenServer 6.5
  • XenServer 6.2
  • XenServer 5.6

Library

const { createClient } = require('xen-api')

const xapi = createClient({
  url: 'https://xen1.company.net',
  allowUnauthorized: false,
  auth: {
    user: 'root',
    password: 'important secret password',
  },
  readOnly: false,
})

Options:

  • url: address of a host in the pool we are trying to connect to
  • allowUnauthorized: whether to accept self-signed certificates
  • auth: credentials used to sign in (can also be specified in the URL)
  • readOnly = false: if true, no methods with side-effects can be called
  • callTimeout: number of milliseconds after which a call is considered failed (can also be a map of timeouts by methods)
  • httpProxy: URL of the HTTP/HTTPS proxy used to reach the host, can include credentials
// Force connection.
xapi.connect().catch(error => {
  console.error(error)
})

// Watch objects.
xapi.objects.on('add', objects => {
  console.log('new objects:', objects)
})

Note: all objects are frozen and cannot be altered!

Custom fields on objects (hidden ie. non enumerable):

  • $type: the type of the object (VM, task, …);
  • $ref: the (opaque) reference of the object;
  • $id: the identifier of this object (its UUID if any, otherwise its reference);
  • $pool: the pool object this object belongs to.

Furthermore, any field containing a reference (or references if an array) can be resolved by prepending the field name with a $:

console.log(xapi.pool.$master.$resident_VMs[0].name_label)
// vm1

CLI

A CLI is provided to help exploration and discovery of the XAPI.

> xen-api xen1.company.net root
Password: ******
root@xen1.company.net> xapi.status
'connected'
root@xen1.company.net> xapi.pool.master
'OpaqueRef:ec7c5147-8aee-990f-c70b-0de916a8e993'
root@xen1.company.net> xapi.pool.$master.name_label
'xen1'

You can optionally prefix the address by a protocol: https:// (default) or http://.

In case of error due to invalid or self-signed certificates you can use the --allow-unauthorized flag (or --au):

> xen-api --au xen1.company.net root

To ease searches, find() and findAll() functions are available:

root@xen1.company.net> findAll({ $type: 'VM' }).length
183

Contributions

Contributions are very welcomed, either on the documentation or on the code.

You may:

  • report any issue you've encountered;
  • fork and create a pull request.

License

ISC © Vates SAS