mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-25 20:54:07 -08:00
c738aa53e9
* add or update documentation URLs for all credentials * add UTM params to documentation urls even when they are absolute urls * Setup a CI job to validate documentation urls after every release * Fix FacebookGraphApi documentation URL * also validate node documentation urls Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
101 lines
2 KiB
TypeScript
101 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';
|
|
|
|
documentationUrl = 'venafitlsprotectdatacenter';
|
|
|
|
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}}',
|
|
},
|
|
},
|
|
};
|
|
}
|