Sha256: fbbef77c267ea9d26456ebd1a52be272c6301da66b0f7a1dcf04c4557e8d4310

Contents?: true

Size: 1007 Bytes

Versions: 2

Compression:

Stored size: 1007 Bytes

Contents

require "alephant/logger"

module Alephant
  module Broker
    module Response
      class Asset < Base
        include Logger

        def initialize(component, request_env)
          @component = component

          @status = self.class.component_not_modified(@component.headers, request_env) ? 304 : component.status

          super(@status, component.content_type, request_env)

          @headers.merge!(@component.headers)
        end

        def setup
          @content = @component.content
          log if @component.is_a? Component
        end

        private

        def batched
          @component.batch_id.nil? ? "" : "batched"
        end

        def details
          c = @component
          "#{c.id}/#{c.options}/#{c.headers} #{batched} #{c.options}"
        end

        def log
          logger.metric "BrokerResponse#{status}"
          logger.info(
            message:  'Asset component loaded',
            status:   status
          )
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
alephant-broker-3.19.1 lib/alephant/broker/response/asset.rb
alephant-broker-3.19.0 lib/alephant/broker/response/asset.rb