ldap-rails 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (49) hide show
  1. data/LICENSE.txt +20 -0
  2. data/README.md +49 -0
  3. data/Rakefile +37 -0
  4. data/lib/generators/ldap_auth/ldap_auth_generator.rb +34 -0
  5. data/lib/generators/ldap_auth/templates/README +25 -0
  6. data/lib/generators/ldap_auth/templates/ldap_auth.rb.erb +16 -0
  7. data/lib/generators/ldap_auth/templates/ldap_login.html.erb +25 -0
  8. data/lib/generators/ldap_auth/templates/ldap_logins_controller.rb +32 -0
  9. data/lib/ldap-rails.rb +3 -0
  10. data/lib/ldap-rails/config.rb +65 -0
  11. data/lib/ldap-rails/controller_extensions.rb +21 -0
  12. data/lib/ldap-rails/helper_extensions.rb +16 -0
  13. data/lib/ldap-rails/ldap_user.rb +40 -0
  14. data/lib/ldap-rails/version.rb +3 -0
  15. data/lib/tasks/ldap-rails_tasks.rake +4 -0
  16. data/test/config_test.rb +84 -0
  17. data/test/dummy/Rakefile +7 -0
  18. data/test/dummy/app/assets/javascripts/application.js +9 -0
  19. data/test/dummy/app/assets/stylesheets/application.css +7 -0
  20. data/test/dummy/app/controllers/application_controller.rb +3 -0
  21. data/test/dummy/app/helpers/application_helper.rb +2 -0
  22. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  23. data/test/dummy/config.ru +4 -0
  24. data/test/dummy/config/application.rb +45 -0
  25. data/test/dummy/config/boot.rb +10 -0
  26. data/test/dummy/config/database.yml +25 -0
  27. data/test/dummy/config/environment.rb +5 -0
  28. data/test/dummy/config/environments/development.rb +30 -0
  29. data/test/dummy/config/environments/production.rb +60 -0
  30. data/test/dummy/config/environments/test.rb +42 -0
  31. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  32. data/test/dummy/config/initializers/inflections.rb +10 -0
  33. data/test/dummy/config/initializers/ldap_rails.rb +1 -0
  34. data/test/dummy/config/initializers/mime_types.rb +5 -0
  35. data/test/dummy/config/initializers/secret_token.rb +7 -0
  36. data/test/dummy/config/initializers/session_store.rb +8 -0
  37. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  38. data/test/dummy/config/locales/en.yml +5 -0
  39. data/test/dummy/config/routes.rb +58 -0
  40. data/test/dummy/db/test.sqlite3 +0 -0
  41. data/test/dummy/log/test.log +0 -0
  42. data/test/dummy/public/404.html +26 -0
  43. data/test/dummy/public/422.html +26 -0
  44. data/test/dummy/public/500.html +26 -0
  45. data/test/dummy/public/favicon.ico +0 -0
  46. data/test/dummy/script/rails +6 -0
  47. data/test/test_helper.rb +10 -0
  48. data/test/version_test.rb +7 -0
  49. metadata +165 -0
