mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-14 14:28:14 -08:00
95 lines
2 KiB
TypeScript
95 lines
2 KiB
TypeScript
|
import {
|
||
|
IAuthenticateGeneric,
|
||
|
ICredentialDataDecryptedObject,
|
||
|
ICredentialType,
|
||
|
IHttpRequestHelper,
|
||
|
IHttpRequestOptions,
|
||
|
INodeProperties,
|
||
|
} from 'n8n-workflow';
|
||
|
|
||
|
export class VenafiTlsProtectDatacenterApi implements ICredentialType {
|
||
|
name = 'venafiTlsProtectDatacenterApi';
|
||
|
displayName = 'Venafi TLS Protect Datacenter API';
|
||
|
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',
|
||
|
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,
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const { access_token } = await this.helpers.httpRequest(requestOptions) as { access_token: string };
|
||
|
|
||
|
return { token: access_token };
|
||
|
}
|
||
|
|
||
|
authenticate: IAuthenticateGeneric = {
|
||
|
type: 'generic',
|
||
|
properties: {
|
||
|
headers: {
|
||
|
Authorization: '=Bearer {{$credentials.token}}',
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
}
|