OmniAuth IndieAuth

This is an OmniAuth strategy for using IndieAuth.com as an authentication server.

Basic Usage

use OmniAuth::Builder do
  provider :indieauth, :client_id => 'http://example.com'
end

Using a Custom Auth Server

use OmniAuth::Builder do
  provider :indieauth, :client_id => 'http://example.com', :server => 'https://indieauth.com'
end

Profile Info

After the user signs in, the uid reported by OmniAuth will be their URL they entered. The gem will also attempt to parse their URL for an h-card, and return their real name and profile image if available.

{
  "url": "http://aaronparecki.com/",
  "name": "Aaron Parecki",
  "image": "https://aaronparecki.com/images/aaronpk.png"
}

Basic Sinatra Example

require 'bundler/setup'
require 'sinatra/base'
require 'omniauth-indieauth'

use Rack::Session::Cookie, :secret => "change_me"

use OmniAuth::Builder do
  provider :indieauth, :client_id => 'http://example.com'
end

class App < Sinatra::Base
  get '/' do
    <<-HTML
    <ul>
      <li><a href='/auth/indieauth'>Sign in with IndieAuth</a></li>
    </ul>
    HTML
  end

  get '/auth/:provider/callback' do
    request.env['omniauth.auth'].info.to_hash.inspect
    "<h1>Signed in!</h1>
    <pre>#{request.env['omniauth.auth'].uid}</pre>
    <pre>#{request.env['omniauth.auth'].info.to_hash.inspect}</pre>
    "
  end
end

run App.new

License

Copyright 2014 by Aaron Parecki

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.