Sha256: 266bcdf96a87f290af0797ff010d423a1bf4fc4748c8744a08906572ee20dbd4

Contents?: true

Size: 1.53 KB

Versions: 1

Compression:

Stored size: 1.53 KB

Contents

require 'sinatra/base'

module Sinatra
  module SessionAuth

    module Helpers
      def authorized?
        session[:authorized]
      end

      def user
        session[:user]
      end

      def authorize!
        redirect '/login' unless authorized?
      end

      def logout!
        session[:authorized] = false
      end
    end

    def self.registered(app)
      app.helpers SessionAuth::Helpers

      app.set :users, {}

      app.get '/login' do
        "<h1>Please enter your login information</h1>" +
        "<form method='POST' action='/login'>" +
        "<label>Username</label>" +
        "<input type='text' name='user'>" +
        "<label>Password</label>" +
        "<input type='password' name='pass'>" +
        "<input type='submit' name='Submit'>" +
        "</form>"
      end

      app.post '/login' do
        Log.debug "Loggin: #{params.inspect}"
        if options.users.include? params[:user] and options.users[params[:user]] == params[:pass]
          Log.debug "Loggin Successful"
          session[:authorized] = true
          session[:user] = params[:user]
          session[:context] = nil
          redirect '/'
        else
          Log.debug "Loggin Failed"
          session[:authorized] = false
          session[:user] = nil
          session[:context] = nil
          redirect '/login'
        end
      end

      app.get '/logout' do
        session[:authorized] = false
        session[:user] = nil
        session[:context] = nil
        redirect '/'
      end

    end
  end

  register SessionAuth
end


Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rbbt-views-1.0.0 lib/rbbt/workflow/rest/auth.rb