2018-11-15 12:22:02 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Middleware
|
|
|
|
class EnforceHostname
|
|
|
|
def initialize(app, settings = nil)
|
|
|
|
@app = app
|
|
|
|
end
|
|
|
|
|
|
|
|
def call(env)
|
|
|
|
# enforces hostname to match the hostname of our connection
|
|
|
|
# this middleware lives after rails multisite so at this point
|
|
|
|
# Discourse.current_hostname MUST be canonical, enforce it so
|
2021-05-21 09:43:47 +08:00
|
|
|
# all Rails helpers are guaranteed to use it unconditionally and
|
2018-11-15 12:22:02 +08:00
|
|
|
# never generate incorrect links
|
|
|
|
env[Rack::Request::HTTP_X_FORWARDED_HOST] = nil
|
2020-03-20 03:54:42 +08:00
|
|
|
|
|
|
|
allowed_hostnames = RailsMultisite::ConnectionManagement.current_db_hostnames
|
|
|
|
requested_hostname = env[Rack::HTTP_HOST]
|
|
|
|
|
2021-01-29 10:14:49 +08:00
|
|
|
env[Discourse::REQUESTED_HOSTNAME] = requested_hostname
|
2022-12-22 21:13:43 +08:00
|
|
|
env[Rack::HTTP_HOST] = allowed_hostnames.find { |h| h == requested_hostname } ||
|
|
|
|
Discourse.current_hostname_with_port
|
2020-03-20 03:54:42 +08:00
|
|
|
|
2018-11-15 12:22:02 +08:00
|
|
|
@app.call(env)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|