mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-15 17:14:05 -08:00
61e26804ba
* ⚡ enabled array-type * ⚡ await-thenable on * ⚡ ban-types on * ⚡ default-param-last on * ⚡ dot-notation on * ⚡ member-delimiter-style on * ⚡ no-duplicate-imports on * ⚡ no-empty-interface on * ⚡ no-floating-promises on * ⚡ no-for-in-array on * ⚡ no-invalid-void-type on * ⚡ no-loop-func on * ⚡ no-shadow on * ⚡ ban-ts-comment re enabled * ⚡ @typescript-eslint/lines-between-class-members on * address my own comment * @typescript-eslint/return-await on * @typescript-eslint/promise-function-async on * @typescript-eslint/no-unnecessary-boolean-literal-compare on * @typescript-eslint/no-unnecessary-type-assertion on * prefer-const on * @typescript-eslint/prefer-optional-chain on Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
99 lines
2 KiB
TypeScript
99 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}}',
|
|
},
|
|
},
|
|
};
|
|
}
|