module TwitterAuth class Error < StandardError; end def self.config(environment=RAILS_ENV) @config ||= {} @config[environment] ||= YAML.load(File.open(RAILS_ROOT + '/config/twitter_auth.yml').read)[environment] end def self.base_url config['base_url'] || 'https://twitter.com' end def self.path_prefix URI.parse(base_url).path end def self.api_timeout config['api_timeout'] || 10 end def self.encryption_key raise TwitterAuth::Cryptify::Error, 'You must specify an encryption_key in config/twitter_auth.yml' if config['encryption_key'].blank? config['encryption_key'] end def self.oauth_callback? config.key?('oauth_callback') end def self.oauth_callback config['oauth_callback'] end def self.remember_for (config['remember_for'] || 14).to_i end # The authentication strategy employed by this # application. Set in +config/twitter.yml+ as # strategy; valid options are oauth or basic. def self.strategy strat = config['strategy'] raise ArgumentError, 'Invalid TwitterAuth Strategy: Valid strategies are oauth and basic.' unless %w(oauth basic).include?(strat) strat.to_sym rescue Errno::ENOENT :oauth end def self.oauth? strategy == :oauth end def self.basic? strategy == :basic end # The OAuth consumer used by TwitterAuth for authentication. The consumer key and secret are set in your application's +config/twitter.yml+ def self.consumer OAuth::Consumer.new( config['oauth_consumer_key'], config['oauth_consumer_secret'], :site => TwitterAuth.base_url ) end def self.net uri = URI.parse(TwitterAuth.base_url) net = Net::HTTP.new(uri.host, uri.port) net.use_ssl = uri.scheme == 'https' net.read_timeout = TwitterAuth.api_timeout net end end require 'twitter_auth/controller_extensions' require 'twitter_auth/cryptify' require 'twitter_auth/dispatcher/oauth' require 'twitter_auth/dispatcher/basic' require 'twitter_auth/dispatcher/shared' module TwitterAuth module Dispatcher class Error < StandardError; end class Unauthorized < Error; end end end