Merge Previews/Variants controller into one Representations controller.

Since ActiveStorage::Blob::Representable unifies the idea of previews and
variants under one roof as representation, we may as well have the
controllers follow suit.

Thus ActiveStorage::RepresenationsController enters the fray. I've copied
the old tests for both previews and variants and unified those as well.
This commit is contained in:
Kasper Timm Hansen 2018-03-03 21:36:43 +01:00
parent 6932998fc7
commit 0f302b8970
No known key found for this signature in database
GPG Key ID: 191153215EDA53D8
7 changed files with 74 additions and 100 deletions

View File

@ -1,10 +0,0 @@
# frozen_string_literal: true
class ActiveStorage::PreviewsController < ActionController::Base
include ActiveStorage::SetBlob
def show
expires_in ActiveStorage::Blob.service.url_expires_in
redirect_to ActiveStorage::Preview.new(@blob, params[:variation_key]).processed.service_url(disposition: params[:disposition])
end
end

View File

@ -1,14 +1,14 @@
# frozen_string_literal: true
# Take a signed permanent reference for a variant and turn it into an expiring service URL for download.
# Take a signed permanent reference for a blob representation and turn it into an expiring service URL for download.
# Note: These URLs are publicly accessible. If you need to enforce access protection beyond the
# security-through-obscurity factor of the signed blob and variation reference, you'll need to implement your own
# authenticated redirection controller.
class ActiveStorage::VariantsController < ActionController::Base
class ActiveStorage::RepresentationsController < ActionController::Base
include ActiveStorage::SetBlob
def show
expires_in ActiveStorage::Blob.service.url_expires_in
redirect_to ActiveStorage::Variant.new(@blob, params[:variation_key]).processed.service_url(disposition: params[:disposition])
redirect_to @blob.representation(params[:variation_key]).processed.service_url(disposition: params[:disposition])
end
end

View File

@ -27,7 +27,7 @@ module ActiveStorage::Blob::Representable
# variable, call ActiveStorage::Blob#variable?.
def variant(transformations)
if variable?
ActiveStorage::Variant.new(self, ActiveStorage::Variation.wrap(transformations))
ActiveStorage::Variant.new(self, transformations)
else
raise ActiveStorage::InvariableError
end
@ -55,7 +55,7 @@ module ActiveStorage::Blob::Representable
# whether a blob is accepted by any previewer, call ActiveStorage::Blob#previewable?.
def preview(transformations)
if previewable?
ActiveStorage::Preview.new(self, ActiveStorage::Variation.wrap(transformations))
ActiveStorage::Preview.new(self, transformations)
else
raise ActiveStorage::UnpreviewableError
end

View File

@ -11,30 +11,18 @@ Rails.application.routes.draw do
resolve("ActiveStorage::Attachment") { |attachment, options| route_for(:rails_blob, attachment.blob, options) }
get "/rails/active_storage/variants/:signed_blob_id/:variation_key/*filename" => "active_storage/variants#show", as: :rails_blob_variation
get "/rails/active_storage/representations/:signed_blob_id/:variation_key/*filename" => "active_storage/representations#show", as: :rails_blob_representation
direct :rails_variant do |variant, options|
signed_blob_id = variant.blob.signed_id
variation_key = variant.variation.key
filename = variant.blob.filename
direct :rails_representation do |representation, options|
signed_blob_id = representation.blob.signed_id
variation_key = representation.variation.key
filename = representation.blob.filename
route_for(:rails_blob_variation, signed_blob_id, variation_key, filename, options)
route_for(:rails_blob_representation, signed_blob_id, variation_key, filename, options)
end
resolve("ActiveStorage::Variant") { |variant, options| route_for(:rails_variant, variant, options) }
get "/rails/active_storage/previews/:signed_blob_id/:variation_key/*filename" => "active_storage/previews#show", as: :rails_blob_preview
direct :rails_preview do |preview, options|
signed_blob_id = preview.blob.signed_id
variation_key = preview.variation.key
filename = preview.blob.filename
route_for(:rails_blob_preview, signed_blob_id, variation_key, filename, options)
end
resolve("ActiveStorage::Preview") { |preview, options| route_for(:rails_preview, preview, options) }
resolve("ActiveStorage::Variant") { |variant, options| route_for(:rails_representation, variant, options) }
resolve("ActiveStorage::Preview") { |preview, options| route_for(:rails_representation, preview, options) }
get "/rails/active_storage/disk/:encoded_key/*filename" => "active_storage/disk#show", as: :rails_disk_service

