mirror of
https://github.com/LukeHagar/plexjs.git
synced 2025-12-06 12:37:46 +00:00
217 lines
6.1 KiB
TypeScript
217 lines
6.1 KiB
TypeScript
import axios from "axios";
|
|
import * as os from 'os';
|
|
import * as path from 'path';
|
|
import * as yaml from "js-yaml";
|
|
import * as fs from "fs";
|
|
import { IAxiosRetryConfig } from "axios-retry";
|
|
|
|
export interface ConfigurationParameters {
|
|
baseurl?: string;
|
|
clientId?: string;
|
|
clientSecret?: string;
|
|
accessToken?: string;
|
|
tokenUrl?: string;
|
|
}
|
|
|
|
export interface Configuration {
|
|
activeenvironment?: string;
|
|
authtype?: string;
|
|
customexporttemplatespath?: string;
|
|
customsearchtemplatespath?: string;
|
|
debug?: boolean;
|
|
environments?: {[key: string]: Environment};
|
|
}
|
|
|
|
export interface Environment {
|
|
baseurl: string;
|
|
pat: Pat;
|
|
tenanturl: string;
|
|
}
|
|
|
|
export interface Pat {
|
|
clientid: string;
|
|
clientsecret: string;
|
|
}
|
|
|
|
export class Configuration {
|
|
|
|
/**
|
|
* parameter for apiKey security
|
|
* @param name security name
|
|
* @memberof Configuration
|
|
*/
|
|
apiKey?: string | Promise<string> | ((name: string) => string) | ((name: string) => Promise<string>);
|
|
|
|
/**
|
|
* parameter for clientId
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
clientId?: string;
|
|
/**
|
|
* parameter for clientSecret
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
clientSecret?: string;
|
|
/**
|
|
* parameter for clientSecret
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
/**
|
|
* parameter for oauth2 security
|
|
* @param name security name
|
|
* @param scopes oauth2 scope
|
|
* @memberof Configuration
|
|
*/
|
|
accessToken?: string | Promise<string> | ((name?: string, scopes?: string[]) => string) | ((name?: string, scopes?: string[]) => Promise<string>);
|
|
|
|
/**
|
|
* parameter for clientId
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
tokenUrl?: string;
|
|
/**
|
|
* parameter for basic security
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
username?: string;
|
|
/**
|
|
* parameter for basic security
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
password?: string;
|
|
/**
|
|
* override base path
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
basePathBeta?: string;
|
|
/**
|
|
* override base path
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
basePathV3?: string;
|
|
/**
|
|
* override base path
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
basePathV2?: string;
|
|
/**
|
|
* override base path
|
|
*
|
|
* @type {string}
|
|
* @memberof Configuration
|
|
*/
|
|
basePathCC?: string;
|
|
/**
|
|
* base options for axios calls
|
|
*
|
|
* @type {any}
|
|
* @memberof Configuration
|
|
*/
|
|
baseOptions?: any;
|
|
/**
|
|
* The FormData constructor that will be used to create multipart form data
|
|
* requests. You can inject this here so that execution environments that
|
|
* do not support the FormData class can still run the generated client.
|
|
*
|
|
* @type {new () => FormData}
|
|
*/
|
|
formDataCtor?: new () => any;
|
|
/**
|
|
* axios retry configuration
|
|
*
|
|
* @type {IAxiosRetryConfig}
|
|
* @memberof Configuration
|
|
*/
|
|
retriesConfig?: IAxiosRetryConfig
|
|
|
|
constructor(param?: ConfigurationParameters) {
|
|
|
|
if (!param) {
|
|
param = this.getParams()
|
|
}
|
|
|
|
this.basePathBeta = param.baseurl + `/beta`
|
|
this.basePathV3 = param.baseurl + `/v3`
|
|
this.basePathV2 = param.baseurl + `/v2`
|
|
this.basePathCC = param.baseurl
|
|
this.tokenUrl = param.tokenUrl
|
|
this.clientId = param.clientId;
|
|
this.clientSecret = param.clientSecret;
|
|
const url = `${this.tokenUrl}?grant_type=client_credentials&client_id=${this.clientId}&client_secret=${this.clientSecret}`;
|
|
if (!this.accessToken) {
|
|
this.accessToken = this.getAccessToken(url);
|
|
}
|
|
|
|
}
|
|
|
|
private getParams(): ConfigurationParameters {
|
|
const config: ConfigurationParameters = {}
|
|
try {
|
|
const homeDir = os.homedir()
|
|
const configPath = path.join(homeDir, '.sailpoint','config.yaml')
|
|
const doc = yaml.load(fs.readFileSync(configPath, 'utf8')) as Configuration
|
|
if (doc.authtype && doc.authtype.toLowerCase() === 'pat') {
|
|
config.baseurl = doc.environments[doc.activeenvironment].baseurl
|
|
config.clientId = doc.environments[doc.activeenvironment].pat.clientid
|
|
config.clientSecret = doc.environments[doc.activeenvironment].pat.clientsecret
|
|
}
|
|
} catch (error) {
|
|
console.log('unable to find config file')
|
|
}
|
|
config.baseurl = process.env["SAIL_BASE_URL"] ? process.env["BASE_URL"] : config.baseurl
|
|
config.clientId = process.env["SAIL_CLIENT_ID"] ? process.env["CLIENT_ID"] : config.clientId
|
|
config.clientSecret = process.env["SAIL_CLIENT_SECRET"] ? process.env["CLIENT_SECRET"] : config.clientSecret
|
|
|
|
config.tokenUrl = config.baseurl + '/oauth/token'
|
|
|
|
return config
|
|
}
|
|
|
|
private async getAccessToken(url: string): Promise<string> {
|
|
try {
|
|
const {data, status} = await axios.post(url)
|
|
if (status === 200) {
|
|
return data.access_token;
|
|
} else {
|
|
throw new Error("Unauthorized")
|
|
}
|
|
} catch (error) {
|
|
console.error("Unable to fetch access token. Aborting.");
|
|
throw new Error(error);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Check if the given MIME is a JSON MIME.
|
|
* JSON MIME examples:
|
|
* application/json
|
|
* application/json; charset=UTF8
|
|
* APPLICATION/JSON
|
|
* application/vnd.company+json
|
|
* @param mime - MIME (Multipurpose Internet Mail Extensions)
|
|
* @return True if the given MIME is JSON, false otherwise.
|
|
*/
|
|
public isJsonMime(mime: string): boolean {
|
|
const jsonMime: RegExp = new RegExp('^(application\/json|[^;/ \t]+\/[^;/ \t]+[+]json)[ \t]*(;.*)?$', 'i');
|
|
return mime !== null && (jsonMime.test(mime) || mime.toLowerCase() === 'application/json-patch+json');
|
|
}
|
|
} |