Conecte al host no certificado a través de FTP a través de TLS / SSL

Un proveedor del que tomo un archivo está cambiando de FTP a FTP a través de SSL.

Estoy intentando actualizar mi código desdenet/ftp anet/ftptls

El nuevo host al que necesito conectarme no está certificado y mi script informa de este error.

hostname no coincide con el certificado del servidor

El vendedor no arreglará esto.

Mirando a/usr/lib/ruby/1.8/net/ftptls.rb Pensé que no sería demasiado difícil parchear el FTPTLS para ignorar el host no confiable.

Intenté cambiarverify_mode aOpenSSL::SSL::VERIFY_NONE y comentando la línea post_connection_check`.

ninguno funcionó.

¿Alguna idea sobre cómo hacer esto?

require 'socket'
require 'openssl'
require 'net/ftp'

module Net
  class FTPTLS < FTP
    def connect(host, port=FTP_PORT)
      @hostname = host
      super
    end

    def login(user = "anonymous", passwd = nil, acct = nil)
       store = OpenSSL::X509::Store.new
       store.set_default_paths
       ctx = OpenSSL::SSL::SSLContext.new('SSLv23')
       ctx.cert_store = store
       ctx.verify_mode = OpenSSL::SSL::VERIFY_PEER
       ctx.key = nil
       ctx.cert = nil
       voidcmd("AUTH TLS")
       @sock = OpenSSL::SSL::SSLSocket.new(@sock, ctx)
       @sock.connect
       @sock.post_connection_check(@hostname)
       super(user, passwd, acct)
       voidcmd("PBSZ 0")
    end
  end
end

Respuestas a la pregunta(4)

Su respuesta a la pregunta