deedubs-twitter 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. data/History +206 -0
  2. data/License +20 -0
  3. data/Notes +33 -0
  4. data/README.rdoc +19 -0
  5. data/Rakefile +103 -0
  6. data/VERSION.yml +4 -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/search.rb +15 -0
  13. data/examples/timeline.rb +19 -0
  14. data/examples/unauthorized.rb +16 -0
  15. data/examples/update.rb +11 -0
  16. data/examples/user.rb +5 -0
  17. data/lib/twitter/base.rb +165 -0
  18. data/lib/twitter/httpauth.rb +27 -0
  19. data/lib/twitter/oauth.rb +41 -0
  20. data/lib/twitter/request.rb +102 -0
  21. data/lib/twitter/search.rb +106 -0
  22. data/lib/twitter/trends.rb +29 -0
  23. data/lib/twitter.rb +63 -0
  24. data/test/fixtures/firehose.json +1 -0
  25. data/test/fixtures/follower_ids.json +1 -0
  26. data/test/fixtures/friend_ids.json +1 -0
  27. data/test/fixtures/friends_timeline.json +1 -0
  28. data/test/fixtures/rate_limit_exceeded.json +1 -0
  29. data/test/fixtures/replies.json +1 -0
  30. data/test/fixtures/search.json +1 -0
  31. data/test/fixtures/search_from_jnunemaker.json +1 -0
  32. data/test/fixtures/status.json +1 -0
  33. data/test/fixtures/status_show.json +1 -0
  34. data/test/fixtures/trends_current.json +1 -0
  35. data/test/fixtures/trends_current_exclude.json +1 -0
  36. data/test/fixtures/trends_daily.json +1 -0
  37. data/test/fixtures/trends_daily_date.json +1 -0
  38. data/test/fixtures/trends_daily_exclude.json +1 -0
  39. data/test/fixtures/trends_weekly.json +1 -0
  40. data/test/fixtures/trends_weekly_date.json +1 -0
  41. data/test/fixtures/trends_weekly_exclude.json +1 -0
  42. data/test/fixtures/user.json +1 -0
  43. data/test/fixtures/user_timeline.json +1 -0
  44. data/test/test_helper.rb +36 -0
  45. data/test/twitter/base_test.rb +95 -0
  46. data/test/twitter/httpauth_test.rb +76 -0
  47. data/test/twitter/oauth_test.rb +81 -0
  48. data/test/twitter/request_test.rb +217 -0
  49. data/test/twitter/search_test.rb +144 -0
  50. data/test/twitter/trends_test.rb +95 -0
  51. data/test/twitter_test.rb +38 -0
  52. metadata +200 -0
