JSPM

genesys-provisioning-client-js

1.0.391
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 5041
  • Score
    100M100P100Q99943F
  • License MIT

Provisioning API used to create objects in configuration server in a way that is consistent with the BEC model

Package Exports

  • genesys-provisioning-client-js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (genesys-provisioning-client-js) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Provisioning Client Library

The Provisioning Client Library is a Node.js wrapper for the Provisioning API that makes it easier to code against the API. The library provides much of the supporting code needed to make HTTP requests and process HTTP responses.

The library is hosted on GitHub and Genesys welcomes pull requests for corrections.

Install

Genesys recommends that you install the Provisioning Client Library for Node.js with NPM. Run the following command to install the library:

npm i genesys-provisioning-client-js

Classes

The Provisioning Client Library includes the following classes:

These classes contains all the resources and events that are part of the Provisioning API, along with all the methods you need to access the API functionality.

Examples

Here's an example of how you can use the Provisioning Client Library to create a new user.

const provisioning = require('genesys-provisioning-client-js');

const apiKey = "<apiKey>";
const username = "<username>";
const password = "<password>";
const apiUrl = "<apiUrl>";

const provisioningUrl = `${apiUrl}/provisioning/v3`;

//Create and setup ApiClient instance with your ApiKey and Provisioning API URL.
const provisioningClient = new provisioning.ApiClient();
provisioningClient.basePath = provisioningUrl;
provisioningClient.defaultHeaders = { 'x-api-key': apiKey };

//Creating instance of SessionApi using the ApiClient.
const sessionApi = new provisioning.SessionApi(provisioningClient);

//Logging in using our username and password
sessionApi.login({
    domain_username: username,
    password: password
}).then(resp => {
    if(resp.status.code !== 0) {
        throw new Error('Cannot log in');
    }

    return resp.data;
}).then(resp => {
    //Obtaining sessionId and setting PROVISIONING_SESSIONID cookie to the client
    const sessionId = resp.sessionId;
    provisioningClient.defaultHeaders.Cookie = `PROVISIONING_SESSIONID=${sessionId};`;

    //Creating instance of UsersApi using the ApiClient
    const usersApi = new provisioning.UsersApi(provisioningClient);

    //Creating a user using UsersApi instance
    const user = {
        userName: "<agentUsername>",
        firstName: "<agentFirstName>",
        lastName: "<agentLastName>",
        password: "<agentPassword>",
        accessGroup: [ "<agentAccessGroup>" ]
    };

    return usersApi.addUser(user);
}).then(resp => {
    if(resp.status.code !== 0) {
        throw new Error("Cannot create user");
    }

    return resp.data;
}).then(data => {
    //Ending our Provisioning API session
    sessionApi.logout();
}).catch(err => {
    console.error(err);
});

For usage examples for each method available in the library, see the documentation for the classes.