2017-08-30 18:38:35 -07:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-04-17 06:23:46 -07:00
|
|
|
class Api::Web::EmbedsController < Api::Web::BaseController
|
2017-08-30 18:38:35 -07:00
|
|
|
before_action :require_user!
|
|
|
|
|
|
|
|
def create
|
|
|
|
status = StatusFinder.new(params[:url]).status
|
2020-02-07 06:24:22 -08:00
|
|
|
|
|
|
|
return not_found if status.hidden?
|
|
|
|
|
2017-08-30 18:38:35 -07:00
|
|
|
render json: status, serializer: OEmbedSerializer, width: 400
|
|
|
|
rescue ActiveRecord::RecordNotFound
|
2018-05-02 09:58:48 -07:00
|
|
|
oembed = FetchOEmbedService.new.call(params[:url])
|
|
|
|
|
2020-02-07 06:24:22 -08:00
|
|
|
return not_found if oembed.nil?
|
|
|
|
|
|
|
|
begin
|
2022-03-25 18:53:34 -07:00
|
|
|
oembed[:html] = Sanitize.fragment(oembed[:html], Sanitize::Config::MASTODON_OEMBED)
|
2020-02-07 06:24:22 -08:00
|
|
|
rescue ArgumentError
|
|
|
|
return not_found
|
2018-05-02 09:58:48 -07:00
|
|
|
end
|
2020-02-07 06:24:22 -08:00
|
|
|
|
|
|
|
render json: oembed
|
2017-08-30 18:38:35 -07:00
|
|
|
end
|
|
|
|
end
|