Sha256: d38294071276e9ca9a6e63e571c309a552c46f8f9a274959ce5c80aa9ee536e0

Contents?: true

Size: 915 Bytes

Versions: 2

Compression:

Stored size: 915 Bytes

Contents

require 'alephant/logger'

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

        def initialize(component, request_env)
          @component = component

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

          super @status

          @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 "Broker: Component loaded! #{details} (200)"
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
alephant-broker-3.10.1 lib/alephant/broker/response/asset.rb
alephant-broker-3.10.0 lib/alephant/broker/response/asset.rb