Class: UU::OS::Application::StatisticsMiddleware
- Inherits:
-
Server::AbstractMiddleware
show all
- Defined in:
- uu_os_application-server-2.7.3/lib/uu/os/application/statistics_middleware.rb
Constant Summary
- @@statistics =
UU::OS::Util::ServerStatistics.new(15)
Class Method Summary
(collapse)
Instance Method Summary
(collapse)
#initialize
Class Method Details
+ (Object) statistics
12
13
14
|
# File 'uu_os_application-server-2.7.3/lib/uu/os/application/statistics_middleware.rb', line 12
def self.statistics
@@statistics
end
|
Instance Method Details
- (Object) call(env)
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
# File 'uu_os_application-server-2.7.3/lib/uu/os/application/statistics_middleware.rb', line 16
def call(env)
start = Time.now
result = nil
begin
@@statistics.begin_request
result = @app.call(env)
rescue Exception => e
result = e
end
duration = ((Time.now - start) * 1000000000).round(0)
status = nil
if result.kind_of?(Exception)
status = result.status if result.respond_to?(:status)
status ||= 500
else
status = result[0]
end
if status >= 500
@@statistics.record_server_error(duration)
elsif status >= 400
@@statistics.record_client_error(duration)
else
@@statistics.record_request(duration)
end
if result.kind_of?(Exception)
raise result
else
return result
end
end
|