cartodb-4.42/app/models/carto/overlay.rb

76 lines
2.5 KiB
Ruby
Raw Normal View History

2024-04-06 13:25:13 +08:00
require 'active_record'
module Carto
class Overlay < ActiveRecord::Base
# INFO: disable ActiveRecord inheritance column
self.inheritance_column = :_type
belongs_to :visualization
serialize :options, JSON
validates :type, presence: true
validate :unique_overlay_not_duplicated
validate :validate_user_not_viewer
before_destroy :validate_user_not_viewer
after_save :invalidate_cache
after_destroy :invalidate_cache
# There can be at most one of this types per visualization
UNIQUE_TYPES = [
'header', 'search', 'layer_selector', 'share', 'zoom', 'logo', 'loader', 'fullscreen'
].freeze
BUILDER_COMPATIBLE_TYPES = ['search', 'layer_selector', 'share', 'fullscreen', 'loader', 'logo', 'zoom'].freeze
scope :builder_incompatible, -> { where("type NOT IN ('#{BUILDER_COMPATIBLE_TYPES.join("','")}')") }
def hide
options['display'] = false
self
end
def show
options['display'] = true
self
end
def hidden?
!options['display']
end
private
def unique_overlay_not_duplicated
# This check probably belongs in visualization. See #6919
if UNIQUE_TYPES.include?(type)
other_overlay = Carto::Overlay.where(visualization_id: visualization_id, type: type)
other_overlay = other_overlay.where('id != ?', id) unless new_record?
unless other_overlay.first.nil?
errors.add(:base, "Unique overlay of type #{type} already exists")
end
end
end
def validate_user_not_viewer
# TODO: `visualization` check is needed because the creation of default overlays for visualization
# is yet done from the old models (Member). Member assigns the id (because it can't assign itself, as
# it's not a `Carto::Visualization`), but since that happens in a transaction managed by Sequel
# we can't get the `Carto::Visualization` here. When `Member` is gone the `visualization` check can
# be removed, as an `Overlay` must have a `Visualization`.
if visualization && visualization.user.viewer
errors.add(:visualization, "Viewer users can't edit overlays")
return false
end
end
def invalidate_cache
# Using `send` to avoid making it public. A future refactor should make this call unnecessary
# Visualization might not exist during creation, as the overlays are created before the visualization
visualization.try(:invalidate_after_commit)
end
end
end