-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
client.rb
103 lines (92 loc) · 3.11 KB
/
client.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
require 'faraday'
require 'multi_json'
require 'twitter/api/direct_messages'
require 'twitter/api/favorites'
require 'twitter/api/friends_and_followers'
require 'twitter/api/help'
require 'twitter/api/lists'
require 'twitter/api/places_and_geo'
require 'twitter/api/saved_searches'
require 'twitter/api/search'
require 'twitter/api/spam_reporting'
require 'twitter/api/suggested_users'
require 'twitter/api/timelines'
require 'twitter/api/trends'
require 'twitter/api/tweets'
require 'twitter/api/undocumented'
require 'twitter/api/users'
require 'twitter/configurable'
require 'twitter/error/client_error'
require 'twitter/error/decode_error'
require 'simple_oauth'
require 'uri'
module Twitter
# Wrapper for the Twitter REST API
#
# @note All methods have been separated into modules and follow the same grouping used in {http://dev.twitter.com/doc the Twitter API Documentation}.
# @see http://dev.twitter.com/pages/every_developer
class Client
include Twitter::API::DirectMessages
include Twitter::API::Favorites
include Twitter::API::FriendsAndFollowers
include Twitter::API::Help
include Twitter::API::Lists
include Twitter::API::PlacesAndGeo
include Twitter::API::SavedSearches
include Twitter::API::Search
include Twitter::API::SpamReporting
include Twitter::API::SuggestedUsers
include Twitter::API::Timelines
include Twitter::API::Trends
include Twitter::API::Tweets
include Twitter::API::Undocumented
include Twitter::API::Users
include Twitter::Configurable
# Initializes a new Client object
#
# @param options [Hash]
# @return [Twitter::Client]
def initialize(options={})
Twitter::Configurable.keys.each do |key|
instance_variable_set(:"@#{key}", options[key] || Twitter.instance_variable_get(:"@#{key}"))
end
end
# Perform an HTTP DELETE request
def delete(path, params={})
request(:delete, path, params)
end
# Perform an HTTP GET request
def get(path, params={})
request(:get, path, params)
end
# Perform an HTTP POST request
def post(path, params={})
signature_params = params.values.any?{|value| value.respond_to?(:to_io)} ? {} : params
request(:post, path, params, signature_params)
end
# Perform an HTTP PUT request
def put(path, params={})
request(:put, path, params)
end
private
def request(method, path, params={}, signature_params=params)
connection.send(method.to_sym, path, params) do |request|
request.headers[:authorization] = auth_header(method.to_sym, path, signature_params).to_s
end.env
rescue Faraday::Error::ClientError
raise Twitter::Error::ClientError
rescue MultiJson::DecodeError
raise Twitter::Error::DecodeError
end
# Returns a Faraday::Connection object
#
# @return [Faraday::Connection]
def connection
@connection ||= Faraday.new(@endpoint, @connection_options.merge(:builder => @middleware))
end
def auth_header(method, path, params={})
uri = URI(@endpoint + path)
SimpleOAuth::Header.new(method, uri, params, credentials)
end
end
end