Sha256: 34fb07b457455450acfce97997cb455d2238da4ae855ea2c49433ad92be830e5
Contents?: true
Size: 1.79 KB
Versions: 5
Compression:
Stored size: 1.79 KB
Contents
require 'net/http' require 'net/https' require 'uri' require 'digest/sha1' require 'wagon/ward' module Wagon class AuthenticationFailure < StandardError; end class Connection HOST = 'secure.lds.org' LOGIN_PATH = '/units/a/login/1,21568,779-1,00.html?URL=' attr_reader :cookies def initialize(username, password) response = _post(LOGIN_PATH, 'username' => username, 'password' => password) @cookies = response['set-cookie'] @home_path = URI.parse(response['location']).path raise AuthenticationFailure.new("Invalid username and/or password") unless @cookies end def home_path @home_path end def ward @ward ||= Ward.new(self, home_path) end def get(path) _get(path).body end def expired? _head(ward.directory_path).class != Net::HTTPOK end def _dump(depth) Marshal.dump([@cookies, @home_path]) end def self._load(string) attributes = Marshal.restore(string) connection = Connection.allocate() connection.instance_variable_set(:@cookies, attributes.shift) connection.instance_variable_set(:@home_path, attributes.shift) connection end private def _http http = Net::HTTP.new(HOST, 443) http.use_ssl = true http.verify_mode = OpenSSL::SSL::VERIFY_NONE http end def _get(path) _http.request(Net::HTTP::Get.new(path, {'Cookie' => @cookies || ''})) end def _head(path) _http.request(Net::HTTP::Head.new(path, {'Cookie' => @cookies || ''})) end def _post(path, data) request = Net::HTTP::Post.new(path, {'Cookie' => @cookies || ''}) request.set_form_data(data) _http.request(request) end end end
Version data entries
5 entries across 5 versions & 1 rubygems
Version | Path |
---|---|
wagon-2.0.0 | lib/wagon/connection.rb |
wagon-1.1.1 | lib/wagon/connection.rb |
wagon-1.1.0 | lib/wagon/connection.rb |
wagon-1.0.1 | lib/wagon/connection.rb |
wagon-1.0.0 | lib/wagon/connection.rb |