data/History ADDED
@@ -0,0 +1,206 @@
1
+ 0.6.11 - May 18, 2009
2
+ * 1 minor addition
3
+ * Added the ability to sign in with twitter instead of authorizing
4
+
5
+ 0.6.10 - May 18, 2009
6
+ * 1 cool addition
7
+ * Added full support for trends - current, daily and weekly (even allowing excluding of hashtags and for specific dates)
8
+
9
+ 0.6.9 - May 17, 2009
10
+ * 1 minor tweak
11
+ * Bumped oauth dependency version to 0.3.4.
12
+
13
+ 0.6.8 - April 23, 2009
14
+ * 1 dependency fix
15
+ * forgot to update rakefile rendering previous 0.6.7 release useless. crap!
16
+
17
+ 0.6.7 - April 23, 2009
18
+ * 1 minor fix
19
+ * 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
20
+
21
+ 0.6.6 - April 16, 2009
22
+ * 1 minor enhancement
23
+ * added ability to pass query parameters to user method
24
+ * httpauth can now accept :ssl option to use https instead of http
25
+ * Added Twitter.status method for no auth calls to fetch status
26
+ * Added Twitter.friend_ids method for no auth calls to fetch status
27
+ * Added Twitter.follower_ids method for no auth calls to fetch status
28
+
29
+ 0.6.5 - April 15, 2009
30
+ * 1 bug fix
31
+ * 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
32
+
33
+ 0.6.4 - April 14, 2009
34
+ * 1 minor tweak
35
+ * More explicit about dependency versions in gemspec and when requiring.
36
+
37
+ 0.6.3 - April 14, 2009
38
+ * 1 minor addition
39
+ * Added Twitter.user method to get user's information without authenticating
40
+
41
+ 0.6.2 - April 14, 2009
42
+ * 1 minor addition
43
+ * added max to search so you can set the max id that should be used
44
+
45
+ 0.6.1 - April 12, 2009
46
+ * 1 minor fix
47
+ * Had two friend_ids functions. Renamed one of them to follower_ids.
48
+
49
+ 0.6.0 - April 11, 2009
50
+ * 1 feature addition
51
+ * Added http authentication back in. You can now use oauth or http auth as your client.
52
+
53
+ 0.5.3 - April 10, 2009
54
+ * 1 minor fix
55
+ * 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.
56
+
57
+ 0.5.2 - April 8, 2009
58
+ * 4 minor fixes
59
+ * added mash as an install dependency, forgot it initially
60
+ * fixed that search wasn't taking into account a bunch of options duh!
61
+ * fixed some missing vars and stuff in exception raising
62
+ * added development dependencies to rake file to make that more explicit (technomancy)
63
+ * lame workaround for Mash#hash that allows using return objects in sets and such (technomancy)
64
+
65
+ 0.5.1 - April 5, 2009
66
+ * 1 minor change
67
+ * Added data error hash returned from twitter to a few of the exceptions to help with debugging
68
+ * Fixed friendship_exists?. Was throwing mash stringify keys error because it was returning true or false instead of hash or array.
69
+
70
+ 0.5.0 - April 3, 2009
71
+ * 1 major rewrite for OAuth
72
+ * Backwards compatibility thrown to the wind
73
+ * Proxy no longer supported (someone please add it back in, I never use proxies)
74
+ * Identica support killed with an axe (nothing against them but I don't use it)
75
+ * CLI shot to death (will be reborn at a later date using oauth and its own gem)
76
+
77
+ 0.4.3 - February 21, 2009
78
+ * 1 minor enhancement
79
+ * verify_credentials now returns a Twitter::User rather than an hpricot doc
80
+
81
+ 0.4.2 - February 10, 2009
82
+ * 1 minor enhancement
83
+ * Adding the Social Graph API methods (Josh Owens)
84
+
85
+ 0.4.1 - January 1, 2009
86
+ * 4 minor enhancements and 2 bug fixes:
87
+ * Added better exception handling (Billy Gray)
88
+ * Added page to search (Michael Ivey)
89
+ * Adding an option to display tweets on CLI in reverse order (oldest first). (Cameron Booth)
90
+ * Added in_reply_to_status_id option for replying to statuses (anthonycrumley)
91
+ * Fixed a bug where the @config was improperly set (K. Adam Christensen)
92
+ * Fix verify_credentials to include a format (breaks in laconica). (dustin)
93
+
94
+ 0.4.0 - December 23, 2008
95
+ * 3 major changes
96
+ * Removed active support as dependency
97
+ * Removed CLI dependencies from install dependency list
98
+ (they are now only installed by you manually)
99
+ * Switched to echoe for gem managment
100
+
101
+ 0.3.7 - August 26, 2008
102
+ * Fixed source param not getting through
103
+
104
+ 0.3.6 - August 11, 2008
105
+ * Fixed a few more methods that required post.
106
+ * Refactored the remaining methods that were not using #request to use it.
107
+
108
+ 0.3.5 - August 4, 2008
109
+ * Removed sqlite-ruby 1.2.2 as a dependency due to install issues on linux
110
+
111
+ 0.3.4 - August 3, 2008
112
+ * Added search support
113
+
114
+ 0.3.3 - August 3, 2008
115
+ * Now has option for host when initializing to support identi.ca (Dustin Sallings)
116
+ * Twitter changed a bunch of methods to POST only so I updated those to now work
117
+
118
+ 0.3.2 - July 26, 2008
119
+ * added the CLI gems as dependencies for now until I separate out the CLI from the API wrapper
120
+ * cleaner CLI errors for no active account or no accounts at all
121
+ * remove sets a new active account if there are none
122
+ * added username and password optional arguments to add
123
+ * added import attempt on install and on anything that uses #current_account helper
124
+
125
+ 0.3.1 - July 23, 2008
126
+ * added open to CLI twitter open jnunemaker would open default browser to http://twitter.com/jnunemaker
127
+ * added -f to timeline and replies which ignores the since_id and shows all results
128
+ * added clear_config to remove all cached since id's and such
129
+ * Majorly pimped the output of timelines and replies.
130
+
131
+ 0.3.0 - July 22, 2008
132
+ * complete rewrite of CLI. Now supports multiple accounts and changing between them.
133
+ * added source, truncated, in_reply_to_status_id, in_reply_to_user_id, and favorited to Twitter::Status
134
+ * added protected to Twitter::User
135
+ * d CLI method now takes standard input like post
136
+ * Rewrote several methods that had since parameter to now use a hash instead. This makes it more flexible as API updates.
137
+ * Rewrote the methods that took lite or since as an argument to instead take a hash.
138
+ * added Twitter::Base#friendship_exists?
139
+ * added Twitter::Base#update_location
140
+ * added Twitter::Base#update_delivery_device
141
+ * added Twitter::Base#favorites
142
+ * added Twitter::Base#create_favorite
143
+ * added Twitter::Base#destroy_favorite
144
+ * added Twitter::Base#block
145
+ * added Twitter::Base#unblock
146
+
147
+ BACKWORDS COMPATIBILITY BREAK:
148
+ Any method that you have using lite or since as an argument
149
+ will no longer work with this version. Simply change to a
150
+ hash and you'll be fine. For example:
151
+
152
+ friends(true) would now be friends(:lite => true)
153
+
154
+ 0.2.7 - June 29, 2008
155
+ * added #rate_limit_status (Daniel Morrison)
156
+ * added source parameter option to Base#post
157
+ * added twittergem as source when posting from command line
158
+ * Twitter::RateExceeded raised when you hit your limit (Jim O'Leary)
159
+ * Twitter::Unavailable raised when twitter returns 503
160
+ * Twitter::CantConnect is now more descriptive as to what is the problem when it is raised during a request
161
+ * quoting your message when using twitter post on the command line is now optional (Benoit Caccinolo)
162
+ * aliased post to p on command line so it's shorter (Benoit Caccinolo)
163
+ * unescaped html and added some color in command line view (Miles Z. Sterrett)
164
+ * added gemspec (technoweenie, Miles Z. Sterrett)
165
+ * Fixed stack trace error on first command line operation (Matt Rose)
166
+ 0.2.6 - April 2, 2008
167
+ * found a more simple way of doing stdin without any extra gem dependencies
168
+ 0.2.5 - April 2, 2008
169
+ * Command line interface can now use stdin for posting (ideas and example code from Jeremy Friesen)
170
+ $ twitter post 'test without stdin' # => twitters: test without stdin
171
+ $ echo 'test with stdin' | twitter post 'and an argv[1]' # => twitters: test with stdin and an argv[1]
172
+ $ echo 'test with stdin without any argv[1]' | twitter post # => twitters: test with stdin without any argv[1]
173
+ 0.2.4 - Mar 31, 2008
174
+ * Added lite option to friends and followers, which doesn't include the user's current status (Daniel Morrison)
175
+ * Updated since option to use HTTP header, and added the option on timeline() and replies(). (Daniel Morrison)
176
+ 0.2.3 - Jan 16, 2008
177
+ * added d to command line interface twitter d jnunemaker 'hola' (Humbucker)
178
+ * added progress dots when posting for confirmation when twitter is running slow (Hendy Irawan)
179
+ 0.2.2 - added leave and follow which are new twitter api methods for turning notifications on and off
180
+ 0.2.0 - Aug 4, 2007
181
+ * added sent_messages
182
+ * alias direct_messages to received_messages
183
+ * added create_friendship
184
+ * added destroy_friendship
185
+ * added featured to retrieve the featured twitter users
186
+ * added replies
187
+ * added destroy to destroy a status by id
188
+ * added status to find a status by id
189
+ * added active support as an extra dependency
190
+ * implemented d method to send direct messages (jnewland)
191
+ * fixed since argument in direct_messages method (jnewland)
192
+ 0.1.1 - May 20, 2007
193
+ * hpricot 0.5+ now supported; just a bug fix (Ryan Waldron is the man!)
194
+ 0.1.0 - March 31, 2007
195
+ * added d method for creating direct messages (waiting for it to work as documented)
196
+ * added featured method for getting featured users statuses (waiting for it to work as documented)
197
+ * added direct_messages method
198
+ * added friends_for method
199
+ * added a few tests
200
+ * removed relative_created_at as it is deprecated
201
+ * separated out the call method into call, request and parse methods
202
+ 0.0.5 - just a bit of code cleanup
203
+ 0.0.4 - added :location, :description, :url, :profile_image_url to user class (Alex Payne)
204
+ 0.0.3 - added a bit more informative message when things go wrong
205
+ 0.0.2 - added the command line options i forgot to add (friend and follower); improved some docs
206
+ 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,103 @@
1
+ require 'rubygems'
2
+ require 'rake'
3
+
4
+ begin
5
+ require 'jeweler'
6
+ Jeweler::Tasks.new do |gem|
7
+ gem.name = "twitter"
8
+ gem.summary = %Q{wrapper for the twitter api (oauth only) [Remixed to use Mhash]}
9
+ gem.email = "dan.williams@itthugs.com"
10
+ gem.homepage = "http://github.com/deeedubs/twitter"
11
+ gem.authors = ["John Nunemaker","Dan Williams"]
12
+ gem.rubyforge_project = "twitter"
13
+ gem.files = FileList["[A-Z]*", "{examples,lib,test}/**/*"]
14
+
15
+ gem.add_dependency('oauth', '0.3.4')
16
+ gem.add_dependency('peterpunk-mhash', '0.0.8')
17
+ gem.add_dependency('httparty', '0.4.3')
18
+
19
+ gem.add_development_dependency('thoughtbot-shoulda')
20
+ gem.add_development_dependency('jeremymcanally-matchy')
21
+ gem.add_development_dependency('mocha')
22
+ gem.add_development_dependency('fakeweb')
23
+ gem.add_development_dependency('peterpunk-mhash')
24
+ end
25
+ rescue LoadError
26
+ puts "Jeweler not available. Install it with: sudo gem install technicalpickles-jeweler -s http://gems.github.com"
27
+ end
28
+
29
+ require 'rake/testtask'
30
+ Rake::TestTask.new(:test) do |test|
31
+ test.libs << 'lib' << 'test'
32
+ test.pattern = 'test/**/*_test.rb'
33
+ test.verbose = false
34
+ end
35
+
36
+ begin
37
+ require 'rcov/rcovtask'
38
+ Rcov::RcovTask.new do |test|
39
+ test.libs << 'test'
40
+ test.pattern = 'test/**/*_test.rb'
41
+ test.verbose = true
42
+ end
43
+ rescue LoadError
44
+ task :rcov do
45
+ abort "RCov is not available. In order to run rcov, you must: sudo gem install spicycode-rcov"
46
+ end
47
+ end
48
+
49
+
50
+ task :default => :test
51
+
52
+ require 'rake/rdoctask'
53
+ Rake::RDocTask.new do |rdoc|
54
+ if File.exist?('VERSION.yml')
55
+ config = YAML.load(File.read('VERSION.yml'))
56
+ version = "#{config[:major]}.#{config[:minor]}.#{config[:patch]}"
57
+ else
58
+ version = ""
59
+ end
60
+
61
+ rdoc.rdoc_dir = 'rdoc'
62
+ rdoc.title = "twitter #{version}"
63
+ rdoc.rdoc_files.include('README*')
64
+ rdoc.rdoc_files.include('lib/**/*.rb')
65
+ end
66
+
67
+ begin
68
+ require 'rake/contrib/sshpublisher'
69
+ namespace :rubyforge do
70
+
71
+ desc "Release gem and RDoc documentation to RubyForge"
72
+ task :release => ["rubyforge:release:gem", "rubyforge:release:website", "rubyforge:release:docs"]
73
+
74
+ namespace :release do
75
+ desc "Publish RDoc to RubyForge."
76
+ task :docs => [:rdoc] do
77
+ config = YAML.load(
78
+ File.read(File.expand_path('~/.rubyforge/user-config.yml'))
79
+ )
80
+
81
+ host = "#{config['username']}@rubyforge.org"
82
+ remote_dir = "/var/www/gforge-projects/twitter/rdoc"
83
+ local_dir = 'rdoc'
84
+
85
+ Rake::SshDirPublisher.new(host, remote_dir, local_dir).upload
86
+ end
87
+
88
+ task :website do
89
+ config = YAML.load(
90
+ File.read(File.expand_path('~/.rubyforge/user-config.yml'))
91
+ )
92
+
93
+ host = "#{config['username']}@rubyforge.org"
94
+ remote_dir = "/var/www/gforge-projects/twitter/"
95
+ local_dir = 'website'
96
+
97
+ Rake::SshDirPublisher.new(host, remote_dir, local_dir).upload
98
+ end
99
+ end
100
+ end
101
+ rescue LoadError
102
+ puts "Rake SshDirPublisher is unavailable or your rubyforge environment is not configured."
103
+ end
data/VERSION.yml ADDED
@@ -0,0 +1,4 @@
1
+ ---
2
+ :major: 0
3
+ :minor: 7
4
+ :patch: 0
@@ -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'])
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
@@ -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,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')