Module: EventStore::HTTP::Session
- Included in:
- AnyMember, Leader
- Defined in:
- lib/event_store/http/session.rb,
lib/event_store/http/session/read.rb,
lib/event_store/http/session/leader.rb,
lib/event_store/http/session/factory.rb,
lib/event_store/http/session/defaults.rb,
lib/event_store/http/session/log_text.rb,
lib/event_store/http/session/any_member.rb
Defined Under Namespace
Modules: Defaults, LogText, Read
Classes: AnyMember, Factory, Leader
Class Method Summary
collapse
Instance Method Summary
collapse
Class Method Details
.build(settings = nil, namespace: nil, type: nil) ⇒ Object
16
17
18
|
# File 'lib/event_store/http/session.rb', line 16
def self.build(settings=nil, namespace: nil, type: nil)
Factory.(settings, namespace: namespace, type: type)
end
|
20
21
22
23
24
25
26
27
28
29
|
# File 'lib/event_store/http/session.rb', line 20
def self.configure(receiver, settings=nil, attr_name: nil, session: nil, **arguments)
attr_name ||= :session
if session.nil?
session = build settings, **arguments
end
receiver.public_send "#{attr_name}=", session
session
end
|
.included(cls) ⇒ Object
4
5
6
7
8
9
10
11
12
13
14
|
# File 'lib/event_store/http/session.rb', line 4
def self.included(cls)
cls.class_exec do
include Log::Dependency
dependency :connect, Connect
dependency :data_logger, Log::Data
dependency :retry, Retry
attr_writer :net_http
end
end
|
Instance Method Details
108
109
110
|
# File 'lib/event_store/http/session.rb', line 108
def configure_retry(request)
request.retry = self.retry
end
|
#establish_connection(ip_address = nil) ⇒ Object
94
95
96
97
98
99
100
101
102
103
104
105
106
|
# File 'lib/event_store/http/session.rb', line 94
def establish_connection(ip_address=nil)
data_logger.trace { "Establishing connection (IPAddress: #{ip_address || '(none)'})" }
net_http = self.retry.() do
connect.(ip_address).tap &:start
end
self.net_http = net_http
data_logger.debug { "Connection established (IPAddress: #{net_http.ip_address}, Host: #{net_http.address}, Port: #{net_http.port})" }
net_http
end
|
#net_http ⇒ Object
84
85
86
|
# File 'lib/event_store/http/session.rb', line 84
def net_http
@net_http ||= establish_connection
end
|
#reconnect(ip_address = nil) ⇒ Object
88
89
90
91
92
|
# File 'lib/event_store/http/session.rb', line 88
def reconnect(ip_address=nil)
net_http.finish if net_http.active?
establish_connection ip_address
end
|
#request(request) ⇒ Object
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
# File 'lib/event_store/http/session.rb', line 33
def request(request)
logger.trace { "Issuing request (#{LogText.request request})" }
data_logger.trace {
" Issuing request\n \n \#{request.method} \#{request.path}\n \#{LogText.header_data request}\n\n \#{LogText.body_data request}\n TEXT\n }\n\n self.retry.() do |_retry|\n begin\n response = net_http.request request\n rescue SystemCallError, IOError => error\n logger.warn \"Connection error during request; reconnecting (ErrorClass: \#{error.class}, ErrorMessage: \#{error.message})\"\n reconnect\n\n reset_request request\n\n _retry.failed error\n end\n\n logger.debug { \"Request completed (\#{LogText.request request, response})\" }\n\n data_logger.debug {\n <<~TEXT\n Request completed\n \n \#{request.method} \#{request.path}\n \#{LogText.header_data request}\n \#{LogText.body_data request}\n\n HTTP/\#{response.http_version} \#{response.code} \#{response.message}\n \#{LogText.header_data response}\n \#{LogText.body_data response}\n TEXT\n }\n\n if Net::HTTPServerError === response\n logger.warn { \"Server error (\#{LogText.request request, response})\" }\n _retry.failed\n end\n\n response\n end\nend\n"
|
#reset_request(request) ⇒ Object
112
113
114
115
|
# File 'lib/event_store/http/session.rb', line 112
def reset_request(request)
request['host'] = nil
request['connection'] = nil
end
|