# frozen_string_literal: true module Api class ActiveStorageBlobsProxyController < ApiBaseController include ActiveStorage::Streaming skip_before_action :authenticate_user! skip_authorization_check before_action :set_cors_headers before_action :set_noindex_headers def show blob_uuid, purp, exp = ApplicationRecord.signed_id_verifier.verified(params[:signed_uuid]) if blob_uuid.blank? || (purp.present? && purp != 'blob') || (exp && exp < Time.current.to_i) Rollbar.error('Blob not found') if defined?(Rollbar) return head :not_found end blob = ActiveStorage::Blob.find_by!(uuid: blob_uuid) attachment = blob.attachments.take @record = attachment.record authorization_check!(attachment) if exp.blank? if request.headers['Range'].present? send_blob_byte_range_data blob, request.headers['Range'] else http_cache_forever public: true do response.headers['Accept-Ranges'] = 'bytes' response.headers['Content-Length'] = blob.byte_size.to_s send_blob_stream blob, disposition: params[:disposition] end end end private def authorization_check!(attachment) is_authorized = attachment.name.in?(%w[logo preview_images]) || (current_user && attachment.record.account.id == current_user.account_id) || (current_user && !Docuseal.multitenant? && current_user.role == 'superadmin') || !attachment.record.account.account_configs .find_or_initialize_by(key: AccountConfig::DOWNLOAD_LINKS_AUTH_KEY).value return if is_authorized Rollbar.error('Blob aunauthorized') if defined?(Rollbar) raise CanCan::AccessDenied end end end