2023-01-27 03:22:44 -08:00
|
|
|
import type {
|
2022-10-07 06:05:48 -07:00
|
|
|
IAuthenticateGeneric,
|
|
|
|
ICredentialDataDecryptedObject,
|
|
|
|
ICredentialType,
|
|
|
|
IHttpRequestHelper,
|
|
|
|
IHttpRequestOptions,
|
|
|
|
INodeProperties,
|
|
|
|
} from 'n8n-workflow';
|
|
|
|
|
|
|
|
export class VenafiTlsProtectDatacenterApi implements ICredentialType {
|
|
|
|
name = 'venafiTlsProtectDatacenterApi';
|
2022-12-02 12:54:28 -08:00
|
|
|
|
2022-10-07 06:05:48 -07:00
|
|
|
displayName = 'Venafi TLS Protect Datacenter API';
|
2022-12-02 12:54:28 -08:00
|
|
|
|
2022-12-22 08:01:29 -08:00
|
|
|
documentationUrl = 'venafitlsprotectdatacenter';
|
|
|
|
|
2022-10-07 06:05:48 -07:00
|
|
|
properties: INodeProperties[] = [
|
|
|
|
{
|
|
|
|
displayName: 'Domain',
|
|
|
|
name: 'domain',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
placeholder: 'https://example.com',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Client ID',
|
|
|
|
name: 'clientId',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Username',
|
|
|
|
name: 'username',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Password',
|
|
|
|
name: 'password',
|
|
|
|
type: 'string',
|
|
|
|
typeOptions: {
|
|
|
|
password: true,
|
|
|
|
},
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Allow Self-Signed Certificates',
|
|
|
|
name: 'allowUnauthorizedCerts',
|
|
|
|
type: 'boolean',
|
|
|
|
default: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Access Token',
|
|
|
|
name: 'token',
|
|
|
|
type: 'hidden',
|
2023-08-09 01:10:08 -07:00
|
|
|
|
2022-10-07 06:05:48 -07:00
|
|
|
typeOptions: {
|
|
|
|
expirable: true,
|
|
|
|
},
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Scope',
|
|
|
|
name: 'scope',
|
|
|
|
type: 'hidden',
|
|
|
|
default: 'certificate:manage',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
async preAuthentication(this: IHttpRequestHelper, credentials: ICredentialDataDecryptedObject) {
|
|
|
|
const url = `${credentials.domain}/vedauth/authorize/oauth`;
|
|
|
|
|
|
|
|
const requestOptions: IHttpRequestOptions = {
|
|
|
|
url,
|
|
|
|
method: 'POST',
|
|
|
|
json: true,
|
|
|
|
skipSslCertificateValidation: credentials.allowUnauthorizedCerts as boolean,
|
|
|
|
body: {
|
|
|
|
client_id: credentials.clientId,
|
|
|
|
username: credentials.username,
|
|
|
|
password: credentials.password,
|
|
|
|
scope: credentials.scope,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2022-11-22 03:44:35 -08:00
|
|
|
const { access_token } = (await this.helpers.httpRequest(requestOptions)) as {
|
|
|
|
access_token: string;
|
|
|
|
};
|
2022-10-07 06:05:48 -07:00
|
|
|
|
|
|
|
return { token: access_token };
|
|
|
|
}
|
|
|
|
|
|
|
|
authenticate: IAuthenticateGeneric = {
|
|
|
|
type: 'generic',
|
|
|
|
properties: {
|
|
|
|
headers: {
|
|
|
|
Authorization: '=Bearer {{$credentials.token}}',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|