evt-event_store-http 0.0.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/lib/event_store/http/cluster/member_state.rb +28 -0
- data/lib/event_store/http/connect/defaults.rb +11 -0
- data/lib/event_store/http/connect/leader.rb +37 -0
- data/lib/event_store/http/connect.rb +69 -0
- data/lib/event_store/http/controls/cluster/current_members.rb +52 -0
- data/lib/event_store/http/controls/cluster/size.rb +13 -0
- data/lib/event_store/http/controls/event.rb +43 -0
- data/lib/event_store/http/controls/gossip/response/json.rb +91 -0
- data/lib/event_store/http/controls/gossip/response/member.rb +114 -0
- data/lib/event_store/http/controls/gossip/response.rb +17 -0
- data/lib/event_store/http/controls/hostname/cluster.rb +67 -0
- data/lib/event_store/http/controls/hostname/resolution.rb +61 -0
- data/lib/event_store/http/controls/hostname.rb +35 -0
- data/lib/event_store/http/controls/info/response/json.rb +25 -0
- data/lib/event_store/http/controls/info/response.rb +21 -0
- data/lib/event_store/http/controls/ip_address/cluster.rb +77 -0
- data/lib/event_store/http/controls/ip_address.rb +23 -0
- data/lib/event_store/http/controls/json.rb +27 -0
- data/lib/event_store/http/controls/media_types/atom/event/content.rb +47 -0
- data/lib/event_store/http/controls/media_types/atom/event/json.rb +52 -0
- data/lib/event_store/http/controls/media_types/atom/event/links.rb +28 -0
- data/lib/event_store/http/controls/media_types/atom/event.rb +46 -0
- data/lib/event_store/http/controls/media_types/atom/page/entries.rb +131 -0
- data/lib/event_store/http/controls/media_types/atom/page/json/backward.rb +115 -0
- data/lib/event_store/http/controls/media_types/atom/page/json/embed/body.rb +150 -0
- data/lib/event_store/http/controls/media_types/atom/page/json/embed/rich.rb +144 -0
- data/lib/event_store/http/controls/media_types/atom/page/json.rb +113 -0
- data/lib/event_store/http/controls/media_types/atom/page/links.rb +70 -0
- data/lib/event_store/http/controls/media_types/atom/page.rb +43 -0
- data/lib/event_store/http/controls/media_types/events/json.rb +25 -0
- data/lib/event_store/http/controls/media_types/events.rb +39 -0
- data/lib/event_store/http/controls/net_http/host_header.rb +41 -0
- data/lib/event_store/http/controls/net_http/request/post.rb +36 -0
- data/lib/event_store/http/controls/net_http/request.rb +13 -0
- data/lib/event_store/http/controls/net_http.rb +14 -0
- data/lib/event_store/http/controls/port.rb +29 -0
- data/lib/event_store/http/controls/read_event/output_schema.rb +43 -0
- data/lib/event_store/http/controls/read_stream/output_schema/optimized.rb +66 -0
- data/lib/event_store/http/controls/read_stream/output_schema.rb +50 -0
- data/lib/event_store/http/controls/session_type.rb +15 -0
- data/lib/event_store/http/controls/stream.rb +17 -0
- data/lib/event_store/http/controls/time.rb +7 -0
- data/lib/event_store/http/controls/uri/event.rb +24 -0
- data/lib/event_store/http/controls/uuid.rb +7 -0
- data/lib/event_store/http/controls/write.rb +22 -0
- data/lib/event_store/http/controls.rb +59 -0
- data/lib/event_store/http/gossip/response/member.rb +40 -0
- data/lib/event_store/http/gossip/response/transformer.rb +49 -0
- data/lib/event_store/http/gossip/response.rb +25 -0
- data/lib/event_store/http/gossip.rb +28 -0
- data/lib/event_store/http/info/response/transformer.rb +28 -0
- data/lib/event_store/http/info/response.rb +25 -0
- data/lib/event_store/http/info.rb +28 -0
- data/lib/event_store/http/json/deserialize.rb +25 -0
- data/lib/event_store/http/json/serialize.rb +20 -0
- data/lib/event_store/http/log.rb +20 -0
- data/lib/event_store/http/media_types/atom/event/transformer.rb +44 -0
- data/lib/event_store/http/media_types/atom/event.rb +28 -0
- data/lib/event_store/http/media_types/atom/links.rb +18 -0
- data/lib/event_store/http/media_types/atom/page/embed/body/transformer.rb +43 -0
- data/lib/event_store/http/media_types/atom/page/embed/none/transformer.rb +45 -0
- data/lib/event_store/http/media_types/atom/page/embed/rich/event.rb +33 -0
- data/lib/event_store/http/media_types/atom/page/embed/rich/transformer.rb +63 -0
- data/lib/event_store/http/media_types/atom/page/transformer.rb +11 -0
- data/lib/event_store/http/media_types/atom/page.rb +17 -0
- data/lib/event_store/http/media_types/atom.rb +11 -0
- data/lib/event_store/http/media_types/events/data.rb +46 -0
- data/lib/event_store/http/media_types/events.rb +11 -0
- data/lib/event_store/http/net_http/extensions.rb +34 -0
- data/lib/event_store/http/net_http/substitute/telemetry.rb +19 -0
- data/lib/event_store/http/net_http/substitute.rb +112 -0
- data/lib/event_store/http/net_http.rb +11 -0
- data/lib/event_store/http/read_event/log_text.rb +17 -0
- data/lib/event_store/http/read_event/substitute.rb +35 -0
- data/lib/event_store/http/read_event.rb +72 -0
- data/lib/event_store/http/read_stream/defaults.rb +31 -0
- data/lib/event_store/http/read_stream/log_text.rb +17 -0
- data/lib/event_store/http/read_stream/substitute.rb +90 -0
- data/lib/event_store/http/read_stream.rb +100 -0
- data/lib/event_store/http/request.rb +48 -0
- data/lib/event_store/http/retry/substitute.rb +44 -0
- data/lib/event_store/http/retry/telemetry.rb +15 -0
- data/lib/event_store/http/retry.rb +98 -0
- data/lib/event_store/http/session/any_member.rb +9 -0
- data/lib/event_store/http/session/defaults.rb +11 -0
- data/lib/event_store/http/session/factory.rb +74 -0
- data/lib/event_store/http/session/leader.rb +33 -0
- data/lib/event_store/http/session/log_text.rb +41 -0
- data/lib/event_store/http/session/read.rb +22 -0
- data/lib/event_store/http/session.rb +100 -0
- data/lib/event_store/http/settings/read.rb +29 -0
- data/lib/event_store/http/settings.rb +27 -0
- data/lib/event_store/http/write/log_text.rb +17 -0
- data/lib/event_store/http/write/substitute.rb +52 -0
- data/lib/event_store/http/write.rb +82 -0
- data/lib/event_store/http.rb +77 -0
- metadata +237 -0
@@ -0,0 +1,29 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module Port
|
5
|
+
def self.example
|
6
|
+
2113
|
7
|
+
end
|
8
|
+
|
9
|
+
module Internal
|
10
|
+
def self.example
|
11
|
+
2112
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
module TCP
|
16
|
+
def self.example
|
17
|
+
1113
|
18
|
+
end
|
19
|
+
|
20
|
+
module Internal
|
21
|
+
def self.example
|
22
|
+
1112
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module ReadEvent
|
5
|
+
module OutputSchema
|
6
|
+
def self.example
|
7
|
+
self
|
8
|
+
end
|
9
|
+
|
10
|
+
module Result
|
11
|
+
def self.example
|
12
|
+
{
|
13
|
+
:type => Event::Type.example,
|
14
|
+
:data => Event::Data.example
|
15
|
+
}
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
module Transformer
|
20
|
+
def self.json
|
21
|
+
JSON
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.instance(raw_data)
|
25
|
+
content = raw_data.fetch :content
|
26
|
+
|
27
|
+
type = content.fetch :eventType
|
28
|
+
data = Casing::Underscore.(content.fetch(:data))
|
29
|
+
|
30
|
+
{ :type => type, :data => data }
|
31
|
+
end
|
32
|
+
|
33
|
+
module JSON
|
34
|
+
def self.read(text)
|
35
|
+
::JSON.parse text, symbolize_names: true
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module ReadStream
|
5
|
+
module OutputSchema
|
6
|
+
module Optimized
|
7
|
+
def self.example
|
8
|
+
self
|
9
|
+
end
|
10
|
+
|
11
|
+
module Event
|
12
|
+
def self.example(id: nil, stream: nil, position: nil, global_position: nil)
|
13
|
+
position ||= 0
|
14
|
+
global_position ||= position
|
15
|
+
id ||= Controls::Event::ID.example position
|
16
|
+
stream ||= Stream.example
|
17
|
+
|
18
|
+
type = Controls::Event::Type.example
|
19
|
+
data = Controls::Event::Data.example position
|
20
|
+
metadata = Controls::Event::Metadata.example position
|
21
|
+
|
22
|
+
Example.new id, type, data, metadata, stream, position, global_position
|
23
|
+
end
|
24
|
+
|
25
|
+
Example = Struct.new :id, :type, :data, :metadata, :stream, :position, :global_position
|
26
|
+
end
|
27
|
+
|
28
|
+
module Transformer
|
29
|
+
def self.json
|
30
|
+
JSON
|
31
|
+
end
|
32
|
+
|
33
|
+
def self.instance(raw_data)
|
34
|
+
raw_data.fetch('entries').map do |entry|
|
35
|
+
id = entry.fetch 'eventId'
|
36
|
+
type = entry.fetch 'eventType'
|
37
|
+
stream = entry.fetch 'streamId'
|
38
|
+
position = entry.fetch 'eventNumber'
|
39
|
+
global_position = entry.fetch 'positionEventNumber'
|
40
|
+
|
41
|
+
data_text = entry.fetch 'data'
|
42
|
+
data = EventStore::HTTP::JSON::Deserialize.(data_text)
|
43
|
+
|
44
|
+
metadata_text = entry['metaData']
|
45
|
+
metadata_text = nil if metadata_text == ''
|
46
|
+
|
47
|
+
unless metadata_text.nil?
|
48
|
+
metadata = EventStore::HTTP::JSON::Deserialize.(metadata_text)
|
49
|
+
end
|
50
|
+
|
51
|
+
Event::Example.new id, type, data, metadata, stream, position, global_position
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
module JSON
|
56
|
+
def self.read(text)
|
57
|
+
::JSON.parse text
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module ReadStream
|
5
|
+
module OutputSchema
|
6
|
+
def self.example
|
7
|
+
self
|
8
|
+
end
|
9
|
+
|
10
|
+
module Result
|
11
|
+
def self.example(events: nil, stream: nil)
|
12
|
+
events ||= 1
|
13
|
+
|
14
|
+
(0...events).to_a.reverse.map do |position|
|
15
|
+
URI::Event.raw stream: stream, position: position
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
module Transformer
|
21
|
+
def self.json
|
22
|
+
JSON
|
23
|
+
end
|
24
|
+
|
25
|
+
def self.instance(raw_data)
|
26
|
+
raw_data.fetch('entries').map do |entry|
|
27
|
+
edit_link = nil
|
28
|
+
|
29
|
+
entry['links'].each do |link|
|
30
|
+
if link.fetch('relation') == 'edit'
|
31
|
+
edit_link = link.fetch 'uri'
|
32
|
+
break
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
edit_link
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
module JSON
|
41
|
+
def self.read(text)
|
42
|
+
::JSON.parse text
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module Stream
|
5
|
+
def self.example(random: nil)
|
6
|
+
random = true if random.nil?
|
7
|
+
|
8
|
+
if random
|
9
|
+
"testStream-#{Identifier::UUID::Random.get}"
|
10
|
+
else
|
11
|
+
"testStream"
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module URI
|
5
|
+
module Event
|
6
|
+
def self.example(stream: nil, position: nil)
|
7
|
+
stream ||= Stream.example
|
8
|
+
position ||= 0
|
9
|
+
|
10
|
+
ip_address = IPAddress.example
|
11
|
+
port = Port.example
|
12
|
+
|
13
|
+
::URI.parse "http://#{ip_address}:#{port}/streams/#{stream}/#{position}"
|
14
|
+
end
|
15
|
+
|
16
|
+
def self.raw(stream: nil, position: nil)
|
17
|
+
uri = example stream: stream, position: position
|
18
|
+
uri.to_s
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module Controls
|
4
|
+
module Write
|
5
|
+
def self.call(events: nil, stream: nil, session: nil, metadata: nil)
|
6
|
+
stream ||= Stream.example
|
7
|
+
events ||= 1
|
8
|
+
|
9
|
+
batch = MediaTypes::Events.example(
|
10
|
+
batch_size: events,
|
11
|
+
metadata: metadata,
|
12
|
+
random: true
|
13
|
+
)
|
14
|
+
|
15
|
+
EventStore::HTTP::Write.(batch, stream, session: session)
|
16
|
+
|
17
|
+
return stream, batch
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
require 'erb'
|
2
|
+
require 'resolv'
|
3
|
+
require 'tempfile'
|
4
|
+
|
5
|
+
require 'clock/controls'
|
6
|
+
require 'identifier/uuid/controls'
|
7
|
+
|
8
|
+
require 'event_store/http/controls/json'
|
9
|
+
require 'event_store/http/controls/time'
|
10
|
+
require 'event_store/http/controls/uuid'
|
11
|
+
|
12
|
+
require 'event_store/http/controls/hostname'
|
13
|
+
require 'event_store/http/controls/hostname/resolution'
|
14
|
+
require 'event_store/http/controls/hostname/cluster'
|
15
|
+
require 'event_store/http/controls/ip_address'
|
16
|
+
require 'event_store/http/controls/ip_address/cluster'
|
17
|
+
require 'event_store/http/controls/port'
|
18
|
+
|
19
|
+
require 'event_store/http/controls/net_http'
|
20
|
+
require 'event_store/http/controls/net_http/host_header'
|
21
|
+
require 'event_store/http/controls/net_http/request'
|
22
|
+
require 'event_store/http/controls/net_http/request/post'
|
23
|
+
|
24
|
+
require 'event_store/http/controls/cluster/size'
|
25
|
+
require 'event_store/http/controls/cluster/current_members'
|
26
|
+
|
27
|
+
require 'event_store/http/controls/event'
|
28
|
+
require 'event_store/http/controls/session_type'
|
29
|
+
require 'event_store/http/controls/stream'
|
30
|
+
require 'event_store/http/controls/uri/event'
|
31
|
+
|
32
|
+
require 'event_store/http/controls/info/response'
|
33
|
+
require 'event_store/http/controls/info/response/json'
|
34
|
+
|
35
|
+
require 'event_store/http/controls/gossip/response'
|
36
|
+
require 'event_store/http/controls/gossip/response/json'
|
37
|
+
require 'event_store/http/controls/gossip/response/member'
|
38
|
+
|
39
|
+
require 'event_store/http/controls/read_event/output_schema'
|
40
|
+
require 'event_store/http/controls/read_stream/output_schema'
|
41
|
+
require 'event_store/http/controls/read_stream/output_schema/optimized'
|
42
|
+
|
43
|
+
require 'event_store/http/controls/media_types/atom/event'
|
44
|
+
require 'event_store/http/controls/media_types/atom/event/content'
|
45
|
+
require 'event_store/http/controls/media_types/atom/event/json'
|
46
|
+
require 'event_store/http/controls/media_types/atom/event/links'
|
47
|
+
|
48
|
+
require 'event_store/http/controls/media_types/atom/page'
|
49
|
+
require 'event_store/http/controls/media_types/atom/page/entries'
|
50
|
+
require 'event_store/http/controls/media_types/atom/page/json'
|
51
|
+
require 'event_store/http/controls/media_types/atom/page/json/backward'
|
52
|
+
require 'event_store/http/controls/media_types/atom/page/json/embed/body'
|
53
|
+
require 'event_store/http/controls/media_types/atom/page/json/embed/rich'
|
54
|
+
require 'event_store/http/controls/media_types/atom/page/links'
|
55
|
+
|
56
|
+
require 'event_store/http/controls/media_types/events'
|
57
|
+
require 'event_store/http/controls/media_types/events/json'
|
58
|
+
|
59
|
+
require 'event_store/http/controls/write'
|
@@ -0,0 +1,40 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Gossip
|
4
|
+
class Response
|
5
|
+
class Member
|
6
|
+
include Schema::DataStructure
|
7
|
+
|
8
|
+
attribute :instance_id, String
|
9
|
+
attribute :time_stamp, String
|
10
|
+
attribute :state, String
|
11
|
+
attribute :is_alive
|
12
|
+
|
13
|
+
attribute :internal_tcp_ip, String
|
14
|
+
attribute :internal_tcp_port, Integer
|
15
|
+
attribute :internal_secure_tcp_port, Integer
|
16
|
+
|
17
|
+
attribute :external_tcp_ip, String
|
18
|
+
attribute :external_tcp_port, Integer
|
19
|
+
attribute :external_secure_tcp_port, Integer
|
20
|
+
|
21
|
+
attribute :internal_http_ip, String
|
22
|
+
attribute :internal_http_port, Integer
|
23
|
+
|
24
|
+
attribute :external_http_ip, String
|
25
|
+
attribute :external_http_port, Integer
|
26
|
+
|
27
|
+
attribute :last_commit_position, Integer
|
28
|
+
attribute :writer_checkpoint, Integer
|
29
|
+
attribute :chaser_checkpoint, Integer
|
30
|
+
|
31
|
+
attribute :epoch_position, Integer
|
32
|
+
attribute :epoch_number, Integer
|
33
|
+
attribute :epoch_id, String
|
34
|
+
|
35
|
+
attribute :node_priority, Integer
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Gossip
|
4
|
+
class Response
|
5
|
+
module Transformer
|
6
|
+
def self.json
|
7
|
+
JSON
|
8
|
+
end
|
9
|
+
|
10
|
+
def self.instance(raw_data)
|
11
|
+
response = Response.new
|
12
|
+
|
13
|
+
SetAttributes.(response, raw_data)
|
14
|
+
|
15
|
+
raw_data[:members].each do |member_data|
|
16
|
+
member = member_instance member_data
|
17
|
+
|
18
|
+
response.add_member member
|
19
|
+
end
|
20
|
+
|
21
|
+
response
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.member_instance(member_data)
|
25
|
+
member = Response::Member.new
|
26
|
+
|
27
|
+
SetAttributes.(
|
28
|
+
member,
|
29
|
+
member_data,
|
30
|
+
strict: true
|
31
|
+
)
|
32
|
+
|
33
|
+
member
|
34
|
+
end
|
35
|
+
|
36
|
+
module JSON
|
37
|
+
def self.read(text)
|
38
|
+
formatted_data = ::JSON.parse text, symbolize_names: true
|
39
|
+
|
40
|
+
raw_data = Casing::Underscore.(formatted_data)
|
41
|
+
|
42
|
+
raw_data
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Gossip
|
4
|
+
class Response
|
5
|
+
include Schema::DataStructure
|
6
|
+
|
7
|
+
attribute :server_ip, String
|
8
|
+
attribute :server_port, Integer
|
9
|
+
attribute :leader, Member
|
10
|
+
attribute :followers, Array, default: ->{ Array.new }
|
11
|
+
attribute :unknown, Array, default: ->{ Array.new }
|
12
|
+
|
13
|
+
def add_member(member)
|
14
|
+
if member.state == Cluster::MemberState.leader
|
15
|
+
self.leader = member
|
16
|
+
elsif member.state == Cluster::MemberState.follower
|
17
|
+
followers << member
|
18
|
+
else
|
19
|
+
unknown << member
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Gossip
|
4
|
+
include Log::Dependency
|
5
|
+
include Request
|
6
|
+
|
7
|
+
configure :gossip
|
8
|
+
|
9
|
+
def call
|
10
|
+
logger.trace { "GET gossip endpoint" }
|
11
|
+
|
12
|
+
request = Net::HTTP::Get.new uri_path
|
13
|
+
|
14
|
+
http_response = connection.request request
|
15
|
+
|
16
|
+
response = Transform::Read.(http_response.body, :json, Response)
|
17
|
+
|
18
|
+
logger.debug { "GET gossip endpoint done (LeaderIPAddress: #{response.leader&.external_http_ip.inspect}, FollowerCount: #{response.followers.count})" }
|
19
|
+
|
20
|
+
return response
|
21
|
+
end
|
22
|
+
|
23
|
+
def uri_path
|
24
|
+
'/gossip'
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Info
|
4
|
+
class Response
|
5
|
+
module Transformer
|
6
|
+
def self.json
|
7
|
+
JSON
|
8
|
+
end
|
9
|
+
|
10
|
+
def self.instance(raw_data)
|
11
|
+
response = Response.new
|
12
|
+
response.event_store_version = raw_data[:es_version]
|
13
|
+
response.state = raw_data[:state].capitalize
|
14
|
+
response.projections_mode = raw_data[:projections_mode]
|
15
|
+
response
|
16
|
+
end
|
17
|
+
|
18
|
+
module JSON
|
19
|
+
def self.read(json_text)
|
20
|
+
formatted_data = ::JSON.parse json_text, :symbolize_names => true
|
21
|
+
Casing::Underscore.(formatted_data)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Info
|
4
|
+
class Response
|
5
|
+
include Schema::DataStructure
|
6
|
+
|
7
|
+
attribute :event_store_version, String
|
8
|
+
attribute :state, String
|
9
|
+
attribute :projections_mode, String
|
10
|
+
|
11
|
+
def leader?
|
12
|
+
state == Cluster::MemberState.leader
|
13
|
+
end
|
14
|
+
|
15
|
+
def follower?
|
16
|
+
state == Cluster::MemberState.follower
|
17
|
+
end
|
18
|
+
|
19
|
+
def digest
|
20
|
+
"EventStoreVersion: #{event_store_version}, State: #{Cluster::MemberState.digest state}, ProjectionsMode: #{projections_mode}"
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Info
|
4
|
+
include Log::Dependency
|
5
|
+
include Request
|
6
|
+
|
7
|
+
configure :info
|
8
|
+
|
9
|
+
def call
|
10
|
+
logger.trace { "GET info endpoint" }
|
11
|
+
|
12
|
+
request = Net::HTTP::Get.new uri_path
|
13
|
+
|
14
|
+
http_response = connection.request request
|
15
|
+
|
16
|
+
response = Transform::Read.(http_response.body, :json, Response)
|
17
|
+
|
18
|
+
logger.debug { "GET info endpoint done (#{response.digest})" }
|
19
|
+
|
20
|
+
response
|
21
|
+
end
|
22
|
+
|
23
|
+
def uri_path
|
24
|
+
'/info'
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module JSON
|
4
|
+
module Deserialize
|
5
|
+
def self.call(text)
|
6
|
+
::JSON.parse text, object_class: ObjectClass
|
7
|
+
end
|
8
|
+
|
9
|
+
class ObjectClass < Hash
|
10
|
+
def []=(raw_key, value)
|
11
|
+
key = key_cache[raw_key]
|
12
|
+
|
13
|
+
super key, value
|
14
|
+
end
|
15
|
+
|
16
|
+
def key_cache
|
17
|
+
@@key_cache ||= Hash.new do |cache, raw_key|
|
18
|
+
cache[raw_key] = Casing::Underscore.(raw_key).to_sym
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
module JSON
|
4
|
+
module Serialize
|
5
|
+
def self.call(data, pretty_generate: nil)
|
6
|
+
if pretty_generate
|
7
|
+
method = :pretty_generate
|
8
|
+
else
|
9
|
+
method = :generate
|
10
|
+
end
|
11
|
+
|
12
|
+
data = Casing::Camel.(data)
|
13
|
+
|
14
|
+
::JSON.public_send method, data
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
@@ -0,0 +1,20 @@
|
|
1
|
+
module EventStore
|
2
|
+
module HTTP
|
3
|
+
class Log < ::Log
|
4
|
+
def tag!(tags)
|
5
|
+
tags << :event_store_http
|
6
|
+
tags << :library
|
7
|
+
tags << :verbose
|
8
|
+
end
|
9
|
+
|
10
|
+
class Data < ::Log
|
11
|
+
configure_macro :data_logger
|
12
|
+
|
13
|
+
def tag!(tags)
|
14
|
+
tags << :event_store_http_data
|
15
|
+
tags << :data
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|