mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-16 17:46:45 +00:00
124 lines
2.8 KiB
TypeScript
124 lines
2.8 KiB
TypeScript
import type { AxiosRequestConfig } from 'axios';
|
|
import axios from 'axios';
|
|
import jwt from 'jsonwebtoken';
|
|
import moment from 'moment-timezone';
|
|
import type {
|
|
ICredentialDataDecryptedObject,
|
|
ICredentialTestRequest,
|
|
ICredentialType,
|
|
IHttpRequestOptions,
|
|
INodeProperties,
|
|
} from 'n8n-workflow';
|
|
|
|
export class SalesforceJwtApi implements ICredentialType {
|
|
name = 'salesforceJwtApi';
|
|
|
|
displayName = 'Salesforce JWT API';
|
|
|
|
documentationUrl = 'salesforce';
|
|
|
|
properties: INodeProperties[] = [
|
|
{
|
|
displayName: 'Environment Type',
|
|
name: 'environment',
|
|
type: 'options',
|
|
options: [
|
|
{
|
|
name: 'Production',
|
|
value: 'production',
|
|
},
|
|
{
|
|
name: 'Sandbox',
|
|
value: 'sandbox',
|
|
},
|
|
],
|
|
default: 'production',
|
|
},
|
|
{
|
|
displayName: 'Client ID',
|
|
name: 'clientId',
|
|
type: 'string',
|
|
default: '',
|
|
required: true,
|
|
description: 'Consumer Key from Salesforce Connected App',
|
|
},
|
|
{
|
|
displayName: 'Username',
|
|
name: 'username',
|
|
type: 'string',
|
|
default: '',
|
|
required: true,
|
|
},
|
|
{
|
|
displayName: 'Private Key',
|
|
name: 'privateKey',
|
|
type: 'string',
|
|
typeOptions: {
|
|
password: true,
|
|
},
|
|
default: '',
|
|
required: true,
|
|
description:
|
|
'Use the multiline editor. Make sure it is in standard PEM key format:<br />-----BEGIN PRIVATE KEY-----<br />KEY DATA GOES HERE<br />-----END PRIVATE KEY-----',
|
|
},
|
|
];
|
|
|
|
async authenticate(
|
|
credentials: ICredentialDataDecryptedObject,
|
|
requestOptions: IHttpRequestOptions,
|
|
): Promise<IHttpRequestOptions> {
|
|
const now = moment().unix();
|
|
const authUrl =
|
|
credentials.environment === 'sandbox'
|
|
? 'https://test.salesforce.com'
|
|
: 'https://login.salesforce.com';
|
|
const signature = jwt.sign(
|
|
{
|
|
iss: credentials.clientId as string,
|
|
sub: credentials.username as string,
|
|
aud: authUrl,
|
|
exp: now + 3 * 60,
|
|
},
|
|
credentials.privateKey as string,
|
|
{
|
|
algorithm: 'RS256',
|
|
header: {
|
|
alg: 'RS256',
|
|
},
|
|
},
|
|
);
|
|
|
|
const axiosRequestConfig: AxiosRequestConfig = {
|
|
headers: {
|
|
'Content-Type': 'application/x-www-form-urlencoded',
|
|
},
|
|
method: 'POST',
|
|
data: new URLSearchParams({
|
|
grant_type: 'urn:ietf:params:oauth:grant-type:jwt-bearer',
|
|
assertion: signature,
|
|
}).toString(),
|
|
url: `${authUrl}/services/oauth2/token`,
|
|
responseType: 'json',
|
|
};
|
|
const result = await axios(axiosRequestConfig);
|
|
const { access_token } = result.data as { access_token: string };
|
|
|
|
return {
|
|
...requestOptions,
|
|
headers: {
|
|
...requestOptions.headers,
|
|
Authorization: `Bearer ${access_token}`,
|
|
},
|
|
};
|
|
}
|
|
|
|
test: ICredentialTestRequest = {
|
|
request: {
|
|
baseURL:
|
|
'={{$credentials?.environment === "sandbox" ? "https://test.salesforce.com" : "https://login.salesforce.com"}}',
|
|
url: '/services/oauth2/userinfo',
|
|
method: 'GET',
|
|
},
|
|
};
|
|
}
|