mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-18 02:21:13 +00:00
feat(Salesforce Node): Add credentials test (#14486)
This commit is contained in:
@@ -170,11 +170,10 @@ const isCredentialTestable = computed(() => {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
const hasUntestableExpressions = Object.values(credentialData.value).reduce(
|
const hasUntestableExpressions = credentialProperties.value.some((prop) => {
|
||||||
(accu: boolean, value: CredentialInformation) =>
|
const value = credentialData.value[prop.name];
|
||||||
accu || (typeof value === 'string' && isExpression(value) && !isTestableExpression(value)),
|
return typeof value === 'string' && isExpression(value) && !isTestableExpression(value);
|
||||||
false,
|
});
|
||||||
);
|
|
||||||
if (hasUntestableExpressions) {
|
if (hasUntestableExpressions) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,14 @@
|
|||||||
import type { ICredentialType, INodeProperties } from 'n8n-workflow';
|
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 {
|
export class SalesforceJwtApi implements ICredentialType {
|
||||||
name = 'salesforceJwtApi';
|
name = 'salesforceJwtApi';
|
||||||
@@ -52,4 +62,62 @@ export class SalesforceJwtApi implements ICredentialType {
|
|||||||
'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-----',
|
'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',
|
||||||
|
},
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user