hicknhack-software/redmine_hourglass

View on GitHub
app/controllers/concerns/authorization_concern.rb

Summary

Maintainability
A
0 mins
Test Coverage
module AuthorizationConcern
  extend ActiveSupport::Concern

  included do
    include Pundit

    rescue_from(Pundit::NotAuthorizedError) do |e|
      render_403 message: e.policy.message, no_halt: true
    end

    def pundit_user
      User.current
    end

    def authorize(record, query = nil)
      super
      record
    end

    def authorize_update(record, params)
      authorize record
      record.transaction do
        record.with_before_save proc { authorize record } do
          record.update params
        end
      end
      record
    end
  end
end