n8n/packages/nodes-base/credentials/ERPNextApi.credentials.ts
Iván Ovejero dec19585bc
refactor: Enforce expanded sensitive inputs rules (no-changelog) (#6815)
* refactor: Enforce expanded sensitive inputs rules (no-changelog)

* refactor: Add extra exemption

* fix: Add setting to `sessionToken` fields

* fix: Restore for `hidden` fields

* fix: More edge case exemptions

* fix: One more
2023-08-01 13:08:25 +02:00

132 lines
2.7 KiB
TypeScript

import type {
IAuthenticateGeneric,
ICredentialTestRequest,
ICredentialType,
INodeProperties,
} from 'n8n-workflow';
export class ERPNextApi implements ICredentialType {
name = 'erpNextApi';
displayName = 'ERPNext API';
documentationUrl = 'erpnext';
properties: INodeProperties[] = [
{
displayName: 'API Key',
name: 'apiKey',
type: 'string',
typeOptions: { password: true },
default: '',
},
{
displayName: 'API Secret',
name: 'apiSecret',
type: 'string',
typeOptions: { password: true },
default: '',
},
{
displayName: 'Environment',
name: 'environment',
type: 'options',
default: 'cloudHosted',
options: [
{
name: 'Cloud-Hosted',
value: 'cloudHosted',
},
{
name: 'Self-Hosted',
value: 'selfHosted',
},
],
},
{
displayName: 'Subdomain',
name: 'subdomain',
type: 'string',
default: '',
placeholder: 'n8n',
description:
'Subdomain of cloud-hosted ERPNext instance. For example, "n8n" is the subdomain in: <code>https://n8n.erpnext.com</code>',
displayOptions: {
show: {
environment: ['cloudHosted'],
},
},
},
{
displayName: 'Domain',
name: 'domain',
type: 'options',
default: 'erpnext.com',
options: [
{
name: 'erpnext.com',
value: 'erpnext.com',
},
{
name: 'frappe.cloud',
value: 'frappe.cloud',
},
],
description: 'Domain for your cloud hosted ERPNext instance.',
displayOptions: {
show: {
environment: ['cloudHosted'],
},
},
},
{
displayName: 'Domain',
name: 'domain',
type: 'string',
default: '',
placeholder: 'https://www.mydomain.com',
description: 'Fully qualified domain name of self-hosted ERPNext instance',
displayOptions: {
show: {
environment: ['selfHosted'],
},
},
},
{
displayName: 'Ignore SSL Issues',
name: 'allowUnauthorizedCerts',
type: 'boolean',
description: 'Whether to connect even if SSL certificate validation is not possible',
default: false,
},
];
authenticate: IAuthenticateGeneric = {
type: 'generic',
properties: {
headers: {
Authorization: '=token {{$credentials.apiKey}}:{{$credentials.apiSecret}}',
},
},
};
test: ICredentialTestRequest = {
request: {
baseURL:
'={{$credentials.environment === "cloudHosted" ? "https://" + $credentials.subdomain + "." + $credentials.domain : $credentials.domain}}',
url: '/api/method/frappe.auth.get_logged_user',
skipSslCertificateValidation: '={{ $credentials.allowUnauthorizedCerts }}',
},
rules: [
{
type: 'responseSuccessBody',
properties: {
key: 'message',
value: undefined,
message: 'Unable to authenticate, Check the credentials and the url',
},
},
],
};
}