sinatra-twitter-oauth 0.0.1

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.
data/.document ADDED
@@ -0,0 +1,5 @@
1
+ README.rdoc
2
+ lib/**/*.rb
3
+ bin/*
4
+ features/**/*.feature
5
+ LICENSE
data/.gitignore ADDED
@@ -0,0 +1,21 @@
1
+ ## MAC OS
2
+ .DS_Store
3
+
4
+ ## TEXTMATE
5
+ *.tmproj
6
+ tmtags
7
+
8
+ ## EMACS
9
+ *~
10
+ \#*
11
+ .\#*
12
+
13
+ ## VIM
14
+ *.swp
15
+
16
+ ## PROJECT::GENERAL
17
+ coverage
18
+ rdoc
19
+ pkg
20
+
21
+ ## PROJECT::SPECIFIC
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2009 Nick Howard
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/README.rdoc ADDED
@@ -0,0 +1,42 @@
1
+ = sinatra-twitter-oauth
2
+
3
+ A simple sinatra extension for using twitter oauth for login
4
+
5
+
6
+ == Examples
7
+ === classic style
8
+ require 'sinatra'
9
+ require 'sinatra-twitter-oauth'
10
+
11
+ set :twitter_oauth_config, :key => 'foo-key',
12
+ :secret => 'foo-secret',
13
+ :callback => 'example.com/foo/auth'
14
+ get '/' do
15
+ login_required
16
+ end
17
+ === using Sinatra::Base
18
+
19
+ require 'sinatra'
20
+ require 'sinatra-twitter-oauth'
21
+ class FooApp < Sinatra::Base
22
+ register Sinatra::TwitterOAuth
23
+ set :twitter_oauth_config, :key => 'foo-key',
24
+ :secret => 'foo-secret',
25
+ :callback => 'example.com/foo/auth'
26
+ get '/' do
27
+ login_required
28
+ end
29
+ end
30
+ == Note on Patches/Pull Requests
31
+
32
+ * Fork the project.
33
+ * Make your feature addition or bug fix.
34
+ * Add tests for it. This is important so I don't break it in a
35
+ future version unintentionally.
36
+ * Commit, do not mess with rakefile, version, or history.
37
+ (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)
38
+ * Send me a pull request. Bonus points for topic branches.
39
+
40
+ == Copyright
41
+
42
+ Copyright (c) 2010 Nick Howard. See LICENSE for details.
data/Rakefile ADDED
@@ -0,0 +1,45 @@
1
+ require 'rubygems'
2
+ require 'rake'
3
+
4
+ begin
5
+ require 'jeweler'
6
+ Jeweler::Tasks.new do |gem|
7
+ gem.name = "sinatra-twitter-oauth"
8
+ gem.summary = %Q{A Sinatra Extension that simplifies using twitter for login and authentication.}
9
+ gem.description = %Q{A Sinatra Extension that simplifies using twitter for login and authentication.}
10
+ gem.email = "ndh@baroquebobcat.com"
11
+ gem.homepage = "http://github.com/baroquebobcat/sinatra-twitter-oauth"
12
+ gem.authors = ["Nick Howard"]
13
+ gem.add_development_dependency "rspec", ">= 1.2.9"
14
+ # gem is a Gem::Specification... see http://www.rubygems.org/read/chapter/20 for additional settings
15
+ end
16
+ Jeweler::GemcutterTasks.new
17
+ rescue LoadError
18
+ puts "Jeweler (or a dependency) not available. Install it with: gem install jeweler"
19
+ end
20
+
21
+ require 'spec/rake/spectask'
22
+ Spec::Rake::SpecTask.new(:spec) do |spec|
23
+ spec.libs << 'lib' << 'spec'
24
+ spec.spec_files = FileList['spec/**/*_spec.rb']
25
+ end
26
+
27
+ Spec::Rake::SpecTask.new(:rcov) do |spec|
28
+ spec.libs << 'lib' << 'spec'
29
+ spec.pattern = 'spec/**/*_spec.rb'
30
+ spec.rcov = true
31
+ end
32
+
33
+ task :spec => :check_dependencies
34
+
35
+ task :default => :spec
36
+
37
+ require 'rake/rdoctask'
38
+ Rake::RDocTask.new do |rdoc|
39
+ version = File.exist?('VERSION') ? File.read('VERSION') : ""
40
+
41
+ rdoc.rdoc_dir = 'rdoc'
42
+ rdoc.title = "sinatra-twitter-oauth #{version}"
43
+ rdoc.rdoc_files.include('README*')
44
+ rdoc.rdoc_files.include('lib/**/*.rb')
45
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.0.1
@@ -0,0 +1,70 @@
1
+ require 'sinatra/base'
2
+ require 'twitter_oauth'
3
+
4
+ require 'sinatra-twitter-oauth/twitter_oauth_ext'
5
+ require 'sinatra-twitter-oauth/helpers'
6
+ #Sinatra::TwitterOAuth
7
+ #
8
+ # A sinatra extension that abstracts away most of
9
+ # using twitter oauth for login
10
+ #
11
+ #twitter_oauth_config
12
+ #options
13
+ # key -- oauth consumer key
14
+ # secret -- oauth consumer secret
15
+ # callback -- oauth callback url. Must be absolute. e.g. http://example.com/auth
16
+ # login_template -- a single entry hash with the engine as the key e.g. :login_template => {:haml => :login}
17
+ module Sinatra
18
+ module TwitterOAuth
19
+
20
+ DEFAULT_CONFIG = {
21
+ :key => 'changeme',
22
+ :secret => 'changeme',
23
+ :callback => 'changeme',
24
+ :login_template => {:text=>'<a href="/connect">Login using Twitter</a>'}
25
+ }
26
+
27
+ def self.registered app
28
+
29
+ app.helpers Helpers
30
+ app.enable :sessions
31
+ app.set :twitter_oauth_config, DEFAULT_CONFIG
32
+
33
+ app.get '/login' do
34
+ redirect '/' if @user
35
+
36
+ login_template = options.twitter_oauth_config[:login_template]
37
+
38
+ engine = login_template.keys.first
39
+
40
+ case engine
41
+ when :text
42
+ login_template[:text]
43
+ else
44
+ render engine, login_template[engine]
45
+ end
46
+ end
47
+
48
+ app.get '/connect' do
49
+ redirect_to_twitter_auth_url
50
+ end
51
+
52
+ app.get '/auth' do
53
+ if authenticate!
54
+ redirect '/'
55
+ else
56
+ status 403
57
+ 'Not Authenticated'
58
+ end
59
+ end
60
+
61
+ app.get '/logout' do
62
+ clear_oauth_session
63
+ redirect '/login'
64
+ end
65
+ end
66
+
67
+ end
68
+
69
+ register TwitterOAuth
70
+ end
@@ -0,0 +1,78 @@
1
+ module Sinatra::TwitterOAuth
2
+ module Helpers
3
+
4
+ def login_required
5
+ setup_client
6
+
7
+ @user = ::TwitterOAuth::User.new(@client, session[:user]) if session[:user]
8
+
9
+ @rate_limit_status = @client.rate_limit_status
10
+
11
+ redirect '/login' unless @user
12
+ end
13
+
14
+ def setup_client
15
+ @client ||= ::TwitterOAuth::Client.new(
16
+ :consumer_secret => options.twitter_oauth_config[:secret],
17
+ :consumer_key => options.twitter_oauth_config[:key],
18
+ :token => session[:access_token],
19
+ :secret => session[:secret_token]
20
+ )
21
+ end
22
+
23
+ def get_request_token
24
+ setup_client
25
+
26
+ begin
27
+ @client.authentication_request_token(:oauth_callback=>options.twitter_oauth_config[:callback])
28
+ rescue StandardError => e
29
+ halt 500,'check your key & secret'
30
+ end
31
+ end
32
+
33
+ def get_access_token
34
+ setup_client
35
+
36
+ begin
37
+ @client.authorize(
38
+ session[:request_token],
39
+ session[:request_token_secret],
40
+ :oauth_verifier => params[:oauth_verifier]
41
+ )
42
+ rescue OAuth::Unauthorized => e
43
+ nil
44
+ end
45
+ end
46
+
47
+ def redirect_to_twitter_auth_url
48
+ request_token = get_request_token
49
+
50
+ session[:request_token] = request_token.token
51
+ session[:request_token_secret]= request_token.secret
52
+
53
+ redirect request_token.authorize_url.gsub('authorize','authenticate')
54
+ end
55
+
56
+ def authenticate!
57
+ access_token = get_access_token
58
+
59
+ if @client.authorized?
60
+ session[:access_token] = access_token.token
61
+ session[:secret_token] = access_token.secret
62
+ session[:user] = @client.info
63
+
64
+ session[:user]
65
+ else
66
+ nil
67
+ end
68
+ end
69
+
70
+ def clear_oauth_session
71
+ session[:user] = nil
72
+ session[:request_token] = nil
73
+ session[:request_token_secret] = nil
74
+ session[:access_token] = nil
75
+ session[:secret_token] = nil
76
+ end
77
+ end
78
+ end
@@ -0,0 +1,79 @@
1
+
2
+ #
3
+ # Some additional domain model classes for twitter oauth.
4
+ #
5
+ module TwitterOAuth
6
+
7
+ class User
8
+ attr_accessor :client,:info
9
+
10
+ def initialize client,info
11
+ self.client = client
12
+ self.info = info
13
+ end
14
+
15
+ def lists
16
+ client.get_lists(screen_name)['lists'].map {|list| List.new client, list}
17
+ end
18
+
19
+ def list list_name
20
+ List.new client, client.get_list(screen_name, list_name)
21
+ end
22
+
23
+ def new_list list_name,options={}
24
+ List.new client, client.create_list(screen_name, list_name, options)
25
+ end
26
+
27
+ def destroy_list list_name
28
+ client.delete_list screen_name, list_name
29
+ end
30
+
31
+ def method_missing method, *args
32
+ info[method.to_s]
33
+ end
34
+ end
35
+
36
+
37
+ class List
38
+
39
+ attr_accessor :client,:info
40
+
41
+ #params:
42
+ # client: instance of TwitterOAuth::Client
43
+ # info: the result of client.get_list
44
+ def initialize client,info
45
+ self.info = info
46
+ self.client = client
47
+ end
48
+
49
+ def add_member screen_name
50
+ client.add_member_to_list user['screen_name'],slug, client.show(screen_name)["id"]
51
+ end
52
+
53
+ def add_members screen_names
54
+ screen_names.each {|name| add_member name }
55
+ end
56
+
57
+ def remove_member screen_name
58
+ client.remove_member_from_list user['screen_name'],slug, client.show(screen_name)["id"]
59
+ end
60
+
61
+ def remove_members screen_names
62
+ screen_names.each {|name| remove_member name }
63
+ end
64
+
65
+ def members
66
+ client.list_members(user['screen_name'], slug)['users'].map{|user| User.new(client,user)}
67
+ end
68
+
69
+ def private?
70
+ mode == 'private'
71
+ end
72
+
73
+ def method_missing method, *args
74
+ info[method.to_s]
75
+ end
76
+
77
+ end
78
+ end
79
+
@@ -0,0 +1,56 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run the gemspec command
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = %q{sinatra-twitter-oauth}
8
+ s.version = "0.0.1"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Nick Howard"]
12
+ s.date = %q{2010-03-11}
13
+ s.description = %q{A Sinatra Extension that simplifies using twitter for login and authentication.}
14
+ s.email = %q{ndh@baroquebobcat.com}
15
+ s.extra_rdoc_files = [
16
+ "LICENSE",
17
+ "README.rdoc"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ ".gitignore",
22
+ "LICENSE",
23
+ "README.rdoc",
24
+ "Rakefile",
25
+ "VERSION",
26
+ "lib/sinatra-twitter-oauth.rb",
27
+ "lib/sinatra-twitter-oauth/helpers.rb",
28
+ "lib/sinatra-twitter-oauth/twitter_oauth_ext.rb",
29
+ "sinatra-twitter-oauth.gemspec",
30
+ "spec/sinatra-twitter-oauth_spec.rb",
31
+ "spec/spec_helper.rb"
32
+ ]
33
+ s.homepage = %q{http://github.com/baroquebobcat/sinatra-twitter-oauth}
34
+ s.rdoc_options = ["--charset=UTF-8"]
35
+ s.require_paths = ["lib"]
36
+ s.rubygems_version = %q{1.3.5}
37
+ s.summary = %q{A Sinatra Extension that simplifies using twitter for login and authentication.}
38
+ s.test_files = [
39
+ "spec/spec_helper.rb",
40
+ "spec/sinatra-twitter-oauth_spec.rb"
41
+ ]
42
+
43
+ if s.respond_to? :specification_version then
44
+ current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
45
+ s.specification_version = 3
46
+
47
+ if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
48
+ s.add_development_dependency(%q<rspec>, [">= 1.2.9"])
49
+ else
50
+ s.add_dependency(%q<rspec>, [">= 1.2.9"])
51
+ end
52
+ else
53
+ s.add_dependency(%q<rspec>, [">= 1.2.9"])
54
+ end
55
+ end
56
+
@@ -0,0 +1,99 @@
1
+ require 'spec_helper'
2
+
3
+ class TestApp < Sinatra::Base
4
+ register Sinatra::TwitterOAuth
5
+
6
+ get '/' do
7
+ login_required
8
+ 'hello world'
9
+ end
10
+ end
11
+
12
+ describe Sinatra::TwitterOAuth do
13
+
14
+ def app
15
+ TestApp
16
+ end
17
+
18
+ before do
19
+ @client=mock('client',
20
+ :rate_limit_status=>{
21
+ "remaining_hits"=>150,
22
+ "hourly_limit"=>150,
23
+ "reset_time_in_seconds"=>0,
24
+ "reset_time"=>"Sat Jan 01 00:00:00 UTC 2000"
25
+ })
26
+ TwitterOAuth::Client.stub!(:new).and_return(
27
+ @client=mock('client',
28
+ :rate_limit_status=>{"remaining_hits"=>150,"hourly_limit"=>150,"reset_time_in_seconds"=>0,"reset_time"=>"Sat Jan 01 00:00:00 UTC 2000"}))
29
+
30
+ TwitterOAuth::User.stub!(:new).and_return(@user = mock('user'))
31
+
32
+ @authed_session = {'rack.session'=>{:user => {'screen_name'=>'tester'}}}
33
+ end
34
+
35
+ describe 'protected by login_required' do
36
+ it 'redirects to /login when unauthenticated' do
37
+ get '/'
38
+ last_response.should be_redirect
39
+ last_response.location.should == '/login'
40
+ end
41
+
42
+ it 'lets you through if you are authed' do
43
+ @user.stub!(:lists).and_return [mock('list',:null_object=>true)]
44
+ get '/',{},@authed_session
45
+ last_response.location.should be_nil
46
+ last_response.should be_ok
47
+ end
48
+ end
49
+
50
+ describe 'GET /login' do
51
+ it 'is never redirected' do
52
+ get '/login'
53
+ last_response.location.should be_nil
54
+ last_response.should be_ok
55
+ end
56
+ end
57
+
58
+
59
+ describe 'GET /connect' do
60
+ it 'gets a request token' do
61
+ @client.should_receive(:authentication_request_token).and_return(mock('request token',:authorize_url=>'http://example.com',:token=>'token',:secret=>'secret'))
62
+ get '/connect'
63
+ end
64
+ it "redirects to the request token's auth url" do
65
+ @client.stub!(:authentication_request_token).and_return(token = mock('request token',:token=>'token',:secret=>'secret'))
66
+ token.should_receive(:authorize_url).and_return 'http://example.com'
67
+ get '/connect'
68
+ last_response.location.should == 'http://example.com'
69
+ end
70
+ end
71
+
72
+ describe 'GET /auth' do
73
+ describe "on auth denied" do
74
+ it "responds with 'Not Authenticated' and a 403" do
75
+ @client.stub!(:authorize).and_raise OAuth::Unauthorized.new
76
+ @client.stub!(:authorized?).and_return false
77
+ get '/auth'
78
+ last_response.status.should == 403
79
+ last_response.body.should == 'Not Authenticated'
80
+ end
81
+ end
82
+ describe 'on auth success' do
83
+ it "redirects to '/'" do
84
+ @client.stub!(:authorize).and_return(mock('access token',:null_object => true))
85
+ @client.stub!(:authorized?).and_return true
86
+ @client.stub!(:info).and_return(mock(:user))
87
+ get '/auth'
88
+ last_response.location.should == '/'
89
+ end
90
+ end
91
+ end
92
+
93
+ describe "GET /logout" do
94
+ it "redirects to /login" do
95
+ get '/logout',{},@authed_session
96
+ last_response.location.should == '/login'
97
+ end
98
+ end
99
+ end
@@ -0,0 +1,10 @@
1
+ ENV['RACK_ENV'] = 'test'
2
+ require 'rubygems'
3
+
4
+ require File.expand_path('../lib/sinatra-twitter-oauth', File.dirname(__FILE__))
5
+
6
+ require 'spec'
7
+ require 'spec/interop/test'
8
+ require 'rack/test'
9
+
10
+ Test::Unit::TestCase.send :include, Rack::Test::Methods
metadata ADDED
@@ -0,0 +1,77 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sinatra-twitter-oauth
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Nick Howard
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+
12
+ date: 2010-03-11 00:00:00 -07:00
13
+ default_executable:
14
+ dependencies:
15
+ - !ruby/object:Gem::Dependency
16
+ name: rspec
17
+ type: :development
18
+ version_requirement:
19
+ version_requirements: !ruby/object:Gem::Requirement
20
+ requirements:
21
+ - - ">="
22
+ - !ruby/object:Gem::Version
23
+ version: 1.2.9
24
+ version:
25
+ description: A Sinatra Extension that simplifies using twitter for login and authentication.
26
+ email: ndh@baroquebobcat.com
27
+ executables: []
28
+
29
+ extensions: []
30
+
31
+ extra_rdoc_files:
32
+ - LICENSE
33
+ - README.rdoc
34
+ files:
35
+ - .document
36
+ - .gitignore
37
+ - LICENSE
38
+ - README.rdoc
39
+ - Rakefile
40
+ - VERSION
41
+ - lib/sinatra-twitter-oauth.rb
42
+ - lib/sinatra-twitter-oauth/helpers.rb
43
+ - lib/sinatra-twitter-oauth/twitter_oauth_ext.rb
44
+ - sinatra-twitter-oauth.gemspec
45
+ - spec/sinatra-twitter-oauth_spec.rb
46
+ - spec/spec_helper.rb
47
+ has_rdoc: true
48
+ homepage: http://github.com/baroquebobcat/sinatra-twitter-oauth
49
+ licenses: []
50
+
51
+ post_install_message:
52
+ rdoc_options:
53
+ - --charset=UTF-8
54
+ require_paths:
55
+ - lib
56
+ required_ruby_version: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - ">="
59
+ - !ruby/object:Gem::Version
60
+ version: "0"
61
+ version:
62
+ required_rubygems_version: !ruby/object:Gem::Requirement
63
+ requirements:
64
+ - - ">="
65
+ - !ruby/object:Gem::Version
66
+ version: "0"
67
+ version:
68
+ requirements: []
69
+
70
+ rubyforge_project:
71
+ rubygems_version: 1.3.5
72
+ signing_key:
73
+ specification_version: 3
74
+ summary: A Sinatra Extension that simplifies using twitter for login and authentication.
75
+ test_files:
76
+ - spec/spec_helper.rb
77
+ - spec/sinatra-twitter-oauth_spec.rb