mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 13:27:31 -08:00
🐛 Fix credential testing for versioned nodes
This commit is contained in:
parent
2b3079a0a5
commit
7d5f65d8c0
|
@ -1,3 +1,4 @@
|
||||||
|
/* eslint-disable @typescript-eslint/no-non-null-assertion */
|
||||||
/* eslint-disable no-restricted-syntax */
|
/* eslint-disable no-restricted-syntax */
|
||||||
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
||||||
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
||||||
|
@ -423,7 +424,6 @@ export class CredentialsHelper extends ICredentialsHelper {
|
||||||
type,
|
type,
|
||||||
};
|
};
|
||||||
|
|
||||||
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
||||||
await Db.collections.Credentials!.update(findQuery, newCredentialsData);
|
await Db.collections.Credentials!.update(findQuery, newCredentialsData);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -460,8 +460,25 @@ export class CredentialsHelper extends ICredentialsHelper {
|
||||||
for (const credential of nodeType.description.credentials ?? []) {
|
for (const credential of nodeType.description.credentials ?? []) {
|
||||||
if (credential.name === credentialType && !!credential.testedBy) {
|
if (credential.name === credentialType && !!credential.testedBy) {
|
||||||
if (typeof credential.testedBy === 'string') {
|
if (typeof credential.testedBy === 'string') {
|
||||||
|
if (Object.prototype.hasOwnProperty.call(node, 'nodeVersions')) {
|
||||||
|
// The node is versioned. So check all versions for test function
|
||||||
|
// starting with the latest
|
||||||
|
const versions = Object.keys((node as INodeVersionedType).nodeVersions)
|
||||||
|
.sort()
|
||||||
|
.reverse();
|
||||||
|
for (const version of versions) {
|
||||||
|
const versionedNode = (node as INodeVersionedType).nodeVersions[
|
||||||
|
parseInt(version, 10)
|
||||||
|
];
|
||||||
|
if (
|
||||||
|
versionedNode.methods?.credentialTest &&
|
||||||
|
versionedNode.methods?.credentialTest[credential.testedBy]
|
||||||
|
) {
|
||||||
|
return versionedNode.methods?.credentialTest[credential.testedBy];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
// Test is defined as string which links to a functoin
|
// Test is defined as string which links to a functoin
|
||||||
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
||||||
return (node as unknown as INodeType).methods?.credentialTest![credential.testedBy];
|
return (node as unknown as INodeType).methods?.credentialTest![credential.testedBy];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue