2015-02-05 00:08:52 -05:00
|
|
|
require_dependency 'middleware/anonymous_cache'
|
|
|
|
|
|
|
|
class Middleware::RequestTracker
|
|
|
|
|
|
|
|
def initialize(app, settings={})
|
|
|
|
@app = app
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.log_request_on_site(result, env, helper=nil)
|
|
|
|
host = RailsMultisite::ConnectionManagement.host(env)
|
|
|
|
RailsMultisite::ConnectionManagement.with_hostname(host) do
|
|
|
|
log_request(result,env,helper)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
PATH_PARAMS = "action_dispatch.request.path_parameters".freeze
|
2015-02-05 22:39:04 -05:00
|
|
|
TRACK_VIEW = "HTTP_DISCOURSE_TRACK_VIEW".freeze
|
|
|
|
|
2015-02-05 00:08:52 -05:00
|
|
|
|
|
|
|
def self.log_request(result,env,helper=nil)
|
|
|
|
|
|
|
|
helper ||= Middleware::AnonymousCache::Helper.new(env)
|
|
|
|
request = Rack::Request.new(env)
|
|
|
|
|
2015-02-05 22:39:04 -05:00
|
|
|
status,headers = result
|
2015-02-05 00:08:52 -05:00
|
|
|
status = status.to_i
|
|
|
|
|
2015-02-05 22:39:04 -05:00
|
|
|
if (env[TRACK_VIEW] || (request.get? && !request.xhr? && headers["Content-Type"] =~ /text\/html/)) && status == 200
|
2015-02-05 00:08:52 -05:00
|
|
|
if helper.is_crawler?
|
2015-02-05 22:39:04 -05:00
|
|
|
ApplicationRequest.increment!(:page_view_crawler)
|
2015-02-05 00:08:52 -05:00
|
|
|
elsif helper.has_auth_cookie?
|
2015-02-05 22:39:04 -05:00
|
|
|
ApplicationRequest.increment!(:page_view_logged_in)
|
2015-02-05 00:08:52 -05:00
|
|
|
else
|
2015-02-05 22:39:04 -05:00
|
|
|
ApplicationRequest.increment!(:page_view_anon)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
ApplicationRequest.increment!(:http_total)
|
|
|
|
|
|
|
|
if status >= 500
|
|
|
|
ApplicationRequest.increment!(:http_5xx)
|
|
|
|
elsif status >= 400
|
|
|
|
ApplicationRequest.increment!(:http_4xx)
|
|
|
|
elsif status >= 300
|
|
|
|
ApplicationRequest.increment!(:http_3xx)
|
|
|
|
else
|
|
|
|
if request.path =~ /^\/message-bus\// || request.path == /\/topics\/timings/
|
|
|
|
ApplicationRequest.increment!(:http_background)
|
|
|
|
elsif status >= 200 && status < 300
|
|
|
|
ApplicationRequest.increment!(:http_2xx)
|
2015-02-05 00:08:52 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-02-05 22:39:04 -05:00
|
|
|
# rescue => ex
|
|
|
|
# Discourse.handle_exception(ex, {message: "Failed to log request"})
|
2015-02-05 00:08:52 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
def call(env)
|
|
|
|
result = @app.call(env)
|
|
|
|
ensure
|
|
|
|
Scheduler::Defer.later("Track view", _db=nil) do
|
|
|
|
self.class.log_request_on_site(result,env)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|