mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
fix(FTP Node): Fix issue with connections not closing properly (#8619)
This commit is contained in:
parent
a3bed97883
commit
e597fbc78f
|
@ -439,8 +439,8 @@ export class Ftp implements INodeType {
|
|||
credential: ICredentialsDecrypted,
|
||||
): Promise<INodeCredentialTestResult> {
|
||||
const credentials = credential.data as ICredentialDataDecryptedObject;
|
||||
try {
|
||||
const ftp = new ftpClient();
|
||||
try {
|
||||
await ftp.connect({
|
||||
host: credentials.host as string,
|
||||
port: credentials.port as number,
|
||||
|
@ -448,11 +448,13 @@ export class Ftp implements INodeType {
|
|||
password: credentials.password as string,
|
||||
});
|
||||
} catch (error) {
|
||||
await ftp.end();
|
||||
return {
|
||||
status: 'Error',
|
||||
message: error.message,
|
||||
};
|
||||
}
|
||||
await ftp.end();
|
||||
return {
|
||||
status: 'OK',
|
||||
message: 'Connection successful!',
|
||||
|
@ -463,8 +465,8 @@ export class Ftp implements INodeType {
|
|||
credential: ICredentialsDecrypted,
|
||||
): Promise<INodeCredentialTestResult> {
|
||||
const credentials = credential.data as ICredentialDataDecryptedObject;
|
||||
try {
|
||||
const sftp = new sftpClient();
|
||||
try {
|
||||
if (credentials.privateKey) {
|
||||
await sftp.connect({
|
||||
host: credentials.host as string,
|
||||
|
@ -483,11 +485,13 @@ export class Ftp implements INodeType {
|
|||
});
|
||||
}
|
||||
} catch (error) {
|
||||
await sftp.end();
|
||||
return {
|
||||
status: 'Error',
|
||||
message: error.message,
|
||||
};
|
||||
}
|
||||
await sftp.end();
|
||||
return {
|
||||
status: 'OK',
|
||||
message: 'Connection successful!',
|
||||
|
@ -511,10 +515,9 @@ export class Ftp implements INodeType {
|
|||
} else {
|
||||
credentials = await this.getCredentials('ftp');
|
||||
}
|
||||
try {
|
||||
let ftp: ftpClient;
|
||||
let sftp: sftpClient;
|
||||
|
||||
try {
|
||||
if (protocol === 'sftp') {
|
||||
sftp = new sftpClient();
|
||||
if (credentials.privateKey) {
|
||||
|
@ -809,6 +812,11 @@ export class Ftp implements INodeType {
|
|||
await ftp!.end();
|
||||
}
|
||||
} catch (error) {
|
||||
if (protocol === 'sftp') {
|
||||
await sftp!.end();
|
||||
} else {
|
||||
await ftp!.end();
|
||||
}
|
||||
if (this.continueOnFail()) {
|
||||
return [[{ json: { error: error.message } }]];
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue