# frozen_string_literal: true # This Rack middleware is intended to proxy the webpack assets directory to the # webpack-dev-server. It is only intended for use in development. # :nocov: module Gitlab module Webpack class DevServerMiddleware < Rack::Proxy def initialize(app = nil, opts = {}) @proxy_host = opts.fetch(:proxy_host, 'localhost') @proxy_port = opts.fetch(:proxy_port, 3808) @proxy_path = opts[:proxy_path] if opts[:proxy_path] @proxy_scheme = opts[:proxy_https] ? 'https' : 'http' super(app, backend: "#{@proxy_scheme}://#{@proxy_host}:#{@proxy_port}", **opts) end def perform_request(env) if @proxy_path && env['PATH_INFO'].start_with?("/#{@proxy_path}") # disable SSL check since any cert used here will likely be self-signed env['rack.ssl_verify_none'] = true # ensure we pass the expected Host header so webpack-dev-server doesn't complain env['HTTP_HOST'] = "#{@proxy_host}:#{@proxy_port}" if relative_url_root = Rails.application.config.relative_url_root env['SCRIPT_NAME'] = "" env['REQUEST_PATH'].sub!(/\A#{Regexp.escape(relative_url_root)}/, '') end super(env) else @app.call(env) end end end end end # :nocov: