FTPES - Reutilização de Sessão Necessária

Então, eu estou tentando se conectar a um servidor ftp para obter listagens de diretório e baixar arquivos. Mas o primeiro comando após a função prot_p () está levantando uma exceção - Produzindo esses erros a partir do log:

*get* '150 Here comes the directory listing.\r\n'
*resp* '150 Here comes the directory listing.'
*get* '522 SSL connection failed; session reuse required: see require_ssl_reuse
option in vsftpd.conf man page\r\n'
*resp* '522 SSL connection failed; session reuse required: see require_ssl_reuse
 option in vsftpd.conf man page'
Traceback (most recent call last):
  File "C:\temp\download.py", line 29, in <module>
    files = ftps.dir()
  File "C:\Python27\lib\ftplib.py", line 522, in dir
    self.retrlines(cmd, func)
  File "C:\Python27\lib\ftplib.py", line 725, in retrlines
    return self.voidresp()
  File "C:\Python27\lib\ftplib.py", line 224, in voidresp
    resp = self.getresp()
  File "C:\Python27\lib\ftplib.py", line 219, in getresp
    raise error_perm, resp
ftplib.error_perm: 522 SSL connection failed; session reuse required: see requir
e_ssl_reuse option in vsftpd.conf man page

Aqui está o código:

from ftplib import FTP_TLS
import os
import socket

host = 'example.com'
port = 34567
user = 'user1'
passwd = 'pass123'
acct = 'Normal'

ftps = FTP_TLS()

ftps.set_debuglevel(2)

ftps.connect(host, port)

print(ftps.getwelcome())
print(ftps.sock)

ftps.auth()

ftps.login(user, passwd, acct)

ftps.set_pasv(True)
ftps.prot_p()

print('Current directory:')
print(ftps.pwd())
files = ftps.dir()

ftps.quit()

Eu quero fazer isso de forma segura, portanto, usando o FTP sobre o TLS Explicit. Eu tenho a idéia de que eu possa precisar manipular algumas configurações na classe Socket referenciada pelo FTPLib. Alterar as configurações no servidor não é uma possibilidade. Eu testei o servidor com sucesso com o cliente FileZilla, uma versão mais antiga do WinSCP estava levantando o mesmo erro - embora uma atualização para a versão mais recente o tenha corrigido.

Alguma ideia?

questionAnswers(2)

yourAnswerToTheQuestion