class StylesheetsController < ApplicationController skip_before_filter :preload_json, :redirect_to_login_if_required, :check_xhr, :verify_authenticity_token, only: [:show] def show no_cookies target,digest = params[:name].split(/_([a-f0-9]{40})/) cache_time = request.env["HTTP_IF_MODIFIED_SINCE"] cache_time = Time.rfc2822(cache_time) rescue nil if cache_time query = StylesheetCache.where(target: target) if digest query = query.where(digest: digest) else query = query.order('id desc') end # Security note, safe due to route constraint underscore_digest = digest ? "_" + digest : "" location = "#{Rails.root}/#{DiscourseStylesheets::CACHE_PATH}/#{target}#{underscore_digest}.css" stylesheet_time = query.pluck(:created_at).first if !stylesheet_time handle_missing_cache(location, target, digest) end if cache_time && stylesheet_time && stylesheet_time <= cache_time return render nothing: true, status: 304 end unless File.exist?(location) if current = query.first File.write(location, current.content) else raise Discourse::NotFound end end response.headers['Last-Modified'] = stylesheet_time.httpdate if stylesheet_time expires_in 1.year, public: true unless Rails.env == "development" send_file(location, disposition: :inline) end protected def handle_missing_cache(location, name, digest) existing = File.read(location) rescue nil if existing && digest StylesheetCache.add(name, digest, existing) end end end