Skip to content

Instantly share code, notes, and snippets.

@aaronpk
Forked from troelskn/app.rb
Created November 28, 2012 12:07
Show Gist options
  • Save aaronpk/4160761 to your computer and use it in GitHub Desktop.
Save aaronpk/4160761 to your computer and use it in GitHub Desktop.
Gollum protected by HTTP Basic
require 'gollum/frontend/app'
require 'digest/sha1'
class App < Precious::App
User = Struct.new(:name, :email, :password_hash)
before { authenticate! }
helpers do
def authenticate!
@_auth ||= Rack::Auth::Basic::Request.new(request.env)
if @_auth.provided?
end
if @_auth.provided? && @_auth.basic? && @_auth.credentials &&
@user = detected_user(@_auth.credentials)
return @user
else
response['WWW-Authenticate'] = %(Basic realm="Gollum Wiki")
throw(:halt, [401, "Not authorized\n"])
end
end
def users
@_users ||= settings.authorized_users.map {|u| User.new(*u) }
end
def detected_user(credentials)
users.detect do |u|
[u.email, u.password_hash] ==
[credentials[0], Digest::SHA1.hexdigest(credentials[1])]
end
end
end
def commit_message
{
:message => params[:message],
:name => @user.name,
:email => @user.email
}
end
end
__DIR__ = File.expand_path(File.dirname(__FILE__))
$: << __DIR__
require 'rubygems'
require 'yaml'
require 'app'
App.set(:gollum_path, __DIR__ + "/wikidata")
App.set(:authorized_users, YAML.load_file(File.expand_path('users.yml', __DIR__)))
App.set(:wiki_options, {})
run App
#!/bin/bash
rackup -p 4567 config.ru
---
- - User Name
- [email protected]
- `puts Digest::SHA1.hexdigest('password')`
- - Another User
- [email protected]
- `puts Digest::SHA1.hexdigest('p455w0rd')`
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment