gitlab-org--gitlab-foss/app/models/blob_viewer/base.rb

97 lines
2.5 KiB
Ruby
Raw Normal View History

2017-04-13 13:14:08 -04:00
module BlobViewer
class Base
class_attribute :partial_name, :type, :extensions, :client_side, :binary, :switcher_icon, :switcher_title, :max_size, :absolute_max_size
2017-04-13 13:14:08 -04:00
2017-04-24 10:27:19 -04:00
delegate :partial_path, :rich?, :simple?, :client_side?, :server_side?, :text?, :binary?, to: :class
2017-04-13 13:14:08 -04:00
attr_reader :blob
2017-04-21 14:59:34 -04:00
attr_accessor :override_max_size
2017-04-13 13:14:08 -04:00
def initialize(blob)
@blob = blob
end
def self.partial_path
"projects/blob/viewers/#{partial_name}"
end
def self.rich?
type == :rich
end
def self.simple?
type == :simple
end
def self.client_side?
client_side
end
2017-04-21 14:22:04 -04:00
def self.server_side?
2017-04-13 13:14:08 -04:00
!client_side?
end
def self.binary?
binary
2017-04-13 13:14:08 -04:00
end
def self.text?
!binary?
2017-04-24 10:27:19 -04:00
end
2017-04-13 13:14:08 -04:00
def self.can_render?(blob)
!extensions || extensions.include?(blob.extension)
end
2017-04-21 14:59:34 -04:00
def too_large?
blob.raw_size > max_size
2017-04-13 13:14:08 -04:00
end
2017-04-21 14:59:34 -04:00
def absolutely_too_large?
blob.raw_size > absolute_max_size
end
def can_override_max_size?
too_large? && !absolutely_too_large?
2017-04-13 13:14:08 -04:00
end
2017-04-26 16:29:12 -04:00
# This method is used on the server side to check whether we can attempt to
# render the blob at all. Human-readible error messages are found in the
# `BlobHelper#blob_render_error_reason` helper.
#
# This method does not and should not load the entire blob contents into
# memory, and should not be overridden to do so in order to validate the
# format of the blob.
#
# Prefer to implement a client-side viewer, where the JS component loads the
# binary from `blob_raw_url` and does its own format validation and error
# rendering, especially for potentially large binary formats.
2017-04-21 14:59:34 -04:00
def render_error
2017-04-26 16:48:49 -04:00
return @render_error if defined?(@render_error)
@render_error =
if server_side_but_stored_in_lfs?
# Files stored in LFS can only be rendered using a client-side viewer,
# since we do not want to read large amounts of data into memory on the
# server side. Client-side viewers use JS and can fetch the file from
# `blob_raw_url` using AJAX.
:server_side_but_stored_in_lfs
elsif override_max_size ? absolutely_too_large? : too_large?
:too_large
end
2017-04-13 13:14:08 -04:00
end
def prepare!
if server_side? && blob.project
blob.load_all_data!(blob.project.repository)
end
end
private
def server_side_but_stored_in_lfs?
2017-04-20 12:48:19 -04:00
server_side? && blob.valid_lfs_pointer?
2017-04-13 13:14:08 -04:00
end
end
end