A Padrino (github.com/padrino/padrino-framework) module that provides authentication for your Padrino application through Warden (github.com/hassox/warden).
Most of the code was adapted from sinatra_warden (github.com/jsmestad/sinatra_warden)
Currently padrino-warden uses password
as default authentication strategy. If you wish to change that consult Warden (github.com/hassox/warden).
class SampleApp < Padrino::Application configure do ## # Application-specific configuration options # end
register Padrino::Warden
class User attr_reader :name def initialize(name) @name=name end
def self.authenticate(a, b) return User.new(‘john’) end end
Warden::Strategies.add(:password) do def valid? params || params end
def authenticate! u = User.authenticate(params, params) u.nil? ? fail!(“Could not log in”) : success!(u) end end
Warden::Manager.serialize_into_session do |user| user.id end
Warden::Manager.serialize_from_session do |id| User.get(id) end
end
Run this to see your new routes:
$ padrino rake routes
You can now login at localhost/sessions/login
After login you can fiddle with current_user
for anything you need.
NOTE: Try to make all helpers compatable with padrino admin generator AuthenticationHelpers so the over all project authethication to be possible by Warden
-
Fork the project.
-
Make your feature addition or bug fix.
-
Add tests for it. This is important so I don’t break it in a future version unintentionally.
-
Commit, do not mess with rakefile, version, or history. (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)
-
Send me a pull request. Bonus points for topic branches.
-
Dotan Nahum (github.com/jondot)
For sinatra_warden, thanks to: Justin Smestad (github.com/jsmestad), Daniel Neighman (github.com/hassox), Shane Hanna (github.com/shanna)
Copyright © 2010 Dotan Nahum (jondot). See LICENSE for details.