# frozen_string_literal: true require 'ditty/models/user' require 'ditty/models/role' require 'ditty/models/identity' module Ditty module Helpers module Authentication def current_user return nil if current_user_id.nil? @current_user ||= User[current_user_id] end def current_user=(user) env['rack.session'] = {} if env['rack.session'].nil? env['rack.session']['user_id'] = user.id if user @current_user = user end def current_user_id return env['rack.session']['user_id'] if env['rack.session'] env['omniauth.auth'].uid if env['omniauth.auth'] end def authenticate authenticated? end def authenticated? current_user && !current_user.role?('anonymous') end def authenticate! raise NotAuthenticated unless authenticated? true end def logout env['rack.session'].delete('user_id') unless env['rack.session'].nil? env.delete('omniauth.auth') end end class NotAuthenticated < StandardError end end end