event_store_client 1.4.9 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +30 -145
- data/docs/appending_events.md +155 -0
- data/docs/catch_up_subscriptions.md +253 -0
- data/docs/configuration.md +83 -0
- data/docs/deleting_streams.md +25 -0
- data/docs/encrypting_events.md +84 -0
- data/docs/linking_events.md +149 -0
- data/docs/reading_events.md +200 -0
- data/lib/event_store_client/adapters/grpc/client.rb +244 -105
- data/lib/event_store_client/adapters/grpc/cluster/gossip_discover.rb +131 -0
- data/lib/event_store_client/adapters/grpc/cluster/insecure_connection.rb +21 -0
- data/lib/event_store_client/adapters/grpc/cluster/member.rb +18 -0
- data/lib/event_store_client/adapters/grpc/cluster/queryless_discover.rb +25 -0
- data/lib/event_store_client/adapters/grpc/cluster/secure_connection.rb +71 -0
- data/lib/event_store_client/adapters/grpc/command_registrar.rb +7 -7
- data/lib/event_store_client/adapters/grpc/commands/command.rb +63 -25
- data/lib/event_store_client/adapters/grpc/commands/gossip/cluster_info.rb +24 -0
- data/lib/event_store_client/adapters/grpc/commands/streams/append.rb +43 -68
- data/lib/event_store_client/adapters/grpc/commands/streams/append_multiple.rb +44 -0
- data/lib/event_store_client/adapters/grpc/commands/streams/delete.rb +21 -17
- data/lib/event_store_client/adapters/grpc/commands/streams/hard_delete.rb +39 -0
- data/lib/event_store_client/adapters/grpc/commands/streams/link_to.rb +7 -52
- data/lib/event_store_client/adapters/grpc/commands/streams/link_to_multiple.rb +44 -0
- data/lib/event_store_client/adapters/grpc/commands/streams/read.rb +20 -85
- data/lib/event_store_client/adapters/grpc/commands/streams/read_paginated.rb +174 -0
- data/lib/event_store_client/adapters/grpc/commands/streams/subscribe.rb +31 -106
- data/lib/event_store_client/adapters/grpc/connection.rb +56 -36
- data/lib/event_store_client/adapters/grpc/discover.rb +75 -0
- data/lib/event_store_client/adapters/grpc/generated/cluster_pb.rb +106 -18
- data/lib/event_store_client/adapters/grpc/generated/cluster_services_pb.rb +12 -12
- data/lib/event_store_client/adapters/grpc/generated/code_pb.rb +34 -0
- data/lib/event_store_client/adapters/grpc/generated/gossip_pb.rb +3 -2
- data/lib/event_store_client/adapters/grpc/generated/gossip_services_pb.rb +3 -3
- data/lib/event_store_client/adapters/grpc/generated/monitoring_pb.rb +25 -0
- data/lib/event_store_client/adapters/grpc/generated/monitoring_services_pb.rb +26 -0
- data/lib/event_store_client/adapters/grpc/generated/operations_pb.rb +2 -1
- data/lib/event_store_client/adapters/grpc/generated/operations_services_pb.rb +8 -7
- data/lib/event_store_client/adapters/grpc/generated/persistent_pb.rb +199 -38
- data/lib/event_store_client/adapters/grpc/generated/persistent_services_pb.rb +7 -3
- data/lib/event_store_client/adapters/grpc/generated/projections_pb.rb +9 -26
- data/lib/event_store_client/adapters/grpc/generated/projections_services_pb.rb +4 -3
- data/lib/event_store_client/adapters/grpc/generated/serverfeatures_pb.rb +29 -0
- data/lib/event_store_client/adapters/grpc/generated/serverfeatures_services_pb.rb +26 -0
- data/lib/event_store_client/adapters/grpc/generated/shared_pb.rb +54 -12
- data/lib/event_store_client/adapters/grpc/generated/status_pb.rb +23 -0
- data/lib/event_store_client/adapters/grpc/generated/streams_pb.rb +104 -64
- data/lib/event_store_client/adapters/grpc/generated/streams_services_pb.rb +3 -2
- data/lib/event_store_client/adapters/grpc/generated/users_services_pb.rb +2 -2
- data/lib/event_store_client/adapters/grpc/options/streams/read_options.rb +78 -0
- data/lib/event_store_client/adapters/grpc/options/streams/write_options.rb +39 -0
- data/lib/event_store_client/adapters/grpc/shared/event_deserializer.rb +52 -0
- data/lib/event_store_client/adapters/grpc/shared/options/filter_options.rb +76 -0
- data/lib/event_store_client/adapters/grpc/shared/options/stream_options.rb +91 -0
- data/lib/event_store_client/adapters/grpc/shared/streams/process_response.rb +28 -0
- data/lib/event_store_client/adapters/grpc/shared/streams/process_responses.rb +33 -0
- data/lib/event_store_client/adapters/grpc.rb +28 -12
- data/lib/event_store_client/configuration.rb +39 -54
- data/lib/event_store_client/connection/url.rb +57 -0
- data/lib/event_store_client/connection/url_parser.rb +144 -0
- data/lib/event_store_client/data_decryptor.rb +2 -9
- data/lib/event_store_client/deserialized_event.rb +35 -10
- data/lib/event_store_client/encryption_metadata.rb +0 -1
- data/lib/event_store_client/event.rb +4 -2
- data/lib/event_store_client/extensions/options_extension.rb +87 -0
- data/lib/event_store_client/mapper/default.rb +12 -9
- data/lib/event_store_client/mapper/encrypted.rb +18 -17
- data/lib/event_store_client/types.rb +1 -1
- data/lib/event_store_client/utils.rb +30 -0
- data/lib/event_store_client/version.rb +1 -1
- data/lib/event_store_client.rb +8 -7
- metadata +74 -83
- data/lib/event_store_client/adapters/grpc/Protos/cluster.proto +0 -149
- data/lib/event_store_client/adapters/grpc/Protos/gossip.proto +0 -44
- data/lib/event_store_client/adapters/grpc/Protos/operations.proto +0 -45
- data/lib/event_store_client/adapters/grpc/Protos/persistent.proto +0 -180
- data/lib/event_store_client/adapters/grpc/Protos/projections.proto +0 -174
- data/lib/event_store_client/adapters/grpc/Protos/shared.proto +0 -22
- data/lib/event_store_client/adapters/grpc/Protos/streams.proto +0 -242
- data/lib/event_store_client/adapters/grpc/Protos/users.proto +0 -119
- data/lib/event_store_client/adapters/grpc/README.md +0 -16
- data/lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/create.rb +0 -46
- data/lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/delete.rb +0 -34
- data/lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/read.rb +0 -77
- data/lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/settings_schema.rb +0 -38
- data/lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/update.rb +0 -48
- data/lib/event_store_client/adapters/grpc/commands/projections/create.rb +0 -48
- data/lib/event_store_client/adapters/grpc/commands/projections/delete.rb +0 -34
- data/lib/event_store_client/adapters/grpc/commands/projections/update.rb +0 -44
- data/lib/event_store_client/adapters/grpc/commands/streams/read_all.rb +0 -43
- data/lib/event_store_client/adapters/grpc/commands/streams/tombstone.rb +0 -35
- data/lib/event_store_client/adapters/http/README.md +0 -16
- data/lib/event_store_client/adapters/http/client.rb +0 -161
- data/lib/event_store_client/adapters/http/commands/command.rb +0 -27
- data/lib/event_store_client/adapters/http/commands/persistent_subscriptions/ack.rb +0 -15
- data/lib/event_store_client/adapters/http/commands/persistent_subscriptions/create.rb +0 -35
- data/lib/event_store_client/adapters/http/commands/persistent_subscriptions/read.rb +0 -60
- data/lib/event_store_client/adapters/http/commands/projections/create.rb +0 -33
- data/lib/event_store_client/adapters/http/commands/projections/update.rb +0 -31
- data/lib/event_store_client/adapters/http/commands/streams/append.rb +0 -49
- data/lib/event_store_client/adapters/http/commands/streams/delete.rb +0 -16
- data/lib/event_store_client/adapters/http/commands/streams/link_to.rb +0 -49
- data/lib/event_store_client/adapters/http/commands/streams/read.rb +0 -52
- data/lib/event_store_client/adapters/http/commands/streams/tombstone.rb +0 -17
- data/lib/event_store_client/adapters/http/connection.rb +0 -46
- data/lib/event_store_client/adapters/http/request_method.rb +0 -28
- data/lib/event_store_client/adapters/http.rb +0 -17
- data/lib/event_store_client/adapters/in_memory.rb +0 -144
- data/lib/event_store_client/broker.rb +0 -40
- data/lib/event_store_client/catch_up_subscription.rb +0 -42
- data/lib/event_store_client/catch_up_subscriptions.rb +0 -92
- data/lib/event_store_client/client.rb +0 -73
- data/lib/event_store_client/error_handler.rb +0 -10
- data/lib/event_store_client/subscription.rb +0 -23
- data/lib/event_store_client/subscriptions.rb +0 -38
- data/lib/event_store_client/value_objects/read_direction.rb +0 -43
@@ -0,0 +1,87 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module EventStoreClient
|
4
|
+
module Extensions
|
5
|
+
# A very simple extension that implements a DLS for adding attr_accessors with default values,
|
6
|
+
# and assigning their values during object initialization.
|
7
|
+
# Example. Let's say you frequently do something like this:
|
8
|
+
# ```ruby
|
9
|
+
# class SomeClass
|
10
|
+
# attr_accessor :attr1, :attr2, :attr3, :attr4
|
11
|
+
#
|
12
|
+
# def initialize(opts = {})
|
13
|
+
# @attr1 = opts[:attr1] || 'Attr 1 value'
|
14
|
+
# @attr2 = opts[:attr2] || 'Attr 2 value'
|
15
|
+
# @attr3 = opts[:attr3] || do_some_calc
|
16
|
+
# @attr4 = opts[:attr4]
|
17
|
+
# end
|
18
|
+
#
|
19
|
+
# def do_some_calc
|
20
|
+
# end
|
21
|
+
# end
|
22
|
+
#
|
23
|
+
# SomeClass.new(attr1: 'hihi', attr4: 'byebye')
|
24
|
+
# ```
|
25
|
+
#
|
26
|
+
# You can replace the code above using the OptionsExtension:
|
27
|
+
# ```ruby
|
28
|
+
# class SomeClass
|
29
|
+
# include EventStoreClient::Extensions::OptionsExtension
|
30
|
+
#
|
31
|
+
# option(:attr1) { 'Attr 1 value' }
|
32
|
+
# option(:attr2) { 'Attr 2 value' }
|
33
|
+
# option(:attr3) { do_some_calc }
|
34
|
+
# option(:attr4)
|
35
|
+
# end
|
36
|
+
#
|
37
|
+
# SomeClass.new(attr1: 'hihi', attr4: 'byebye')
|
38
|
+
# ```
|
39
|
+
module OptionsExtension
|
40
|
+
module ClassMethods
|
41
|
+
# @param opt_name [Symbol] option name
|
42
|
+
# @param blk [Proc] provide define value using block. It will be later evaluated in the
|
43
|
+
# context of your object to determine the default value of the option
|
44
|
+
# @return [Symbol]
|
45
|
+
def option(opt_name, &blk)
|
46
|
+
self.options = (options + Set.new([opt_name])).freeze
|
47
|
+
attr_writer opt_name
|
48
|
+
|
49
|
+
define_method opt_name do
|
50
|
+
result = instance_variable_get(:"@#{opt_name}")
|
51
|
+
return result if instance_variable_defined?(:"@#{opt_name}")
|
52
|
+
|
53
|
+
instance_exec(&blk) if blk
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
def inherited(klass)
|
58
|
+
super
|
59
|
+
klass.options = Set.new(options).freeze
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
def self.included(klass)
|
64
|
+
klass.singleton_class.attr_accessor(:options)
|
65
|
+
klass.options = Set.new.freeze
|
66
|
+
klass.extend(ClassMethods)
|
67
|
+
end
|
68
|
+
|
69
|
+
def initialize(**options)
|
70
|
+
self.class.options.each do |option|
|
71
|
+
# init default values of options
|
72
|
+
value = options.key?(option) ? options[option] : public_send(option)
|
73
|
+
public_send("#{option}=", value)
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
# Construct a hash from options, where key is the option's name and the value is option's
|
78
|
+
# value
|
79
|
+
# @return [Hash]
|
80
|
+
def options_hash
|
81
|
+
self.class.options.each_with_object({}) do |option, res|
|
82
|
+
res[option] = public_send(option)
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
@@ -3,6 +3,13 @@
|
|
3
3
|
module EventStoreClient
|
4
4
|
module Mapper
|
5
5
|
class Default
|
6
|
+
attr_reader :serializer
|
7
|
+
private :serializer
|
8
|
+
|
9
|
+
def initialize(serializer: Serializer::Json)
|
10
|
+
@serializer = serializer
|
11
|
+
end
|
12
|
+
|
6
13
|
def serialize(event)
|
7
14
|
Event.new(
|
8
15
|
id: event.respond_to?(:id) ? event.id : nil,
|
@@ -28,17 +35,13 @@ module EventStoreClient
|
|
28
35
|
type: event.type,
|
29
36
|
title: event.title,
|
30
37
|
data: data,
|
31
|
-
metadata: metadata
|
38
|
+
metadata: metadata,
|
39
|
+
stream_revision: event.stream_revision,
|
40
|
+
commit_position: event.commit_position,
|
41
|
+
prepare_position: event.prepare_position,
|
42
|
+
stream_name: event.stream_name
|
32
43
|
)
|
33
44
|
end
|
34
|
-
|
35
|
-
private
|
36
|
-
|
37
|
-
attr_reader :serializer
|
38
|
-
|
39
|
-
def initialize(serializer: Serializer::Json)
|
40
|
-
@serializer = serializer
|
41
|
-
end
|
42
45
|
end
|
43
46
|
end
|
44
47
|
end
|
@@ -9,10 +9,21 @@ module EventStoreClient
|
|
9
9
|
##
|
10
10
|
# Transforms given event's data and encrypts/decrypts selected subset of data
|
11
11
|
# based on encryption schema stored in the event itself.
|
12
|
-
|
13
12
|
class Encrypted
|
14
13
|
MissingEncryptionKey = Class.new(StandardError)
|
15
14
|
|
15
|
+
attr_reader :key_repository, :serializer
|
16
|
+
private :key_repository, :serializer
|
17
|
+
|
18
|
+
##
|
19
|
+
# Initializes the mapper with required dependencies. Accepts:
|
20
|
+
# * +key_repoistory+ - repository stored encryption keys. Passed down to the +DataEncryptor+
|
21
|
+
# * +serializer+ - object used to serialize data. By default JSON serializer is used.
|
22
|
+
def initialize(key_repository, serializer: Serializer::Json)
|
23
|
+
@key_repository = key_repository
|
24
|
+
@serializer = serializer
|
25
|
+
end
|
26
|
+
|
16
27
|
##
|
17
28
|
# Encrypts the given event's subset of data.
|
18
29
|
# Accepts specific event class instance with:
|
@@ -20,7 +31,6 @@ module EventStoreClient
|
|
20
31
|
# * encryption_schema - hash with information which data to encrypt and
|
21
32
|
# which key should be used as an identifier.
|
22
33
|
# *Returns*: General +Event+ instance with encrypted data
|
23
|
-
|
24
34
|
def serialize(event)
|
25
35
|
encryption_schema = (
|
26
36
|
event.class.respond_to?(:encryption_schema) &&
|
@@ -33,6 +43,7 @@ module EventStoreClient
|
|
33
43
|
)
|
34
44
|
encryptor.call
|
35
45
|
EventStoreClient::Event.new(
|
46
|
+
id: event.respond_to?(:id) ? event.id : nil,
|
36
47
|
data: serializer.serialize(encryptor.encrypted_data),
|
37
48
|
metadata: serializer.serialize(
|
38
49
|
event.metadata.merge(encryption: encryptor.encryption_metadata)
|
@@ -48,7 +59,6 @@ module EventStoreClient
|
|
48
59
|
# * encryption_metadata - hash with information which data to encrypt and
|
49
60
|
# which key should be used as an identifier.
|
50
61
|
# *Returns*: Specific event class with all data decrypted
|
51
|
-
|
52
62
|
def deserialize(event, skip_decryption: false)
|
53
63
|
metadata = serializer.deserialize(event.metadata)
|
54
64
|
encryption_schema = metadata['encryption']
|
@@ -77,22 +87,13 @@ module EventStoreClient
|
|
77
87
|
type: event.type,
|
78
88
|
title: event.title,
|
79
89
|
data: decrypted_data,
|
80
|
-
metadata: metadata
|
90
|
+
metadata: metadata,
|
91
|
+
stream_revision: event.stream_revision,
|
92
|
+
commit_position: event.commit_position,
|
93
|
+
prepare_position: event.prepare_position,
|
94
|
+
stream_name: event.stream_name
|
81
95
|
)
|
82
96
|
end
|
83
|
-
|
84
|
-
private
|
85
|
-
|
86
|
-
attr_reader :key_repository, :serializer
|
87
|
-
|
88
|
-
##
|
89
|
-
# Initializes the mapper with required dependencies. Accepts:
|
90
|
-
# * +key_repoistory+ - repository stored encryption keys. Passed down to the +DataEncryptor+
|
91
|
-
# * +serializer+ - object used to serialize data. By default JSON serializer is used.
|
92
|
-
def initialize(key_repository, serializer: Serializer::Json)
|
93
|
-
@key_repository = key_repository
|
94
|
-
@serializer = serializer
|
95
|
-
end
|
96
97
|
end
|
97
98
|
end
|
98
99
|
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# rubocop:disable Metrics/AbcSize
|
4
|
+
|
5
|
+
module EventStoreClient
|
6
|
+
class Utils
|
7
|
+
class << self
|
8
|
+
# @param uuid [EventStore::Client::UUID]
|
9
|
+
# @return [String]
|
10
|
+
def uuid_to_str(uuid)
|
11
|
+
return uuid.string unless uuid.string.empty?
|
12
|
+
|
13
|
+
msb =
|
14
|
+
if uuid.structured.most_significant_bits.negative?
|
15
|
+
(2**64) + uuid.structured.most_significant_bits
|
16
|
+
else
|
17
|
+
uuid.structured.most_significant_bits
|
18
|
+
end
|
19
|
+
lsb =
|
20
|
+
if uuid.structured.least_significant_bits.negative?
|
21
|
+
(2**64) + uuid.structured.least_significant_bits
|
22
|
+
else
|
23
|
+
uuid.structured.least_significant_bits
|
24
|
+
end
|
25
|
+
(msb.to_s(16) + lsb.to_s(16)).unpack('A8A4A4A4A12').join('-')
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
# rubocop:enable Metrics/AbcSize
|
data/lib/event_store_client.rb
CHANGED
@@ -9,13 +9,14 @@ require 'event_store_client/serializer/json'
|
|
9
9
|
|
10
10
|
require 'event_store_client/mapper'
|
11
11
|
|
12
|
-
require 'event_store_client/
|
12
|
+
require 'event_store_client/extensions/options_extension'
|
13
|
+
|
14
|
+
require 'event_store_client/utils'
|
15
|
+
|
16
|
+
require 'event_store_client/connection/url'
|
17
|
+
require 'event_store_client/connection/url_parser'
|
13
18
|
require 'event_store_client/event'
|
14
19
|
require 'event_store_client/deserialized_event'
|
20
|
+
require 'event_store_client/configuration'
|
15
21
|
|
16
|
-
require 'event_store_client/
|
17
|
-
require 'event_store_client/subscriptions'
|
18
|
-
require 'event_store_client/catch_up_subscription'
|
19
|
-
require 'event_store_client/catch_up_subscriptions'
|
20
|
-
require 'event_store_client/broker'
|
21
|
-
require 'event_store_client/client'
|
22
|
+
require 'event_store_client/adapters/grpc'
|
metadata
CHANGED
@@ -1,29 +1,29 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: event_store_client
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version:
|
4
|
+
version: 2.0.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Sebastian Wilgosz
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-
|
11
|
+
date: 2022-09-22 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: dry-configurable
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- - "
|
17
|
+
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: '0.
|
19
|
+
version: '0.13'
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- - "
|
24
|
+
- - "~>"
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: '0.
|
26
|
+
version: '0.13'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: dry-monads
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -67,7 +67,7 @@ dependencies:
|
|
67
67
|
- !ruby/object:Gem::Version
|
68
68
|
version: '1'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
|
-
name:
|
70
|
+
name: grpc
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
72
72
|
requirements:
|
73
73
|
- - "~>"
|
@@ -81,103 +81,103 @@ dependencies:
|
|
81
81
|
- !ruby/object:Gem::Version
|
82
82
|
version: '1.0'
|
83
83
|
- !ruby/object:Gem::Dependency
|
84
|
-
name:
|
84
|
+
name: pry
|
85
85
|
requirement: !ruby/object:Gem::Requirement
|
86
86
|
requirements:
|
87
87
|
- - "~>"
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version: '
|
90
|
-
type: :
|
89
|
+
version: '0.14'
|
90
|
+
type: :development
|
91
91
|
prerelease: false
|
92
92
|
version_requirements: !ruby/object:Gem::Requirement
|
93
93
|
requirements:
|
94
94
|
- - "~>"
|
95
95
|
- !ruby/object:Gem::Version
|
96
|
-
version: '
|
96
|
+
version: '0.14'
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
|
-
name:
|
98
|
+
name: rspec
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
100
100
|
requirements:
|
101
|
-
- - "
|
101
|
+
- - "~>"
|
102
102
|
- !ruby/object:Gem::Version
|
103
|
-
version:
|
104
|
-
type: :
|
103
|
+
version: '3.11'
|
104
|
+
type: :development
|
105
105
|
prerelease: false
|
106
106
|
version_requirements: !ruby/object:Gem::Requirement
|
107
107
|
requirements:
|
108
|
-
- - "
|
108
|
+
- - "~>"
|
109
109
|
- !ruby/object:Gem::Version
|
110
|
-
version:
|
110
|
+
version: '3.11'
|
111
111
|
- !ruby/object:Gem::Dependency
|
112
|
-
name:
|
112
|
+
name: simplecov
|
113
113
|
requirement: !ruby/object:Gem::Requirement
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '0.
|
117
|
+
version: '0.21'
|
118
118
|
type: :development
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version: '0.
|
124
|
+
version: '0.21'
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
|
-
name:
|
126
|
+
name: simplecov-formatter-badge
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|
128
128
|
requirements:
|
129
|
-
- - "
|
129
|
+
- - "~>"
|
130
130
|
- !ruby/object:Gem::Version
|
131
|
-
version: '0'
|
131
|
+
version: '0.1'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
134
|
version_requirements: !ruby/object:Gem::Requirement
|
135
135
|
requirements:
|
136
|
-
- - "
|
136
|
+
- - "~>"
|
137
137
|
- !ruby/object:Gem::Version
|
138
|
-
version: '0'
|
138
|
+
version: '0.1'
|
139
139
|
- !ruby/object:Gem::Dependency
|
140
|
-
name:
|
140
|
+
name: rake
|
141
141
|
requirement: !ruby/object:Gem::Requirement
|
142
142
|
requirements:
|
143
143
|
- - "~>"
|
144
144
|
- !ruby/object:Gem::Version
|
145
|
-
version: '0
|
145
|
+
version: '13.0'
|
146
146
|
type: :development
|
147
147
|
prerelease: false
|
148
148
|
version_requirements: !ruby/object:Gem::Requirement
|
149
149
|
requirements:
|
150
150
|
- - "~>"
|
151
151
|
- !ruby/object:Gem::Version
|
152
|
-
version: '0
|
152
|
+
version: '13.0'
|
153
153
|
- !ruby/object:Gem::Dependency
|
154
|
-
name:
|
154
|
+
name: grpc-tools
|
155
155
|
requirement: !ruby/object:Gem::Requirement
|
156
156
|
requirements:
|
157
157
|
- - "~>"
|
158
158
|
- !ruby/object:Gem::Version
|
159
|
-
version: '
|
159
|
+
version: '1.46'
|
160
160
|
type: :development
|
161
161
|
prerelease: false
|
162
162
|
version_requirements: !ruby/object:Gem::Requirement
|
163
163
|
requirements:
|
164
164
|
- - "~>"
|
165
165
|
- !ruby/object:Gem::Version
|
166
|
-
version: '
|
166
|
+
version: '1.46'
|
167
167
|
- !ruby/object:Gem::Dependency
|
168
|
-
name:
|
168
|
+
name: timecop
|
169
169
|
requirement: !ruby/object:Gem::Requirement
|
170
170
|
requirements:
|
171
|
-
- - "
|
171
|
+
- - "~>"
|
172
172
|
- !ruby/object:Gem::Version
|
173
|
-
version:
|
173
|
+
version: 0.9.5
|
174
174
|
type: :development
|
175
175
|
prerelease: false
|
176
176
|
version_requirements: !ruby/object:Gem::Requirement
|
177
177
|
requirements:
|
178
|
-
- - "
|
178
|
+
- - "~>"
|
179
179
|
- !ruby/object:Gem::Version
|
180
|
-
version:
|
180
|
+
version: 0.9.5
|
181
181
|
description: Easy to use client for event-sources applications written in ruby
|
182
182
|
email:
|
183
183
|
- sebastian@driggl.com
|
@@ -188,94 +188,85 @@ files:
|
|
188
188
|
- MIT-LICENSE
|
189
189
|
- README.md
|
190
190
|
- Rakefile
|
191
|
+
- docs/appending_events.md
|
192
|
+
- docs/catch_up_subscriptions.md
|
193
|
+
- docs/configuration.md
|
194
|
+
- docs/deleting_streams.md
|
195
|
+
- docs/encrypting_events.md
|
196
|
+
- docs/linking_events.md
|
197
|
+
- docs/reading_events.md
|
191
198
|
- lib/event_store_client.rb
|
192
199
|
- lib/event_store_client/adapters/grpc.rb
|
193
|
-
- lib/event_store_client/adapters/grpc/Protos/cluster.proto
|
194
|
-
- lib/event_store_client/adapters/grpc/Protos/gossip.proto
|
195
|
-
- lib/event_store_client/adapters/grpc/Protos/operations.proto
|
196
|
-
- lib/event_store_client/adapters/grpc/Protos/persistent.proto
|
197
|
-
- lib/event_store_client/adapters/grpc/Protos/projections.proto
|
198
|
-
- lib/event_store_client/adapters/grpc/Protos/shared.proto
|
199
|
-
- lib/event_store_client/adapters/grpc/Protos/streams.proto
|
200
|
-
- lib/event_store_client/adapters/grpc/Protos/users.proto
|
201
|
-
- lib/event_store_client/adapters/grpc/README.md
|
202
200
|
- lib/event_store_client/adapters/grpc/client.rb
|
201
|
+
- lib/event_store_client/adapters/grpc/cluster/gossip_discover.rb
|
202
|
+
- lib/event_store_client/adapters/grpc/cluster/insecure_connection.rb
|
203
|
+
- lib/event_store_client/adapters/grpc/cluster/member.rb
|
204
|
+
- lib/event_store_client/adapters/grpc/cluster/queryless_discover.rb
|
205
|
+
- lib/event_store_client/adapters/grpc/cluster/secure_connection.rb
|
203
206
|
- lib/event_store_client/adapters/grpc/command_registrar.rb
|
204
207
|
- lib/event_store_client/adapters/grpc/commands/command.rb
|
205
|
-
- lib/event_store_client/adapters/grpc/commands/
|
206
|
-
- lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/delete.rb
|
207
|
-
- lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/read.rb
|
208
|
-
- lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/settings_schema.rb
|
209
|
-
- lib/event_store_client/adapters/grpc/commands/persistent_subscriptions/update.rb
|
210
|
-
- lib/event_store_client/adapters/grpc/commands/projections/create.rb
|
211
|
-
- lib/event_store_client/adapters/grpc/commands/projections/delete.rb
|
212
|
-
- lib/event_store_client/adapters/grpc/commands/projections/update.rb
|
208
|
+
- lib/event_store_client/adapters/grpc/commands/gossip/cluster_info.rb
|
213
209
|
- lib/event_store_client/adapters/grpc/commands/streams/append.rb
|
210
|
+
- lib/event_store_client/adapters/grpc/commands/streams/append_multiple.rb
|
214
211
|
- lib/event_store_client/adapters/grpc/commands/streams/delete.rb
|
212
|
+
- lib/event_store_client/adapters/grpc/commands/streams/hard_delete.rb
|
215
213
|
- lib/event_store_client/adapters/grpc/commands/streams/link_to.rb
|
214
|
+
- lib/event_store_client/adapters/grpc/commands/streams/link_to_multiple.rb
|
216
215
|
- lib/event_store_client/adapters/grpc/commands/streams/read.rb
|
217
|
-
- lib/event_store_client/adapters/grpc/commands/streams/
|
216
|
+
- lib/event_store_client/adapters/grpc/commands/streams/read_paginated.rb
|
218
217
|
- lib/event_store_client/adapters/grpc/commands/streams/subscribe.rb
|
219
|
-
- lib/event_store_client/adapters/grpc/commands/streams/tombstone.rb
|
220
218
|
- lib/event_store_client/adapters/grpc/connection.rb
|
219
|
+
- lib/event_store_client/adapters/grpc/discover.rb
|
221
220
|
- lib/event_store_client/adapters/grpc/generated/cluster_pb.rb
|
222
221
|
- lib/event_store_client/adapters/grpc/generated/cluster_services_pb.rb
|
222
|
+
- lib/event_store_client/adapters/grpc/generated/code_pb.rb
|
223
223
|
- lib/event_store_client/adapters/grpc/generated/gossip_pb.rb
|
224
224
|
- lib/event_store_client/adapters/grpc/generated/gossip_services_pb.rb
|
225
|
+
- lib/event_store_client/adapters/grpc/generated/monitoring_pb.rb
|
226
|
+
- lib/event_store_client/adapters/grpc/generated/monitoring_services_pb.rb
|
225
227
|
- lib/event_store_client/adapters/grpc/generated/operations_pb.rb
|
226
228
|
- lib/event_store_client/adapters/grpc/generated/operations_services_pb.rb
|
227
229
|
- lib/event_store_client/adapters/grpc/generated/persistent_pb.rb
|
228
230
|
- lib/event_store_client/adapters/grpc/generated/persistent_services_pb.rb
|
229
231
|
- lib/event_store_client/adapters/grpc/generated/projections_pb.rb
|
230
232
|
- lib/event_store_client/adapters/grpc/generated/projections_services_pb.rb
|
233
|
+
- lib/event_store_client/adapters/grpc/generated/serverfeatures_pb.rb
|
234
|
+
- lib/event_store_client/adapters/grpc/generated/serverfeatures_services_pb.rb
|
231
235
|
- lib/event_store_client/adapters/grpc/generated/shared_pb.rb
|
236
|
+
- lib/event_store_client/adapters/grpc/generated/status_pb.rb
|
232
237
|
- lib/event_store_client/adapters/grpc/generated/streams_pb.rb
|
233
238
|
- lib/event_store_client/adapters/grpc/generated/streams_services_pb.rb
|
234
239
|
- lib/event_store_client/adapters/grpc/generated/users_pb.rb
|
235
240
|
- lib/event_store_client/adapters/grpc/generated/users_services_pb.rb
|
236
|
-
- lib/event_store_client/adapters/
|
237
|
-
- lib/event_store_client/adapters/
|
238
|
-
- lib/event_store_client/adapters/
|
239
|
-
- lib/event_store_client/adapters/
|
240
|
-
- lib/event_store_client/adapters/
|
241
|
-
- lib/event_store_client/adapters/
|
242
|
-
- lib/event_store_client/adapters/
|
243
|
-
- lib/event_store_client/adapters/http/commands/projections/create.rb
|
244
|
-
- lib/event_store_client/adapters/http/commands/projections/update.rb
|
245
|
-
- lib/event_store_client/adapters/http/commands/streams/append.rb
|
246
|
-
- lib/event_store_client/adapters/http/commands/streams/delete.rb
|
247
|
-
- lib/event_store_client/adapters/http/commands/streams/link_to.rb
|
248
|
-
- lib/event_store_client/adapters/http/commands/streams/read.rb
|
249
|
-
- lib/event_store_client/adapters/http/commands/streams/tombstone.rb
|
250
|
-
- lib/event_store_client/adapters/http/connection.rb
|
251
|
-
- lib/event_store_client/adapters/http/request_method.rb
|
252
|
-
- lib/event_store_client/adapters/in_memory.rb
|
253
|
-
- lib/event_store_client/broker.rb
|
254
|
-
- lib/event_store_client/catch_up_subscription.rb
|
255
|
-
- lib/event_store_client/catch_up_subscriptions.rb
|
256
|
-
- lib/event_store_client/client.rb
|
241
|
+
- lib/event_store_client/adapters/grpc/options/streams/read_options.rb
|
242
|
+
- lib/event_store_client/adapters/grpc/options/streams/write_options.rb
|
243
|
+
- lib/event_store_client/adapters/grpc/shared/event_deserializer.rb
|
244
|
+
- lib/event_store_client/adapters/grpc/shared/options/filter_options.rb
|
245
|
+
- lib/event_store_client/adapters/grpc/shared/options/stream_options.rb
|
246
|
+
- lib/event_store_client/adapters/grpc/shared/streams/process_response.rb
|
247
|
+
- lib/event_store_client/adapters/grpc/shared/streams/process_responses.rb
|
257
248
|
- lib/event_store_client/configuration.rb
|
249
|
+
- lib/event_store_client/connection/url.rb
|
250
|
+
- lib/event_store_client/connection/url_parser.rb
|
258
251
|
- lib/event_store_client/data_decryptor.rb
|
259
252
|
- lib/event_store_client/data_encryptor.rb
|
260
253
|
- lib/event_store_client/deserialized_event.rb
|
261
254
|
- lib/event_store_client/encryption_metadata.rb
|
262
|
-
- lib/event_store_client/error_handler.rb
|
263
255
|
- lib/event_store_client/event.rb
|
256
|
+
- lib/event_store_client/extensions/options_extension.rb
|
264
257
|
- lib/event_store_client/mapper.rb
|
265
258
|
- lib/event_store_client/mapper/default.rb
|
266
259
|
- lib/event_store_client/mapper/encrypted.rb
|
267
260
|
- lib/event_store_client/serializer/json.rb
|
268
|
-
- lib/event_store_client/subscription.rb
|
269
|
-
- lib/event_store_client/subscriptions.rb
|
270
261
|
- lib/event_store_client/types.rb
|
271
|
-
- lib/event_store_client/
|
262
|
+
- lib/event_store_client/utils.rb
|
272
263
|
- lib/event_store_client/version.rb
|
273
264
|
homepage: https://github.com/yousty/event_store_client
|
274
265
|
licenses:
|
275
266
|
- MIT
|
276
267
|
metadata:
|
277
268
|
allowed_push_host: https://rubygems.org
|
278
|
-
post_install_message:
|
269
|
+
post_install_message:
|
279
270
|
rdoc_options: []
|
280
271
|
require_paths:
|
281
272
|
- lib
|
@@ -291,7 +282,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
291
282
|
version: '0'
|
292
283
|
requirements: []
|
293
284
|
rubygems_version: 3.1.6
|
294
|
-
signing_key:
|
285
|
+
signing_key:
|
295
286
|
specification_version: 4
|
296
287
|
summary: Ruby integration for https://eventstore.org
|
297
288
|
test_files: []
|