@@ -0,0 +1,20 @@
1
+ Copyright 2012 Ben Weissmann
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.
@@ -0,0 +1,49 @@
1
+ # LDAP-Rails
2
+
3
+ ## Radically simple LDAP authentication
4
+
5
+ ldap-rails is a Rails plugin that makes it easy to authenticate users against
6
+ your organization's LDAP server.
7
+
8
+ It's designed for Rails 3.1 and above.
9
+
10
+ ldap-rails is developed and maintained by
11
+ [Ben Weissmann](http://benweissmann.com). If you have bug reports or
12
+ feature requests, please
13
+ [file an issue](https://github.com/benweissmann/ldap-rails/issues) or email
14
+ me at [ben@benweissmann.com](mailto:ben@benweissmann.com).
15
+
16
+ ## Setup
17
+
18
+ 1. Add "gem ldap-rails" to your Gemfile.
19
+ 2. Run "bundle install" to install the new gem.
20
+ 3. Run "rails generate ldap_auth ldap.your-org.com"
21
+
22
+ That's it. You're done. Users will be presented with a login form when they
23
+ visit your site, and will need to log in with LDAP before they can access your
24
+ site.
25
+
26
+ ## Configuration
27
+
28
+ ldap-rails will try to guess your LDAP server's configuration based on the
29
+ the URL you give to the rails generate command. Note that you can specify
30
+ the for as part of the URL -- for example, if your LDAP server runs on port
31
+ 1000, use "rails generate ldap_auth ldap.your-org.com:1000". ldap-rails will
32
+ automatically try to use and SSL connection to your LDAP server if your LDAP
33
+ server is on port 636.
34
+
35
+ You can customize the LDAP connection configuration after you've run the
36
+ generator in config/initializer/ldap_auth.rb. See the instruction in that
37
+ file for more detail.
38
+
39
+ ## Roadmap
40
+
41
+ Planned features:
42
+
43
+ * Access control based on LDAP groups.
44
+ * Integration with ActiveRecord to easily store authenticated users in your
45
+ database.
46
+
47
+ ## License
48
+
49
+ ldap-rails is licensed under the MIT license. See LICENSE.txt for details.
@@ -0,0 +1,37 @@
1
+ #!/usr/bin/env rake
2
+ begin
3
+ require 'bundler/setup'
4
+ rescue LoadError
5
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
6
+ end
7
+ begin
8
+ require 'rdoc/task'
9
+ rescue LoadError
10
+ require 'rdoc/rdoc'
11
+ require 'rake/rdoctask'
12
+ RDoc::Task = Rake::RDocTask
13
+ end
14
+
15
+ RDoc::Task.new(:rdoc) do |rdoc|
16
+ rdoc.rdoc_dir = 'rdoc'
17
+ rdoc.title = 'LdapRails'
18
+ rdoc.options << '--line-numbers'
19
+ rdoc.rdoc_files.include('README.rdoc')
20
+ rdoc.rdoc_files.include('lib/**/*.rb')
21
+ end
22
+
23
+
24
+
25
+ Bundler::GemHelper.install_tasks
26
+
27
+ require 'rake/testtask'
28
+
29
+ Rake::TestTask.new(:test) do |t|
30
+ t.libs << 'lib'
31
+ t.libs << 'test'
32
+ t.pattern = 'test/**/*_test.rb'
33
+ t.verbose = false
34
+ end
35
+
36
+
37
+ task :default => :test
@@ -0,0 +1,34 @@
1
+ class LdapAuthGenerator < Rails::Generators::Base
2
+ desc "Creates the views and controllers for LDAP authentication"
3
+ source_root File.expand_path("../templates", __FILE__)
4
+ argument :ldap_host, :type => :string
5
+
6
+ def create_initializer
7
+ LdapRails.configure :host => ldap_host
8
+ template "ldap_auth.rb.erb", "config/initializers/ldap_auth.rb"
9
+ end
10
+
11
+ def add_before_filter
12
+ inject_into_class "app/controllers/application_controller.rb", ApplicationController do
13
+ " before_filter :require_ldap_auth, :except => [:ldap_login, :persist_ldap_login, :ldap_logout]\n"
14
+ end
15
+ end
16
+
17
+ def add_routes
18
+ route "get '/ldap_login' => 'LdapLogins#ldap_login', :as => :ldap_login"
19
+ route "post '/ldap_login' => 'LdapLogins#persist_ldap_login', :as => :persist_ldap_login"
20
+ route "post '/ldap_logout' => 'LdapLogins#ldap_logout', :as => :ldap_logout"
21
+ end
22
+
23
+ def create_controller
24
+ copy_file "ldap_logins_controller.rb", "app/controllers/ldap_logins_controller.rb"
25
+ end
26
+
27
+ def create_views
28
+ copy_file "ldap_login.html.erb", "app/views/ldap_logins/ldap_login.html.erb"
29
+ end
30
+
31
+ def instructions
32
+ readme "README"
33
+ end
34
+ end
@@ -0,0 +1,25 @@
1
+
2
+
3
+ You're all set up for authentication. Just double-check that the settings
4
+ in config/initializers/ldap_auth.rb are correct.
5
+
6
+ YOu can style the login page with CSS, or just use Bootstrap
7
+ (http://twitter.github.com/bootstrap/) -- the login page is set up to
8
+ loog great with Bootstrap.
9
+
10
+ In your controllers, use "ldap_user.username" to get the username of the
11
+ logged in user. In your views, use "@controller.ldap_user.username".
12
+
13
+ To create a simple login status display with a logout link
14
+ (e.g. "You are logged in as someuser. <a href="/logout">Log Out</a>.")
15
+ use:
16
+
17
+ <%= ldap_status %>
18
+
19
+ To log out a user, submit a POST request to "/logout_ldap". You can
20
+ create a logout link in your views with:
21
+
22
+ <%= link_to 'Log Out', ldap_logout_path, :method => :post %>
23
+
24
+ For more documentation, go to http://github.com/benweissmann/ldap-rails
25
+
@@ -0,0 +1,16 @@
1
+ # Make sure to restart your server whenever you edit this file.
2
+
3
+ # The configuration parameters here are inferred from the hostname you provided
4
+ # to the generator, and are usually correct. You can edit them to match
5
+ # your LDAP server's configuration.
6
+ #
7
+ # host: The hostname of the LDAP server
8
+ # port: The port to connect to the LDAP server on. The default for non-SSL
9
+ # connections in 389 and the default of SSL connections is 636.
10
+ # ssl: If true, LdapRails will connect using SSL/TLS.
11
+ #
12
+ # base_dn, login_key, login_prefix: Ask you LDAP server administrator
13
+ # for these value. When authenticating, LdapRails constructs the LDAP
14
+ # DN for the user based on their username and these values:
15
+ # DN: <login_key>=<username>,<login_suffix>,<base_dn>
16
+ LdapRails.configure(<%= LdapRails.config.inspect %>)
@@ -0,0 +1,25 @@
1
+ <% if flash[:ldap_login_error] %>
2
+ <div class="alert alert-error">
3
+ <%= flash[:ldap_login_error] %>
4
+ </div>
5
+ <% end %>
6
+
7
+ <%= form_tag :html => {:class => 'ldap-login-form form-horizontal'} do %>
8
+ <legend>Log in with your LDAP username and password</legend>
9
+ <div class="control-group">
10
+ <label class="control-label" for="username">Username</label>
11
+ <div class="controls">
12
+ <input type="text" class="input-xlarge" id="username" name="username">
13
+ </div>
14
+ </div>
15
+ <div class="control-group">
16
+ <label class="control-label" for="password">Password</label>
17
+ <div class="controls">
18
+ <input type="password" class="input-xlarge" id="password" name="password">
19
+ </div>
20
+ </div>
21
+
22
+ <div class="form-actions">
23
+ <button type="submit" class="btn btn-primary">Log In</buton>
24
+ </div>
25
+ <% end %>
@@ -0,0 +1,32 @@
1
+ class LdapLoginsController < ApplicationController
2
+ # GET /ldap_login
3
+ def ldap_login
4
+ # ldap_logins.erb
5
+ end
6
+
7
+ # POST /ldap_login
8
+ def persist_ldap_login
9
+ user = LdapRails::LdapUser.auth params[:username], params[:password]
10
+
11
+ if user.nil?
12
+ flash[:ldap_login_error] = "Incorrect username or password."
13
+ redirect_to ldap_login_path
14
+ else
15
+ session[:ldap_user] = user.to_hash
16
+ flash[:notice] = "Logged in as #{user.username}."
17
+
18
+ # Clear return_to so it doesn't get re-used if the user logs out
19
+ # and logs in again.
20
+ target = (session[:return_to] || '/')
21
+ session.delete :return_to
22
+
23
+ redirect_to target
24
+ end
25
+ end
26
+
27
+ # POST /ldap_logout
28
+ def ldap_logout
29
+ session[:ldap_user] = nil
30
+ redirect_to '/'
31
+ end
32
+ end
@@ -0,0 +1,3 @@
1
+ Dir[File.join(File.dirname(__FILE__), 'ldap-rails', '**', '*.rb')].each do |f|
2
+ require f
3
+ end
@@ -0,0 +1,65 @@
1
+ require 'uri'
2
+
3
+ module LdapRails
4
+ class << self
5
+ attr_reader :config
6
+ attr_reader :ldap
7
+
8
+ def configure config
9
+ # config[:host] is required
10
+ unless config[:host]
11
+ raise InvalidConfigurationError.new("Must provide :host to LdapRails.configure")
12
+ end
13
+
14
+ # store and autocomplete the config
15
+ @config = config
16
+ autocomplete_config
17
+
18
+ # create a Net::LDAP
19
+ opts = {:host => config[:host], :port => config[:port]}
20
+
21
+ if config[:ssl]
22
+ opts[:encryption] = :simple_tls
23
+ end
24
+
25
+ @ldap = Net::LDAP.new opts
26
+ end
27
+
28
+ private
29
+
30
+ def autocomplete_config
31
+ # split port from host
32
+ if @config[:port].nil? and @config[:host] and config[:host].include? ':'
33
+ @config[:host], @config[:port] = @config[:host].split(':')
34
+ @config[:port] = @config[:port].to_i
35
+ end
36
+
37
+ # default port to 389
38
+ @config[:port] ||= 389
39
+
40
+ # infer TLS from port
41
+ if @config[:ssl].nil? and @config[:port] == 636
42
+ @config[:ssl] = true
43
+ end
44
+
45
+ # default TLS to false
46
+ @config[:ssl] ||= false
47
+
48
+ # infer base_dn from host
49
+ if @config[:host] and @config[:base_dn].nil?
50
+ parts = @config[:host].split('.')
51
+ if parts.length == 1
52
+ @config[:base_dn] = "dc=#{parts[0]}"
53
+ elsif parts.length > 1
54
+ @config[:base_dn] = "dc=#{parts[-2]},dc=#{parts[-1]}"
55
+ end
56
+ end
57
+
58
+ # default login key to 'uid' and login suffix to ''
59
+ @config[:login_key] ||= 'uid'
60
+ @config[:login_suffix] ||= ''
61
+ end
62
+ end
63
+
64
+ class InvalidConfigurationError < StandardError; end
65
+ end
@@ -0,0 +1,21 @@
1
+ module LdapRails
2
+ module ControllerExtensions
3
+ def ldap_user
4
+ if session[:ldap_user]
5
+ @ldap_user = LdapRails::LdapUser.new session[:ldap_user]
6
+ end
7
+
8
+ return @ldap_user
9
+ end
10
+
11
+ def require_ldap_auth
12
+ if ldap_user.nil?
13
+ session[:return_to] = request.path
14
+ flash[:error] = "You must log in."
15
+ redirect_to ldap_login_path
16
+ end
17
+ end
18
+ end
19
+ end
20
+
21
+ ActionController::Base.send :include, LdapRails::ControllerExtensions
@@ -0,0 +1,16 @@
1
+ module LdapRails
2
+ module HelperExtensions
3
+ def ldap_user
4
+ controller.ldap_user
5
+ end
6
+
7
+ def ldap_status
8
+ return '' unless ldap_user
9
+
10
+ link = link_to('Log Out', ldap_logout_path, :method => :post)
11
+ return "Logged in as #{ldap_user.username}. #{link}.".html_safe
12
+ end
13
+ end
14
+ end
15
+
16
+ ActionView::Base.send :include, LdapRails::HelperExtensions
@@ -0,0 +1,40 @@
1
+ require 'net-ldap'
2
+
3
+ module LdapRails
4
+ class LdapUser
5
+ attr_reader :username
6
+
7
+ def initialize hash
8
+ @username = hash[:username]
9
+ end
10
+
11
+ def to_hash
12
+ {:username => @username}
13
+ end
14
+
15
+ # Tries to authenticate using the given username and password. Returns
16
+ # an LdapUser is successful, nil if unsuccessful.
17
+ def self.auth username, password
18
+ unless LdapRails.config
19
+ raise NoConfigurationError.new("You must have a call to LdapRails.configure in an initializer.")
20
+ end
21
+
22
+ LdapRails.ldap.auth dn_for(username), password
23
+ if LdapRails.ldap.bind
24
+ return new(:username => username)
25
+ else
26
+ return nil
27
+ end
28
+ end
29
+
30
+ def self.dn_for username
31
+ dn = "#{LdapRails.config[:login_key]}=#{username}"
32
+ if LdapRails.config[:login_suffix].length > 0
33
+ dn += ",#{LdapRails.config[:login_suffix]}"
34
+ end
35
+ end
36
+ private_class_method :dn_for
37
+ end
38
+
39
+ class NoConfigurationError < StandardError; end
40
+ end
@@ -0,0 +1,3 @@
1
+ module LdapRails
2
+ VERSION = "0.1.0"
3
+ end
@@ -0,0 +1,4 @@
1
+ # desc "Explaining what the task does"
2
+ # task :ldap-rails do
3
+ # # Task goes here
4
+ # end
@@ -0,0 +1,84 @@
1
+ require 'test_helper'
2
+
3
+ class LdapRailsTest < ActiveSupport::TestCase
4
+ test "configure, all specified" do
5
+ LdapRails.configure :host => 'foo.example.com',
6
+ :port => 100,
7
+ :ssl => true,
8
+ :base_dn => 'dc=a,dc=b',
9
+ :login_suffix => 'ou=hello,ou=world',
10
+ :login_key => 'userid'
11
+
12
+ assert_equal 'foo.example.com', LdapRails.config[:host]
13
+ assert_equal 100, LdapRails.config[:port]
14
+ assert_equal true, LdapRails.config[:ssl]
15
+ assert_equal 'dc=a,dc=b', LdapRails.config[:base_dn]
16
+ assert_equal 'ou=hello,ou=world', LdapRails.config[:login_suffix]
17
+ assert_equal 'userid', LdapRails.config[:login_key]
18
+ end
19
+
20
+ test "configure, default port" do
21
+ LdapRails.configure :host => 'foo.example.com',
22
+ :ssl => true,
23
+ :base_dn => 'dc=a,dc=b'
24
+
25
+ assert_equal 'foo.example.com', LdapRails.config[:host]
26
+ assert_equal 389, LdapRails.config[:port]
27
+ assert_equal true, LdapRails.config[:ssl]
28
+ assert_equal 'dc=a,dc=b', LdapRails.config[:base_dn]
29
+ end
30
+
31
+ test "configure, infer port" do
32
+ LdapRails.configure :host => 'foo.example.com:1000',
33
+ :ssl => true,
34
+ :base_dn => 'dc=a,dc=b'
35
+
36
+ assert_equal 'foo.example.com', LdapRails.config[:host]
37
+ assert_equal 1000, LdapRails.config[:port]
38
+ assert_equal true, LdapRails.config[:ssl]
39
+ assert_equal 'dc=a,dc=b', LdapRails.config[:base_dn]
40
+ end
41
+
42
+ test "configure, default ssl" do
43
+ LdapRails.configure :host => 'foo.example.com',
44
+ :port => 100,
45
+ :base_dn => 'dc=a,dc=b'
46
+
47
+ assert_equal 'foo.example.com', LdapRails.config[:host]
48
+ assert_equal 100, LdapRails.config[:port]
49
+ assert_equal false, LdapRails.config[:ssl]
50
+ assert_equal 'dc=a,dc=b', LdapRails.config[:base_dn]
51
+ end
52
+
53
+ test "configure, infer ssl" do
54
+ LdapRails.configure :host => 'foo.example.com:636',
55
+ :base_dn => 'dc=a,dc=b'
56
+
57
+ assert_equal 'foo.example.com', LdapRails.config[:host]
58
+ assert_equal 636, LdapRails.config[:port]
59
+ assert_equal true, LdapRails.config[:ssl]
60
+ assert_equal 'dc=a,dc=b', LdapRails.config[:base_dn]
61
+ end
62
+
63
+ test "configure, infer all" do
64
+ LdapRails.configure :host => 'foo.example.com:636'
65
+
66
+ assert_equal 'foo.example.com', LdapRails.config[:host]
67
+ assert_equal 636, LdapRails.config[:port]
68
+ assert_equal true, LdapRails.config[:ssl]
69
+ assert_equal 'dc=example,dc=com', LdapRails.config[:base_dn]
70
+ assert_nil LdapRails.config[:login_suffix]
71
+ assert_equal 'uid', LdapRails.config[:login_key]
72
+ end
73
+
74
+ test "configure, no host" do
75
+ assert_raise LdapRails::InvalidConfigurationError do
76
+ LdapRails.configure :port => 100,
77
+ :ssl => true,
78
+ :base_dn => 'dc=a,dc=b',
79
+ :login_suffix => 'ou=hello,ou=world',
80
+ :login_key => 'userid'
81
+ end
82
+ end
83
+ end
84
+
@@ -0,0 +1,7 @@
1
+ #!/usr/bin/env rake
2
+ # Add your own tasks in files placed in lib/tasks ending in .rake,
3
+ # for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
4
+
5
+ require File.expand_path('../config/application', __FILE__)
6
+
7
+ Dummy::Application.load_tasks
@@ -0,0 +1,9 @@
1
+ // This is a manifest file that'll be compiled into including all the files listed below.
2
+ // Add new JavaScript/Coffee code in separate files in this directory and they'll automatically
3
+ // be included in the compiled file accessible from http://example.com/assets/application.js
4
+ // It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
5
+ // the compiled file.
6
+ //
7
+ //= require jquery
8
+ //= require jquery_ujs
9
+ //= require_tree .
@@ -0,0 +1,7 @@
1
+ /*
2
+ * This is a manifest file that'll automatically include all the stylesheets available in this directory
3
+ * and any sub-directories. You're free to add application-wide styles to this file and they'll appear at
4
+ * the top of the compiled file, but it's generally better to create a new file per style scope.
5
+ *= require_self
6
+ *= require_tree .
7
+ */
@@ -0,0 +1,3 @@
1
+ class ApplicationController < ActionController::Base
2
+ protect_from_forgery
3
+ end
@@ -0,0 +1,2 @@
1
+ module ApplicationHelper
2
+ end
@@ -0,0 +1,14 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Dummy</title>
5
+ <%= stylesheet_link_tag "application" %>
6
+ <%= javascript_include_tag "application" %>
7
+ <%= csrf_meta_tags %>
8
+ </head>
9
+ <body>
10
+
11
+ <%= yield %>
12
+
13
+ </body>
14
+ </html>
@@ -0,0 +1,4 @@
1
+ # This file is used by Rack-based servers to start the application.
2
+
3
+ require ::File.expand_path('../config/environment', __FILE__)
4
+ run Dummy::Application
@@ -0,0 +1,45 @@
1
+ require File.expand_path('../boot', __FILE__)
2
+
3
+ require 'rails/all'
4
+
5
+ Bundler.require
6
+ require "ldap-rails"
7
+
8
+ module Dummy
9
+ class Application < Rails::Application
10
+ # Settings in config/environments/* take precedence over those specified here.
11
+ # Application configuration should go into files in config/initializers
12
+ # -- all .rb files in that directory are automatically loaded.
13
+
14
+ # Custom directories with classes and modules you want to be autoloadable.
15
+ # config.autoload_paths += %W(#{config.root}/extras)
16
+
17
+ # Only load the plugins named here, in the order given (default is alphabetical).
18
+ # :all can be used as a placeholder for all plugins not explicitly named.
19
+ # config.plugins = [ :exception_notification, :ssl_requirement, :all ]
20
+
21
+ # Activate observers that should always be running.
22
+ # config.active_record.observers = :cacher, :garbage_collector, :forum_observer
23
+
24
+ # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
25
+ # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
26
+ # config.time_zone = 'Central Time (US & Canada)'
27
+
28
+ # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
29
+ # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
30
+ # config.i18n.default_locale = :de
31
+
32
+ # Configure the default encoding used in templates for Ruby 1.9.
33
+ config.encoding = "utf-8"
34
+
35
+ # Configure sensitive parameters which will be filtered from the log file.
36
+ config.filter_parameters += [:password]
37
+
38
+ # Enable the asset pipeline
39
+ config.assets.enabled = true
40
+
41
+ # Version of your assets, change this if you want to expire all your assets
42
+ config.assets.version = '1.0'
43
+ end
44
+ end
45
+
@@ -0,0 +1,10 @@
1
+ require 'rubygems'
2
+ gemfile = File.expand_path('../../../../Gemfile', __FILE__)
3
+
4
+ if File.exist?(gemfile)
5
+ ENV['BUNDLE_GEMFILE'] = gemfile
6
+ require 'bundler'
7
+ Bundler.setup
8
+ end
9
+
10
+ $:.unshift File.expand_path('../../../../lib', __FILE__)
@@ -0,0 +1,25 @@
1
+ # SQLite version 3.x
2
+ # gem install sqlite3
3
+ #
4
+ # Ensure the SQLite 3 gem is defined in your Gemfile
5
+ # gem 'sqlite3'
6
+ development:
7
+ adapter: sqlite3
8
+ database: db/development.sqlite3
9
+ pool: 5
10
+ timeout: 5000
11
+
12
+ # Warning: The database defined as "test" will be erased and
13
+ # re-generated from your development database when you run "rake".
14
+ # Do not set this db to the same as development or production.
15
+ test:
16
+ adapter: sqlite3
17
+ database: db/test.sqlite3
18
+ pool: 5
19
+ timeout: 5000
20
+
21
+ production:
22
+ adapter: sqlite3
23
+ database: db/production.sqlite3
24
+ pool: 5
25
+ timeout: 5000
@@ -0,0 +1,5 @@
1
+ # Load the rails application
2
+ require File.expand_path('../application', __FILE__)
3
+
4
+ # Initialize the rails application
5
+ Dummy::Application.initialize!
@@ -0,0 +1,30 @@
1
+ Dummy::Application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb
3
+
4
+ # In the development environment your application's code is reloaded on
5
+ # every request. This slows down response time but is perfect for development
6
+ # since you don't have to restart the web server when you make code changes.
7
+ config.cache_classes = false
8
+
9
+ # Log error messages when you accidentally call methods on nil.
10
+ config.whiny_nils = true
11
+
12
+ # Show full error reports and disable caching
13
+ config.consider_all_requests_local = true
14
+ config.action_controller.perform_caching = false
15
+
16
+ # Don't care if the mailer can't send
17
+ config.action_mailer.raise_delivery_errors = false
18
+
19
+ # Print deprecation notices to the Rails logger
20
+ config.active_support.deprecation = :log
21
+
22
+ # Only use best-standards-support built into browsers
23
+ config.action_dispatch.best_standards_support = :builtin
24
+
25
+ # Do not compress assets
26
+ config.assets.compress = false
27
+
28
+ # Expands the lines which load the assets
29
+ config.assets.debug = true
30
+ end
@@ -0,0 +1,60 @@
1
+ Dummy::Application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb
3
+
4
+ # Code is not reloaded between requests
5
+ config.cache_classes = true
6
+
7
+ # Full error reports are disabled and caching is turned on
8
+ config.consider_all_requests_local = false
9
+ config.action_controller.perform_caching = true
10
+
11
+ # Disable Rails's static asset server (Apache or nginx will already do this)
12
+ config.serve_static_assets = false
13
+
14
+ # Compress JavaScripts and CSS
15
+ config.assets.compress = true
16
+
17
+ # Don't fallback to assets pipeline if a precompiled asset is missed
18
+ config.assets.compile = false
19
+
20
+ # Generate digests for assets URLs
21
+ config.assets.digest = true
22
+
23
+ # Defaults to Rails.root.join("public/assets")
24
+ # config.assets.manifest = YOUR_PATH
25
+
26
+ # Specifies the header that your server uses for sending files
27
+ # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
28
+ # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
29
+
30
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
31
+ # config.force_ssl = true
32
+
33
+ # See everything in the log (default is :info)
34
+ # config.log_level = :debug
35
+
36
+ # Use a different logger for distributed setups
37
+ # config.logger = SyslogLogger.new
38
+
39
+ # Use a different cache store in production
40
+ # config.cache_store = :mem_cache_store
41
+
42
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server
43
+ # config.action_controller.asset_host = "http://assets.example.com"
44
+
45
+ # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added)
46
+ # config.assets.precompile += %w( search.js )
47
+
48
+ # Disable delivery errors, bad email addresses will be ignored
49
+ # config.action_mailer.raise_delivery_errors = false
50
+
51
+ # Enable threaded mode
52
+ # config.threadsafe!
53
+
54
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
55
+ # the I18n.default_locale when a translation can not be found)
56
+ config.i18n.fallbacks = true
57
+
58
+ # Send deprecation notices to registered listeners
59
+ config.active_support.deprecation = :notify
60
+ end
@@ -0,0 +1,42 @@
1
+ Dummy::Application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb
3
+
4
+ # The test environment is used exclusively to run your application's
5
+ # test suite. You never need to work with it otherwise. Remember that
6
+ # your test database is "scratch space" for the test suite and is wiped
7
+ # and recreated between test runs. Don't rely on the data there!
8
+ config.cache_classes = true
9
+
10
+ # Configure static asset server for tests with Cache-Control for performance
11
+ config.serve_static_assets = true
12
+ config.static_cache_control = "public, max-age=3600"
13
+
14
+ # Log error messages when you accidentally call methods on nil
15
+ config.whiny_nils = true
16
+
17
+ # Show full error reports and disable caching
18
+ config.consider_all_requests_local = true
19
+ config.action_controller.perform_caching = false
20
+
21
+ # Raise exceptions instead of rendering exception templates
22
+ config.action_dispatch.show_exceptions = false
23
+
24
+ # Disable request forgery protection in test environment
25
+ config.action_controller.allow_forgery_protection = false
26
+
27
+ # Tell Action Mailer not to deliver emails to the real world.
28
+ # The :test delivery method accumulates sent emails in the
29
+ # ActionMailer::Base.deliveries array.
30
+ config.action_mailer.delivery_method = :test
31
+
32
+ # Use SQL instead of Active Record's schema dumper when creating the test database.
33
+ # This is necessary if your schema can't be completely dumped by the schema dumper,
34
+ # like if you have constraints or database-specific column types
35
+ # config.active_record.schema_format = :sql
36
+
37
+ # Print deprecation notices to the stderr
38
+ config.active_support.deprecation = :stderr
39
+
40
+ # Allow pass debug_assets=true as a query parameter to load pages with unpackaged assets
41
+ config.assets.allow_debugging = true
42
+ end
@@ -0,0 +1,7 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4
+ # Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
5
+
6
+ # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
7
+ # Rails.backtrace_cleaner.remove_silencers!
@@ -0,0 +1,10 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new inflection rules using the following format
4
+ # (all these examples are active by default):
5
+ # ActiveSupport::Inflector.inflections do |inflect|
6
+ # inflect.plural /^(ox)$/i, '\1en'
7
+ # inflect.singular /^(ox)en/i, '\1'
8
+ # inflect.irregular 'person', 'people'
9
+ # inflect.uncountable %w( fish sheep )
10
+ # end
@@ -0,0 +1 @@
1
+ LdapRails.configure :host => 'ceviche.local'
@@ -0,0 +1,5 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new mime types for use in respond_to blocks:
4
+ # Mime::Type.register "text/richtext", :rtf
5
+ # Mime::Type.register_alias "text/html", :iphone
@@ -0,0 +1,7 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Your secret key for verifying the integrity of signed cookies.
4
+ # If you change this key, all old signed cookies will become invalid!
5
+ # Make sure the secret is at least 30 characters and all random,
6
+ # no regular words or you'll be exposed to dictionary attacks.
7
+ Dummy::Application.config.secret_token = 'a2f155ce453fd3fea9ba23634191f5a29628e90f7ac6b3b5a01d059ceb0481e7b0708e342b293f015d556b63c8292c0756844af0ad48ae675e8818aa2479bbf1'
@@ -0,0 +1,8 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ Dummy::Application.config.session_store :cookie_store, key: '_dummy_session'
4
+
5
+ # Use the database for sessions instead of the cookie-based default,
6
+ # which shouldn't be used to store highly confidential information
7
+ # (create the session table with "rails generate session_migration")
8
+ # Dummy::Application.config.session_store :active_record_store
@@ -0,0 +1,14 @@
1
+ # Be sure to restart your server when you modify this file.
2
+ #
3
+ # This file contains settings for ActionController::ParamsWrapper which
4
+ # is enabled by default.
5
+
6
+ # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7
+ ActiveSupport.on_load(:action_controller) do
8
+ wrap_parameters format: [:json]
9
+ end
10
+
11
+ # Disable root element in JSON by default.
12
+ ActiveSupport.on_load(:active_record) do
13
+ self.include_root_in_json = false
14
+ end
@@ -0,0 +1,5 @@
1
+ # Sample localization file for English. Add more files in this directory for other locales.
2
+ # See https://github.com/svenfuchs/rails-i18n/tree/master/rails%2Flocale for starting points.
3
+
4
+ en:
5
+ hello: "Hello world"
@@ -0,0 +1,58 @@
1
+ Dummy::Application.routes.draw do
2
+ # The priority is based upon order of creation:
3
+ # first created -> highest priority.
4
+
5
+ # Sample of regular route:
6
+ # match 'products/:id' => 'catalog#view'
7
+ # Keep in mind you can assign values other than :controller and :action
8
+
9
+ # Sample of named route:
10
+ # match 'products/:id/purchase' => 'catalog#purchase', :as => :purchase
11
+ # This route can be invoked with purchase_url(:id => product.id)
12
+
13
+ # Sample resource route (maps HTTP verbs to controller actions automatically):
14
+ # resources :products
15
+
16
+ # Sample resource route with options:
17
+ # resources :products do
18
+ # member do
19
+ # get 'short'
20
+ # post 'toggle'
21
+ # end
22
+ #
23
+ # collection do
24
+ # get 'sold'
25
+ # end
26
+ # end
27
+
28
+ # Sample resource route with sub-resources:
29
+ # resources :products do
30
+ # resources :comments, :sales
31
+ # resource :seller
32
+ # end
33
+
34
+ # Sample resource route with more complex sub-resources
35
+ # resources :products do
36
+ # resources :comments
37
+ # resources :sales do
38
+ # get 'recent', :on => :collection
39
+ # end
40
+ # end
41
+
42
+ # Sample resource route within a namespace:
43
+ # namespace :admin do
44
+ # # Directs /admin/products/* to Admin::ProductsController
45
+ # # (app/controllers/admin/products_controller.rb)
46
+ # resources :products
47
+ # end
48
+
49
+ # You can have the root of your site routed with "root"
50
+ # just remember to delete public/index.html.
51
+ # root :to => 'welcome#index'
52
+
53
+ # See how all your routes lay out with "rake routes"
54
+
55
+ # This is a legacy wild controller route that's not recommended for RESTful applications.
56
+ # Note: This route will make all actions in every controller accessible via GET requests.
57
+ # match ':controller(/:action(/:id(.:format)))'
58
+ end
File without changes
File without changes
@@ -0,0 +1,26 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>The page you were looking for doesn't exist (404)</title>
5
+ <style type="text/css">
6
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
7
+ div.dialog {
8
+ width: 25em;
9
+ padding: 0 4em;
10
+ margin: 4em auto 0 auto;
11
+ border: 1px solid #ccc;
12
+ border-right-color: #999;
13
+ border-bottom-color: #999;
14
+ }
15
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <!-- This file lives in public/404.html -->
21
+ <div class="dialog">
22
+ <h1>The page you were looking for doesn't exist.</h1>
23
+ <p>You may have mistyped the address or the page may have moved.</p>
24
+ </div>
25
+ </body>
26
+ </html>
@@ -0,0 +1,26 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>The change you wanted was rejected (422)</title>
5
+ <style type="text/css">
6
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
7
+ div.dialog {
8
+ width: 25em;
9
+ padding: 0 4em;
10
+ margin: 4em auto 0 auto;
11
+ border: 1px solid #ccc;
12
+ border-right-color: #999;
13
+ border-bottom-color: #999;
14
+ }
15
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <!-- This file lives in public/422.html -->
21
+ <div class="dialog">
22
+ <h1>The change you wanted was rejected.</h1>
23
+ <p>Maybe you tried to change something you didn't have access to.</p>
24
+ </div>
25
+ </body>
26
+ </html>
@@ -0,0 +1,26 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>We're sorry, but something went wrong (500)</title>
5
+ <style type="text/css">
6
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
7
+ div.dialog {
8
+ width: 25em;
9
+ padding: 0 4em;
10
+ margin: 4em auto 0 auto;
11
+ border: 1px solid #ccc;
12
+ border-right-color: #999;
13
+ border-bottom-color: #999;
14
+ }
15
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <!-- This file lives in public/500.html -->
21
+ <div class="dialog">
22
+ <h1>We're sorry, but something went wrong.</h1>
23
+ <p>We've been notified about this issue and we'll take a look at it shortly.</p>
24
+ </div>
25
+ </body>
26
+ </html>
File without changes
@@ -0,0 +1,6 @@
1
+ #!/usr/bin/env ruby
2
+ # This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
3
+
4
+ APP_PATH = File.expand_path('../../config/application', __FILE__)
5
+ require File.expand_path('../../config/boot', __FILE__)
6
+ require 'rails/commands'
@@ -0,0 +1,10 @@
1
+ # Configure Rails Environment
2
+ ENV["RAILS_ENV"] = "test"
3
+
4
+ require File.expand_path("../dummy/config/environment.rb", __FILE__)
5
+ require "rails/test_help"
6
+
7
+ Rails.backtrace_cleaner.remove_silencers!
8
+
9
+ # Load support files
10
+ Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class LdapRailsTest < ActiveSupport::TestCase
4
+ test "version" do
5
+ assert_equal '0.1.0', LdapRails::VERSION
6
+ end
7
+ end
metadata ADDED
@@ -0,0 +1,165 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: ldap-rails
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Ben Weissmann
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2012-08-05 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: rails
16
+ requirement: &14503000 !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ~>
20
+ - !ruby/object:Gem::Version
21
+ version: 3.1.0
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: *14503000
25
+ - !ruby/object:Gem::Dependency
26
+ name: net-ldap
27
+ requirement: &14502340 !ruby/object:Gem::Requirement
28
+ none: false
29
+ requirements:
30
+ - - ~>
31
+ - !ruby/object:Gem::Version
32
+ version: 0.3.1
33
+ type: :runtime
34
+ prerelease: false
35
+ version_requirements: *14502340
36
+ - !ruby/object:Gem::Dependency
37
+ name: sqlite3
38
+ requirement: &14501860 !ruby/object:Gem::Requirement
39
+ none: false
40
+ requirements:
41
+ - - ! '>='
42
+ - !ruby/object:Gem::Version
43
+ version: '0'
44
+ type: :development
45
+ prerelease: false
46
+ version_requirements: *14501860
47
+ description: Generator that enabled LDAP authentication with a single command.
48
+ email:
49
+ - ben@benweissmann.com
50
+ executables: []
51
+ extensions: []
52
+ extra_rdoc_files: []
53
+ files:
54
+ - lib/tasks/ldap-rails_tasks.rake
55
+ - lib/generators/ldap_auth/ldap_auth_generator.rb
56
+ - lib/generators/ldap_auth/templates/ldap_auth.rb.erb
57
+ - lib/generators/ldap_auth/templates/README
58
+ - lib/generators/ldap_auth/templates/ldap_logins_controller.rb
59
+ - lib/generators/ldap_auth/templates/ldap_login.html.erb
60
+ - lib/ldap-rails/controller_extensions.rb
61
+ - lib/ldap-rails/version.rb
62
+ - lib/ldap-rails/helper_extensions.rb
63
+ - lib/ldap-rails/config.rb
64
+ - lib/ldap-rails/ldap_user.rb
65
+ - lib/ldap-rails.rb
66
+ - LICENSE.txt
67
+ - Rakefile
68
+ - README.md
69
+ - test/version_test.rb
70
+ - test/config_test.rb
71
+ - test/dummy/log/test.log
72
+ - test/dummy/config/database.yml
73
+ - test/dummy/config/locales/en.yml
74
+ - test/dummy/config/application.rb
75
+ - test/dummy/config/environments/test.rb
76
+ - test/dummy/config/environments/production.rb
77
+ - test/dummy/config/environments/development.rb
78
+ - test/dummy/config/boot.rb
79
+ - test/dummy/config/initializers/wrap_parameters.rb
80
+ - test/dummy/config/initializers/session_store.rb
81
+ - test/dummy/config/initializers/secret_token.rb
82
+ - test/dummy/config/initializers/inflections.rb
83
+ - test/dummy/config/initializers/backtrace_silencers.rb
84
+ - test/dummy/config/initializers/ldap_rails.rb
85
+ - test/dummy/config/initializers/mime_types.rb
86
+ - test/dummy/config/environment.rb
87
+ - test/dummy/config/routes.rb
88
+ - test/dummy/config.ru
89
+ - test/dummy/script/rails
90
+ - test/dummy/db/test.sqlite3
91
+ - test/dummy/app/views/layouts/application.html.erb
92
+ - test/dummy/app/helpers/application_helper.rb
93
+ - test/dummy/app/controllers/application_controller.rb
94
+ - test/dummy/app/assets/stylesheets/application.css
95
+ - test/dummy/app/assets/javascripts/application.js
96
+ - test/dummy/public/500.html
97
+ - test/dummy/public/422.html
98
+ - test/dummy/public/404.html
99
+ - test/dummy/public/favicon.ico
100
+ - test/dummy/Rakefile
101
+ - test/test_helper.rb
102
+ homepage: http://github.com/benweissmann/ldap-rails
103
+ licenses: []
104
+ post_install_message:
105
+ rdoc_options: []
106
+ require_paths:
107
+ - lib
108
+ required_ruby_version: !ruby/object:Gem::Requirement
109
+ none: false
110
+ requirements:
111
+ - - ! '>='
112
+ - !ruby/object:Gem::Version
113
+ version: '0'
114
+ segments:
115
+ - 0
116
+ hash: -3351325667015385517
117
+ required_rubygems_version: !ruby/object:Gem::Requirement
118
+ none: false
119
+ requirements:
120
+ - - ! '>='
121
+ - !ruby/object:Gem::Version
122
+ version: '0'
123
+ segments:
124
+ - 0
125
+ hash: -3351325667015385517
126
+ requirements: []
127
+ rubyforge_project:
128
+ rubygems_version: 1.8.6
129
+ signing_key:
130
+ specification_version: 3
131
+ summary: Radically simple LDAP authentication for Rails.
132
+ test_files:
133
+ - test/version_test.rb
134
+ - test/config_test.rb
135
+ - test/dummy/log/test.log
136
+ - test/dummy/config/database.yml
137
+ - test/dummy/config/locales/en.yml
138
+ - test/dummy/config/application.rb
139
+ - test/dummy/config/environments/test.rb
140
+ - test/dummy/config/environments/production.rb
141
+ - test/dummy/config/environments/development.rb
142
+ - test/dummy/config/boot.rb
143
+ - test/dummy/config/initializers/wrap_parameters.rb
144
+ - test/dummy/config/initializers/session_store.rb
145
+ - test/dummy/config/initializers/secret_token.rb
146
+ - test/dummy/config/initializers/inflections.rb
147
+ - test/dummy/config/initializers/backtrace_silencers.rb
148
+ - test/dummy/config/initializers/ldap_rails.rb
149
+ - test/dummy/config/initializers/mime_types.rb
150
+ - test/dummy/config/environment.rb
151
+ - test/dummy/config/routes.rb
152
+ - test/dummy/config.ru
153
+ - test/dummy/script/rails
154
+ - test/dummy/db/test.sqlite3
155
+ - test/dummy/app/views/layouts/application.html.erb
156
+ - test/dummy/app/helpers/application_helper.rb
157
+ - test/dummy/app/controllers/application_controller.rb
158
+ - test/dummy/app/assets/stylesheets/application.css
159
+ - test/dummy/app/assets/javascripts/application.js
160
+ - test/dummy/public/500.html
161
+ - test/dummy/public/422.html
162
+ - test/dummy/public/404.html
163
+ - test/dummy/public/favicon.ico
164
+ - test/dummy/Rakefile
165
+ - test/test_helper.rb