discourse/app/controllers/onebox_controller.rb
Sam 41986cdb2f Refactor requires login logic, reduce duplicate code
This also corrects the positioning in the chain of the check
and removes misuse of prepend_before_action
2018-02-01 15:17:59 +11:00

37 lines
872 B
Ruby

require_dependency 'oneboxer'
class OneboxController < ApplicationController
requires_login
def show
unless params[:refresh] == 'true'
preview = Oneboxer.cached_preview(params[:url])
preview.strip! if preview.present?
return render(plain: preview) if preview.present?
end
# only 1 outgoing preview per user
return render(body: nil, status: 429) if Oneboxer.is_previewing?(current_user.id)
user_id = current_user.id
invalidate = params[:refresh] == 'true'
url = params[:url]
hijack do
Oneboxer.preview_onebox!(user_id)
preview = Oneboxer.preview(url, invalidate_oneboxes: invalidate)
preview.strip! if preview.present?
Oneboxer.onebox_previewed!(user_id)
if preview.blank?
render body: nil, status: 404
else
render plain: preview
end
end
end
end