mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 01:56:46 +00:00
feat(Venafi TLS Protect Datacenter): add Venafi TLS Protect Datacenter node (#4255)
* ✨ Venafi TLS Protect Datacenter * ⚡ Add trigger to package.json * 👕 Fix lint issues * ⚡ Add codex * 👕 Fix linting issues * ⚡ Add paired items * 🔥 Remove trigger
This commit is contained in:
@@ -0,0 +1,94 @@
|
||||
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}}',
|
||||
},
|
||||
},
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user