Clone into your ruby library path.
git clone git://github.com/SaturdayNeghborhoodHealthClinic/omnigollum.git
Omnigollum executes an OmniAuth::Builder proc/block to figure out which providers you've configured, then passes it on to omniauth to create the actual omniauth configuration.
To configure both omniauth and omnigollum you should add the following to your config.ru file.
require 'omnigollum'
require 'omniauth/strategies/twitter'
require 'omniauth/strategies/open_id'
options = {
# OmniAuth::Builder block is passed as a proc
:providers => Proc.new do
provider :twitter, 'CONSUMER_KEY', 'CONSUMER_SECRET'
provider :open_id, OpenID::Store::Filesystem.new('/tmp')
end,
:dummy_auth => false
}
# :omnigollum options *must* be set before the Omnigollum extension is registered
Precious::App.set(:omnigollum, options)
By default, any authenticated user will be able to access the protected routes. Restrict this by setting the authorized_users
option.
authorized_users
accepts an array of emails. Users must authenticate with one of these authorized emails in order to be allowed access.
options[:authorized_users] = ["[email protected]", "[email protected]", "[email protected]"]
Instead of setting these directly, you can use an env var, maybe like this:
# in .env, or other
# [email protected],[email protected],[email protected]
options[:authorized_users] = ENV["OMNIGOLLUM_AUTHORIZED_USERS"].split(",")
Precious::App.register Omnigollum::Sinatra
https://github.com/defunkt/mustache
Must be at v0.99.5 (currently unreleased), replace the gem version with 6c4e12d58844d99909df or the current HEAD.
Feel free to complain loudly that the maintainer should roll a new gem.
You can also (optionally) apply the patches here, to get a neat little auth status widget in the top right corner of the page https://github.com/arr2036/gollum/commit/32de2cad920ccc6e955b8e19f6e23c2b3b4c8964