View File

@ -1,33 +0,0 @@
# frozen_string_literal: true
require "test_helper"
require "database/setup"
class ActiveStorage::PreviewsControllerTest < ActionDispatch::IntegrationTest
setup do
@blob = create_file_blob filename: "report.pdf", content_type: "application/pdf"
end
test "showing preview inline" do
get rails_blob_preview_url(
filename: @blob.filename,
signed_blob_id: @blob.signed_id,
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_predicate @blob.preview_image, :attached?
assert_redirected_to(/report\.png\?.*disposition=inline/)
image = read_image(@blob.preview_image.variant(resize: "100x100"))
assert_equal 77, image.width
assert_equal 100, image.height
end
test "showing preview with invalid signed blob ID" do
get rails_blob_preview_url(
filename: @blob.filename,
signed_blob_id: "invalid",
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_response :not_found
end
end

View File

@ -0,0 +1,61 @@
# frozen_string_literal: true
require "test_helper"
require "database/setup"
class ActiveStorage::RepresentationsControllerWithVariantsTest < ActionDispatch::IntegrationTest
setup do
@blob = create_file_blob filename: "racecar.jpg"
end
test "showing variant inline" do
get rails_blob_representation_url(
filename: @blob.filename,
signed_blob_id: @blob.signed_id,
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_redirected_to(/racecar\.jpg\?.*disposition=inline/)
image = read_image(@blob.variant(resize: "100x100"))
assert_equal 100, image.width
assert_equal 67, image.height
end
test "showing variant with invalid signed blob ID" do
get rails_blob_representation_url(
filename: @blob.filename,
signed_blob_id: "invalid",
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_response :not_found
end
end
class ActiveStorage::RepresentationsControllerWithPreviewsTest < ActionDispatch::IntegrationTest
setup do
@blob = create_file_blob filename: "report.pdf", content_type: "application/pdf"
end
test "showing preview inline" do
get rails_blob_representation_url(
filename: @blob.filename,
signed_blob_id: @blob.signed_id,
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_predicate @blob.preview_image, :attached?
assert_redirected_to(/report\.png\?.*disposition=inline/)
image = read_image(@blob.preview_image.variant(resize: "100x100"))
assert_equal 77, image.width
assert_equal 100, image.height
end
test "showing preview with invalid signed blob ID" do
get rails_blob_representation_url(
filename: @blob.filename,
signed_blob_id: "invalid",
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_response :not_found
end
end

View File

@ -1,32 +0,0 @@
# frozen_string_literal: true
require "test_helper"
require "database/setup"
class ActiveStorage::VariantsControllerTest < ActionDispatch::IntegrationTest
setup do
@blob = create_file_blob filename: "racecar.jpg"
end
test "showing variant inline" do
get rails_blob_variation_url(
filename: @blob.filename,
signed_blob_id: @blob.signed_id,
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_redirected_to(/racecar\.jpg\?.*disposition=inline/)
image = read_image(@blob.variant(resize: "100x100"))
assert_equal 100, image.width
assert_equal 67, image.height
end
test "showing variant with invalid signed blob ID" do
get rails_blob_variation_url(
filename: @blob.filename,
signed_blob_id: "invalid",
variation_key: ActiveStorage::Variation.encode(resize: "100x100"))
assert_response :not_found
end
end