hummingbird-me/kitsu-server

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

Summary

Maintainability
A
0 mins
Test Coverage
D
68%
module CustomControllerHelpers
  extend ActiveSupport::Concern

  included do
    include Pundit::Authorization
  end

  def serialize_error(status, message)
    {
      errors: [
        {
          status: status,
          detail: message
        }
      ]
    }
  end

  def serialize_model(model)
    resource = BaseResource.resource_for_model(model)
    serializer = JSONAPI::ResourceSerializer.new(resource)
    serializer.serialize_to_hash(resource.new(model, context))
  end

  def policy_for(model)
    Pundit.policy!(current_user, model)
  end

  def scope_for(model)
    Pundit.policy_scope!(current_user, model)
  end

  def show?(model)
    scope = model.class.where(id: model.id)
    scope_for(scope).exists?
  end

  def render_jsonapi_error(status, message)
    render_jsonapi(serialize_error(status, message), status: status)
  end

  def render_jsonapi(data, opts = {})
    render opts.merge(json: data, content_type: JSONAPI::MEDIA_TYPE)
  end

  def user
    doorkeeper_token&.resource_owner
  end

  def authenticate_user!
    render_jsonapi serialize_error(403, 'Must be logged in'), status: 403 unless user
  end
end