Подключиться к несертифицированному хосту через FTP через TLS/SSL

Поставщик, у которого я взял файл, переходит с FTP на FTP через SSL.

Я пытаюсь обновить свой код с net/ftpна net/ftptls

Новый хост, к которому мне нужно подключиться, не сертифицирован, и мой сценарий сообщает об этой ошибке.

Имя хоста не соответствует сертификату сервера.

Поставщик не исправит это.

Глядя на /usr/lib/ruby/1.8/net/ftptls.rb, я подумал, что будет несложно изменить FTPTLS, чтобы игнорировать ненадежный хост.

Я попытался изменить verify_modeна OpenSSL::SSL::VERIFY_NONEи закомментировать строку post_connection_check`.

не работает.

Есть мысли, как это сделать?

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
5
задан aidan 3 October 2014 в 06:32
поделиться