bkocik-twitter 0.6.8

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