secobarbital-twitter 0.9.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (84) hide show
  1. data/History +271 -0
  2. data/License +20 -0
  3. data/Notes +33 -0
  4. data/README.rdoc +19 -0
  5. data/Rakefile +39 -0
  6. data/VERSION.yml +5 -0
  7. data/examples/connect.rb +30 -0
  8. data/examples/friendship_existance.rb +13 -0
  9. data/examples/helpers/config_store.rb +38 -0
  10. data/examples/httpauth.rb +11 -0
  11. data/examples/ids.rb +13 -0
  12. data/examples/lists.rb +11 -0
  13. data/examples/oauth.rb +27 -0
  14. data/examples/search.rb +15 -0
  15. data/examples/timeline.rb +19 -0
  16. data/examples/tumblr.rb +9 -0
  17. data/examples/unauthorized.rb +16 -0
  18. data/examples/update.rb +11 -0
  19. data/examples/user.rb +5 -0
  20. data/lib/twitter/base.rb +371 -0
  21. data/lib/twitter/httpauth.rb +39 -0
  22. data/lib/twitter/local_trends.rb +15 -0
  23. data/lib/twitter/oauth.rb +58 -0
  24. data/lib/twitter/request.rb +71 -0
  25. data/lib/twitter/search.rb +157 -0
  26. data/lib/twitter/trends.rb +41 -0
  27. data/lib/twitter.rb +148 -0
  28. data/test/fixtures/blocking.json +1632 -0
  29. data/test/fixtures/firehose.json +1 -0
  30. data/test/fixtures/follower_ids.json +1 -0
  31. data/test/fixtures/followers.json +1 -0
  32. data/test/fixtures/friend_ids.json +1 -0
  33. data/test/fixtures/friends_timeline.json +1 -0
  34. data/test/fixtures/friendship.json +1 -0
  35. data/test/fixtures/home_timeline.json +1 -0
  36. data/test/fixtures/ids.json +1 -0
  37. data/test/fixtures/list.json +1 -0
  38. data/test/fixtures/list_statuses.json +1 -0
  39. data/test/fixtures/list_statuses_1_1.json +1 -0
  40. data/test/fixtures/list_statuses_2_1.json +1 -0
  41. data/test/fixtures/list_subscriptions.json +1 -0
  42. data/test/fixtures/list_users.json +1 -0
  43. data/test/fixtures/lists.json +1 -0
  44. data/test/fixtures/memberships.json +1 -0
  45. data/test/fixtures/mentions.json +1 -0
  46. data/test/fixtures/not_found.json +1 -0
  47. data/test/fixtures/people_search.json +39 -0
  48. data/test/fixtures/rate_limit_exceeded.json +1 -0
  49. data/test/fixtures/retweet.json +1 -0
  50. data/test/fixtures/retweeted_by_me.json +1 -0
  51. data/test/fixtures/retweeted_to_me.json +1 -0
  52. data/test/fixtures/retweeters_of_tweet.json +166 -0
  53. data/test/fixtures/retweets.json +1 -0
  54. data/test/fixtures/retweets_of_me.json +1 -0
  55. data/test/fixtures/sample-image.png +0 -0
  56. data/test/fixtures/search.json +1 -0
  57. data/test/fixtures/search_from_jnunemaker.json +1 -0
  58. data/test/fixtures/status.json +1 -0
  59. data/test/fixtures/status_show.json +1 -0
  60. data/test/fixtures/trends_available.json +253 -0
  61. data/test/fixtures/trends_current.json +1 -0
  62. data/test/fixtures/trends_current_exclude.json +1 -0
  63. data/test/fixtures/trends_daily.json +1925 -0
  64. data/test/fixtures/trends_daily_date.json +1 -0
  65. data/test/fixtures/trends_daily_exclude.json +1 -0
  66. data/test/fixtures/trends_location.json +57 -0
  67. data/test/fixtures/trends_weekly.json +1 -0
  68. data/test/fixtures/trends_weekly_date.json +1 -0
  69. data/test/fixtures/trends_weekly_exclude.json +1 -0
  70. data/test/fixtures/unauthorized.json +1 -0
  71. data/test/fixtures/update_profile_background_image.json +1 -0
  72. data/test/fixtures/update_profile_image.json +1 -0
  73. data/test/fixtures/user.json +1 -0
  74. data/test/fixtures/user_timeline.json +710 -0
  75. data/test/fixtures/users.json +1 -0
  76. data/test/test_helper.rb +46 -0
  77. data/test/twitter/base_test.rb +364 -0
  78. data/test/twitter/httpauth_test.rb +76 -0
  79. data/test/twitter/oauth_test.rb +108 -0
  80. data/test/twitter/request_test.rb +217 -0
  81. data/test/twitter/search_test.rb +208 -0
  82. data/test/twitter/trends_test.rb +112 -0
  83. data/test/twitter_test.rb +106 -0
  84. metadata +280 -0
data/History ADDED
@@ -0,0 +1,271 @@
1
+ 0.9.2 - March 24, 2010
2
+ * More patches from @sferik for better authentication error handling and tests
3
+ 0.9.1 - March 23, 2010
4
+ * More patches from @sferik for bug fixes, removed rubygems dependencies, and more
5
+ 0.9.0 - March 20, 2010
6
+ * Added support for new retweeted_by and retweeted_by ids methods
7
+ * Added support for popular/recent search
8
+ * Patch from @sferik for API versioning and bulk user import
9
+ * Patch from @abozanich for search exclusions
10
+ 0.8.6 - March 11, 2010
11
+ * Patch from @dewski for httparty version
12
+ 0.8.5 - February 21, 2010
13
+ * Patch from @cyu to add fetch_next_page to search
14
+ 0.8.4 - February 11, 2010
15
+ * Added membership query options // thanks ming yeow ng
16
+ * Added support for a phrase search (instead of a group of words) from @zagari
17
+ * Added support for trends/available and trends/location
18
+ 0.8.3 - January 29, 2010
19
+ * Added patch for unauthenticated list timelines from @spastorino
20
+ 0.8.2 - January 21, 2010
21
+ * Added patch for update_profile_image from @taazza
22
+ 0.8.1 - January 12, 2010
23
+ * Added unauthenticated timeline method just for @mtodd
24
+ 0.8.0 - December 18, 2009
25
+ * Made API endpoint configurable to use services like Tumblr
26
+ 0.7.11 - December 16, 2009
27
+ * Added support for list timeline paging (patch from Chen)
28
+ 0.7.10 - December 12, 2009
29
+ * Added support for blocks/blocking
30
+ 0.7.9 - December 1, 2009
31
+ * Applied patch from ivey for retweets support
32
+ 0.7.8 - November 30, 2009
33
+ * Applied patch from ivey to use cursor with list_members
34
+ 0.7.7 - November 29, 2009
35
+ * Fixed bug when removing list members using OAuth
36
+ * Merged patch from kevn for update_profile_background
37
+ * Bumped OAuth dependency to 0.3.6
38
+ * Merged patch from rizwanreza for blocked_ids
39
+ * Merged patch from Josh Schairbaum for since_date and until_date search methods
40
+ 0.7.6 - November 25, 2009
41
+ * Patch from coderifous for home_timeline support
42
+ 0.7.5 - November 17, 2009
43
+ * Patch from hassox to swap Mash for Hashie to avoid conflicts
44
+ 0.7.4 - November 16, 2009
45
+ * Support for user search
46
+ 0.7.3 - November 5, 2009
47
+ * Support for list_subscriptions from christospappas
48
+ 0.7.2 - November 5, 2009
49
+ * Support for friendship_show from dcrec1
50
+ 0.7.1 - November 4, 2009
51
+ * Dependency changes
52
+ 0.7.0 - October 31, 2009
53
+ * Twitter lists! - based on draft API
54
+ 0.6.14 - August 16, 2009
55
+ * Lowered the oauth requirement to 0.3.4 as people are complaining about 0.3.5
56
+
57
+ 0.6.13 - July 27, 2009
58
+ * 1 minor update
59
+ * Set oauth version to >= 0.3.5 so I don't have to release new gem for each oauth update, which seems to be frequent of late
60
+
61
+ 0.6.12 - June 26, 2009
62
+ * 2 minor additions
63
+ * fixed fakeweb test issue (obie fernandez)
64
+ * added user agent option to searches
65
+
66
+ 0.6.11 - May 18, 2009
67
+ * 1 minor addition
68
+ * Added the ability to sign in with twitter instead of authorizing
69
+
70
+ 0.6.10 - May 18, 2009
71
+ * 1 cool addition
72
+ * Added full support for trends - current, daily and weekly (even allowing excluding of hashtags and for specific dates)
73
+
74
+ 0.6.9 - May 17, 2009
75
+ * 1 minor tweak
76
+ * Bumped oauth dependency version to 0.3.4.
77
+
78
+ 0.6.8 - April 23, 2009
79
+ * 1 dependency fix
80
+ * forgot to update rakefile rendering previous 0.6.7 release useless. crap!
81
+
82
+ 0.6.7 - April 23, 2009
83
+ * 1 minor fix
84
+ * Bumped httparty version to 0.4.3 which allows response.message and fixes errors that the lack of response.message was causing to the twitter gem
85
+
86
+ 0.6.6 - April 16, 2009
87
+ * 1 minor enhancement
88
+ * added ability to pass query parameters to user method
89
+ * httpauth can now accept :ssl option to use https instead of http
90
+ * Added Twitter.status method for no auth calls to fetch status
91
+ * Added Twitter.friend_ids method for no auth calls to fetch status
92
+ * Added Twitter.follower_ids method for no auth calls to fetch status
93
+
94
+ 0.6.5 - April 15, 2009
95
+ * 1 bug fix
96
+ * fixed that friend_ids and follower_ids were bombing from trying to mash them. Added :mash option to Twitter::Request so I can specifically not mash certain responses from twitter
97
+
98
+ 0.6.4 - April 14, 2009
99
+ * 1 minor tweak
100
+ * More explicit about dependency versions in gemspec and when requiring.
101
+
102
+ 0.6.3 - April 14, 2009
103
+ * 1 minor addition
104
+ * Added Twitter.user method to get user's information without authenticating
105
+
106
+ 0.6.2 - April 14, 2009
107
+ * 1 minor addition
108
+ * added max to search so you can set the max id that should be used
109
+
110
+ 0.6.1 - April 12, 2009
111
+ * 1 minor fix
112
+ * Had two friend_ids functions. Renamed one of them to follower_ids.
113
+
114
+ 0.6.0 - April 11, 2009
115
+ * 1 feature addition
116
+ * Added http authentication back in. You can now use oauth or http auth as your client.
117
+
118
+ 0.5.3 - April 10, 2009
119
+ * 1 minor fix
120
+ * Twitter API assumed follow true whether true or false. Now only sending follow along to request if follow is true for calls to friendship_create.
121
+
122
+ 0.5.2 - April 8, 2009
123
+ * 4 minor fixes
124
+ * added mash as an install dependency, forgot it initially
125
+ * fixed that search wasn't taking into account a bunch of options duh!
126
+ * fixed some missing vars and stuff in exception raising
127
+ * added development dependencies to rake file to make that more explicit (technomancy)
128
+ * lame workaround for Mash#hash that allows using return objects in sets and such (technomancy)
129
+
130
+ 0.5.1 - April 5, 2009
131
+ * 1 minor change
132
+ * Added data error hash returned from twitter to a few of the exceptions to help with debugging
133
+ * Fixed friendship_exists?. Was throwing mash stringify keys error because it was returning true or false instead of hash or array.
134
+
135
+ 0.5.0 - April 3, 2009
136
+ * 1 major rewrite for OAuth
137
+ * Backwards compatibility thrown to the wind
138
+ * Proxy no longer supported (someone please add it back in, I never use proxies)
139
+ * Identica support killed with an axe (nothing against them but I don't use it)
140
+ * CLI shot to death (will be reborn at a later date using oauth and its own gem)
141
+
142
+ 0.4.3 - February 21, 2009
143
+ * 1 minor enhancement
144
+ * verify_credentials now returns a Twitter::User rather than an hpricot doc
145
+
146
+ 0.4.2 - February 10, 2009
147
+ * 1 minor enhancement
148
+ * Adding the Social Graph API methods (Josh Owens)
149
+
150
+ 0.4.1 - January 1, 2009
151
+ * 4 minor enhancements and 2 bug fixes:
152
+ * Added better exception handling (Billy Gray)
153
+ * Added page to search (Michael Ivey)
154
+ * Adding an option to display tweets on CLI in reverse order (oldest first). (Cameron Booth)
155
+ * Added in_reply_to_status_id option for replying to statuses (anthonycrumley)
156
+ * Fixed a bug where the @config was improperly set (K. Adam Christensen)
157
+ * Fix verify_credentials to include a format (breaks in laconica). (dustin)
158
+
159
+ 0.4.0 - December 23, 2008
160
+ * 3 major changes
161
+ * Removed active support as dependency
162
+ * Removed CLI dependencies from install dependency list
163
+ (they are now only installed by you manually)
164
+ * Switched to echoe for gem managment
165
+
166
+ 0.3.7 - August 26, 2008
167
+ * Fixed source param not getting through
168
+
169
+ 0.3.6 - August 11, 2008
170
+ * Fixed a few more methods that required post.
171
+ * Refactored the remaining methods that were not using #request to use it.
172
+
173
+ 0.3.5 - August 4, 2008
174
+ * Removed sqlite-ruby 1.2.2 as a dependency due to install issues on linux
175
+
176
+ 0.3.4 - August 3, 2008
177
+ * Added search support
178
+
179
+ 0.3.3 - August 3, 2008
180
+ * Now has option for host when initializing to support identi.ca (Dustin Sallings)
181
+ * Twitter changed a bunch of methods to POST only so I updated those to now work
182
+
183
+ 0.3.2 - July 26, 2008
184
+ * added the CLI gems as dependencies for now until I separate out the CLI from the API wrapper
185
+ * cleaner CLI errors for no active account or no accounts at all
186
+ * remove sets a new active account if there are none
187
+ * added username and password optional arguments to add
188
+ * added import attempt on install and on anything that uses #current_account helper
189
+
190
+ 0.3.1 - July 23, 2008
191
+ * added open to CLI twitter open jnunemaker would open default browser to http://twitter.com/jnunemaker
192
+ * added -f to timeline and replies which ignores the since_id and shows all results
193
+ * added clear_config to remove all cached since id's and such
194
+ * Majorly pimped the output of timelines and replies.
195
+
196
+ 0.3.0 - July 22, 2008
197
+ * complete rewrite of CLI. Now supports multiple accounts and changing between them.
198
+ * added source, truncated, in_reply_to_status_id, in_reply_to_user_id, and favorited to Twitter::Status
199
+ * added protected to Twitter::User
200
+ * d CLI method now takes standard input like post
201
+ * Rewrote several methods that had since parameter to now use a hash instead. This makes it more flexible as API updates.
202
+ * Rewrote the methods that took lite or since as an argument to instead take a hash.
203
+ * added Twitter::Base#friendship_exists?
204
+ * added Twitter::Base#update_location
205
+ * added Twitter::Base#update_delivery_device
206
+ * added Twitter::Base#favorites
207
+ * added Twitter::Base#create_favorite
208
+ * added Twitter::Base#destroy_favorite
209
+ * added Twitter::Base#block
210
+ * added Twitter::Base#unblock
211
+
212
+ BACKWORDS COMPATIBILITY BREAK:
213
+ Any method that you have using lite or since as an argument
214
+ will no longer work with this version. Simply change to a
215
+ hash and you'll be fine. For example:
216
+
217
+ friends(true) would now be friends(:lite => true)
218
+
219
+ 0.2.7 - June 29, 2008
220
+ * added #rate_limit_status (Daniel Morrison)
221
+ * added source parameter option to Base#post
222
+ * added twittergem as source when posting from command line
223
+ * Twitter::RateExceeded raised when you hit your limit (Jim O'Leary)
224
+ * Twitter::Unavailable raised when twitter returns 503
225
+ * Twitter::CantConnect is now more descriptive as to what is the problem when it is raised during a request
226
+ * quoting your message when using twitter post on the command line is now optional (Benoit Caccinolo)
227
+ * aliased post to p on command line so it's shorter (Benoit Caccinolo)
228
+ * unescaped html and added some color in command line view (Miles Z. Sterrett)
229
+ * added gemspec (technoweenie, Miles Z. Sterrett)
230
+ * Fixed stack trace error on first command line operation (Matt Rose)
231
+ 0.2.6 - April 2, 2008
232
+ * found a more simple way of doing stdin without any extra gem dependencies
233
+ 0.2.5 - April 2, 2008
234
+ * Command line interface can now use stdin for posting (ideas and example code from Jeremy Friesen)
235
+ $ twitter post 'test without stdin' # => twitters: test without stdin
236
+ $ echo 'test with stdin' | twitter post 'and an argv[1]' # => twitters: test with stdin and an argv[1]
237
+ $ echo 'test with stdin without any argv[1]' | twitter post # => twitters: test with stdin without any argv[1]
238
+ 0.2.4 - Mar 31, 2008
239
+ * Added lite option to friends and followers, which doesn't include the user's current status (Daniel Morrison)
240
+ * Updated since option to use HTTP header, and added the option on timeline() and replies(). (Daniel Morrison)
241
+ 0.2.3 - Jan 16, 2008
242
+ * added d to command line interface twitter d jnunemaker 'hola' (Humbucker)
243
+ * added progress dots when posting for confirmation when twitter is running slow (Hendy Irawan)
244
+ 0.2.2 - added leave and follow which are new twitter api methods for turning notifications on and off
245
+ 0.2.0 - Aug 4, 2007
246
+ * added sent_messages
247
+ * alias direct_messages to received_messages
248
+ * added create_friendship
249
+ * added destroy_friendship
250
+ * added featured to retrieve the featured twitter users
251
+ * added replies
252
+ * added destroy to destroy a status by id
253
+ * added status to find a status by id
254
+ * added active support as an extra dependency
255
+ * implemented d method to send direct messages (jnewland)
256
+ * fixed since argument in direct_messages method (jnewland)
257
+ 0.1.1 - May 20, 2007
258
+ * hpricot 0.5+ now supported; just a bug fix (Ryan Waldron is the man!)
259
+ 0.1.0 - March 31, 2007
260
+ * added d method for creating direct messages (waiting for it to work as documented)
261
+ * added featured method for getting featured users statuses (waiting for it to work as documented)
262
+ * added direct_messages method
263
+ * added friends_for method
264
+ * added a few tests
265
+ * removed relative_created_at as it is deprecated
266
+ * separated out the call method into call, request and parse methods
267
+ 0.0.5 - just a bit of code cleanup
268
+ 0.0.4 - added :location, :description, :url, :profile_image_url to user class (Alex Payne)
269
+ 0.0.3 - added a bit more informative message when things go wrong
270
+ 0.0.2 - added the command line options i forgot to add (friend and follower); improved some docs
271
+ 0.0.1 - initial release
data/License ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2009 John Nunemaker
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/Notes ADDED
@@ -0,0 +1,33 @@
1
+ *****************************************************************
2
+ * From Twitter API Docs, so I don't have to keep going to them. *
3
+ *****************************************************************
4
+
5
+ http://apiwiki.twitter.com/REST+API+Documentation
6
+
7
+ 200 OK: everything went awesome.
8
+ 304 Not Modified: there was no new data to return.
9
+ 400 Bad Request: your request is invalid, and we'll return an error message that tells you why. This is the status code returned if you've exceeded the rate limit (see below).
10
+ 401 Not Authorized: either you need to provide authentication credentials, or the credentials provided aren't valid.
11
+ 403 Forbidden: we understand your request, but are refusing to fulfill it. An accompanying error message should explain why.
12
+ 404 Not Found: either you're requesting an invalid URI or the resource in question doesn't exist (ex: no such user).
13
+ 500 Internal Server Error: we did something wrong. Please post to the group about it and the Twitter team will investigate.
14
+ 502 Bad Gateway: returned if Twitter is down or being upgraded.
15
+ 503 Service Unavailable: the Twitter servers are up, but are overloaded with requests. Try again later.
16
+
17
+ **********
18
+ * Errors *
19
+ **********
20
+
21
+ <?xml version="1.0" encoding="UTF-8"?>
22
+ <hash>
23
+ <request>/direct_messages/destroy/456.xml</request>
24
+ <error>No direct message with that ID found.</error>
25
+ </hash>
26
+
27
+ **********************
28
+ * Rate Limit Headers *
29
+ **********************
30
+
31
+ X-RateLimit-Limit the current limit in effect
32
+ X-RateLimit-Remaining the number of hits remaining before you are rate limited
33
+ X-RateLimit-Reset the time the current rate limiting period ends (in epoch time, number of seconds since 1970-01-01 00:00:00)
data/README.rdoc ADDED
@@ -0,0 +1,19 @@
1
+ = twitter
2
+
3
+ The ruby twitter gem. The gem heard round the world and famous on the streets. Haha. This gem *works with both oauth and http auth*, if you care.
4
+
5
+ For now this is just an API wrapper. The command line interface is temporarily dead until I have time to make it work with oauth. At that point, I'll make it a new gem twitter-cli or something and it will depend on this gem to work. That will keep the separation of the api wrapper and cli and fix a lot of dependency issues.
6
+
7
+ == examples
8
+
9
+ See the examples directory.
10
+
11
+ http://github.com/jnunemaker/twitter/tree/master/examples
12
+
13
+ == docs
14
+
15
+ http://rdoc.info/projects/jnunemaker/twitter
16
+
17
+ == Copyright
18
+
19
+ Copyright (c) 2009 John Nunemaker. See LICENSE for details.
data/Rakefile ADDED
@@ -0,0 +1,39 @@
1
+ require "rake"
2
+ require "jeweler"
3
+
4
+ Jeweler::Tasks.new do |gem|
5
+ gem.name = "secobarbital-twitter"
6
+ gem.summary = %Q{wrapper for the twitter api}
7
+ gem.email = ["nunemaker@gmail.com", "seggy.umboh@gmail.com"]
8
+ gem.homepage = "http://github.com/secobarbital/twitter"
9
+ gem.authors = ["John Nunemaker", "Wynn Netherland", "Seggy Umboh"]
10
+ gem.files = FileList["[A-Z]*", "{examples,lib,test}/**/*"]
11
+
12
+ gem.add_dependency("oauth", "~> 0.3.6")
13
+ gem.add_dependency("hashie", "~> 0.2.0")
14
+ gem.add_dependency("httparty", "~> 0.5.2")
15
+ gem.add_dependency("json", "~> 1.2.3")
16
+
17
+ gem.add_development_dependency("shoulda", "~> 2.10.1")
18
+ gem.add_development_dependency("jnunemaker-matchy", "~> 0.4.0")
19
+ gem.add_development_dependency("mocha", "~> 0.9.4")
20
+ gem.add_development_dependency("fakeweb", "~> 1.2.5")
21
+ end
22
+
23
+ Jeweler::GemcutterTasks.new
24
+
25
+ require "rake/testtask"
26
+ Rake::TestTask.new(:test) do |test|
27
+ test.libs << "test"
28
+ test.ruby_opts << "-rubygems"
29
+ test.pattern = "test/**/*_test.rb"
30
+ test.verbose = true
31
+ end
32
+
33
+ task :default => :test
34
+ task :test => :check_dependencies
35
+
36
+ desc "Upload website files to rubyforge"
37
+ task :website do
38
+ sh %{rsync -av website/ jnunemaker@rubyforge.org:/var/www/gforge-projects/twitter}
39
+ end
data/VERSION.yml ADDED
@@ -0,0 +1,5 @@
1
+ ---
2
+ :major: 0
3
+ :minor: 9
4
+ :build: 1
5
+ :patch: 2
@@ -0,0 +1,30 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+ oauth = Twitter::OAuth.new(config['token'], config['secret'])
7
+
8
+ if config['atoken'] && config['asecret']
9
+ oauth.authorize_from_access(config['atoken'], config['asecret'])
10
+ twitter = Twitter::Base.new(oauth)
11
+ pp twitter.friends_timeline
12
+
13
+ elsif config['rtoken'] && config['rsecret']
14
+ oauth.authorize_from_request(config['rtoken'], config['rsecret'], 'PIN')
15
+ twitter = Twitter::Base.new(oauth)
16
+ pp twitter.friends_timeline
17
+
18
+ config.update({
19
+ 'atoken' => oauth.access_token.token,
20
+ 'asecret' => oauth.access_token.secret,
21
+ }).delete('rtoken', 'rsecret')
22
+ else
23
+ config.update({
24
+ 'rtoken' => oauth.request_token.token,
25
+ 'rsecret' => oauth.request_token.secret,
26
+ })
27
+
28
+ # authorize in browser
29
+ %x(open #{oauth.request_token.authorize_url})
30
+ end
@@ -0,0 +1,13 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+
7
+ oauth = Twitter::OAuth.new(config['token'], config['secret'])
8
+ oauth.authorize_from_access(config['atoken'], config['asecret'])
9
+
10
+ client = Twitter::Base.new(oauth)
11
+
12
+ puts client.friendship_exists?('jnunemaker', 'orderedlist')
13
+ puts client.friendship_exists?('jnunemaker', 'biz')
@@ -0,0 +1,38 @@
1
+ class ConfigStore
2
+ attr_reader :file
3
+
4
+ def initialize(file)
5
+ @file = file
6
+ end
7
+
8
+ def load
9
+ @config ||= YAML::load(open(file))
10
+ self
11
+ end
12
+
13
+ def [](key)
14
+ load
15
+ @config[key]
16
+ end
17
+
18
+ def []=(key, value)
19
+ @config[key] = value
20
+ end
21
+
22
+ def delete(*keys)
23
+ keys.each { |key| @config.delete(key) }
24
+ save
25
+ self
26
+ end
27
+
28
+ def update(c={})
29
+ @config.merge!(c)
30
+ save
31
+ self
32
+ end
33
+
34
+ def save
35
+ File.open(file, 'w') { |f| f.write(YAML.dump(@config)) }
36
+ self
37
+ end
38
+ end
@@ -0,0 +1,11 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+
7
+ httpauth = Twitter::HTTPAuth.new(config['email'], config['password'])
8
+ base = Twitter::Base.new(httpauth)
9
+
10
+ pp base.user_timeline
11
+ pp base.verify_credentials
data/examples/ids.rb ADDED
@@ -0,0 +1,13 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+
7
+ oauth = Twitter::OAuth.new(config['token'], config['secret'])
8
+ oauth.authorize_from_access(config['atoken'], config['asecret'])
9
+
10
+ client = Twitter::Base.new(oauth)
11
+
12
+ puts client.friend_ids
13
+ puts client.follower_ids
data/examples/lists.rb ADDED
@@ -0,0 +1,11 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+
7
+ httpauth = Twitter::HTTPAuth.new(config['email'], config['password'])
8
+ base = Twitter::Base.new(httpauth)
9
+
10
+ pp base.lists('pengwynn')
11
+ pp base.list_members('pengwynn', 'rubyists')
data/examples/oauth.rb ADDED
@@ -0,0 +1,27 @@
1
+ require 'pp'
2
+ require 'pathname'
3
+ dir = Pathname(__FILE__).dirname.expand_path
4
+ require (dir + '..' + 'lib' + 'twitter').expand_path
5
+ require dir + 'helpers' + 'config_store'
6
+
7
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
8
+ oauth = Twitter::OAuth.new(config['token'], config['secret'])
9
+ rtoken = oauth.request_token.token
10
+ rsecret = oauth.request_token.secret
11
+
12
+ puts "> redirecting you to twitter to authorize..."
13
+ %x(open #{oauth.request_token.authorize_url})
14
+
15
+ print "> what was the PIN twitter provided you with? "
16
+ pin = gets.chomp
17
+
18
+ begin
19
+ oauth.authorize_from_request(rtoken, rsecret, pin)
20
+
21
+ twitter = Twitter::Base.new(oauth)
22
+ twitter.user_timeline.each do |tweet|
23
+ puts "#{tweet.user.screen_name}: #{tweet.text}"
24
+ end
25
+ rescue OAuth::Unauthorized
26
+ puts "> FAIL!"
27
+ end
@@ -0,0 +1,15 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require 'pp'
3
+
4
+ search = Twitter::Search.new.from('jnunemaker')
5
+
6
+ puts '*'*50, 'First Run', '*'*50
7
+ search.each { |result| pp result }
8
+
9
+ puts '*'*50, 'Second Run', '*'*50
10
+ search.each { |result| pp result }
11
+
12
+ puts '*'*50, 'Parameter Check', '*'*50
13
+ pp Twitter::Search.new('#austineats').fetch().results.first
14
+ pp Twitter::Search.new('#austineats').page(2).fetch().results.first
15
+ pp Twitter::Search.new('#austineats').since(1412737343).fetch().results.first
@@ -0,0 +1,19 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+
7
+ oauth = Twitter::OAuth.new(config['token'], config['secret'])
8
+ oauth.authorize_from_access(config['atoken'], config['asecret'])
9
+
10
+ client = Twitter::Base.new(oauth)
11
+
12
+ pp client.friends_timeline
13
+ puts '*'*50
14
+
15
+ pp client.user_timeline
16
+ puts '*'*50
17
+
18
+ pp client.replies
19
+ puts '*'*50
@@ -0,0 +1,9 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require 'pp'
3
+
4
+
5
+ httpauth = Twitter::HTTPAuth.new('email', 'password', :api_endpoint => 'tumblr.com')
6
+ base = Twitter::Base.new(httpauth)
7
+
8
+ pp base.user_timeline
9
+ pp base.verify_credentials
@@ -0,0 +1,16 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require 'pp'
3
+
4
+ puts 'User', '*'*50
5
+ pp Twitter.user('jnunemaker')
6
+ pp Twitter.user('snitch_test')
7
+
8
+ puts 'Status', '*'*50
9
+ pp Twitter.status(1533815199)
10
+
11
+ puts 'Friend Ids', '*'*50
12
+ pp Twitter.friend_ids('jnunemaker')
13
+
14
+ puts 'Follower Ids', '*'*50
15
+ pp Twitter.follower_ids('jnunemaker')
16
+
@@ -0,0 +1,11 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require File.join(File.dirname(__FILE__), 'helpers', 'config_store')
3
+ require 'pp'
4
+
5
+ config = ConfigStore.new("#{ENV['HOME']}/.twitter")
6
+
7
+ oauth = Twitter::OAuth.new(config['token'], config['secret'])
8
+ oauth.authorize_from_access(config['atoken'], config['asecret'])
9
+
10
+ client = Twitter::Base.new(oauth)
11
+ pp client.update('This is an update from the twitter gem')
data/examples/user.rb ADDED
@@ -0,0 +1,5 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'lib', 'twitter')
2
+ require 'pp'
3
+
4
+ pp Twitter.user('jnunemaker')
5
+ pp Twitter.user('snitch_test')