network_resiliency 0.6.2 → 0.6.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/Gemfile.lock +1 -1
- data/lib/network_resiliency/adapter/http.rb +3 -2
- data/lib/network_resiliency/version.rb +1 -1
- data/lib/network_resiliency.rb +28 -0
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 46125649099a417a46eaf119d48686bbed8090d4840ee13d607372e93df2df6a
|
4
|
+
data.tar.gz: 5e38386f5e8616d452383d007b97e4e2a4ae0895ad22eddadc8dcda28081da77
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a995769d78fbdaeff1ca869f277eaf1aafcf46531b0eb9c35b31e9782f9d4ded7c7f88ba50c6c88f95a0e4e356c1b4aa6e11a55a8a7b04a4622e79751174d9d4
|
7
|
+
data.tar.gz: 1e98ffcc20016e723802c9ce6ef2730357d7bf98fb7d86b24a057830f59f2f0fed946c21c0d8a3c4292af9b3013f49f21419e0dba1cbcf40251169c66fe6a4dc
|
data/CHANGELOG.md
CHANGED
data/Gemfile.lock
CHANGED
@@ -17,15 +17,16 @@ module NetworkResiliency
|
|
17
17
|
|
18
18
|
ID_REGEX = %r{/[0-9]+(?=/|$)}.freeze
|
19
19
|
UUID_REGEX = %r`/\h{8}-\h{4}-(\h{4})-\h{4}-\h{12}(?=/|$)`.freeze
|
20
|
+
|
20
21
|
refine Net::HTTP do
|
21
22
|
def normalize_path(path)
|
22
|
-
path.gsub(
|
23
|
+
NetworkResiliency.normalize_request(:http, path, host: address).gsub(
|
23
24
|
Regexp.union(
|
24
25
|
NetworkResiliency::Adapter::HTTP::ID_REGEX,
|
25
26
|
NetworkResiliency::Adapter::HTTP::UUID_REGEX,
|
26
27
|
),
|
27
28
|
'/x',
|
28
|
-
)
|
29
|
+
).gsub(%r{//+}, "/")
|
29
30
|
end
|
30
31
|
|
31
32
|
def with_resilience(action, destination, idempotent, &block)
|
data/lib/network_resiliency.rb
CHANGED
@@ -15,6 +15,7 @@ module NetworkResiliency
|
|
15
15
|
autoload :Postgres, "network_resiliency/adapter/postgres"
|
16
16
|
end
|
17
17
|
|
18
|
+
ADAPTERS = [ :http, :faraday, :redis, :mysql, :postgres ].freeze
|
18
19
|
MODE = [ :observe, :resilient ].freeze
|
19
20
|
RESILIENCY_SIZE_THRESHOLD = 1_000
|
20
21
|
|
@@ -103,6 +104,32 @@ module NetworkResiliency
|
|
103
104
|
@mode = mode
|
104
105
|
end
|
105
106
|
|
107
|
+
def normalize_request(adapter, request = nil, **context, &block)
|
108
|
+
unless ADAPTERS.include?(adapter)
|
109
|
+
raise ArgumentError, "invalid adapter: #{adapter}"
|
110
|
+
end
|
111
|
+
|
112
|
+
if request && block_given?
|
113
|
+
raise ArgumentError, "specify request or block, but not both"
|
114
|
+
end
|
115
|
+
|
116
|
+
if request.nil? && !context.empty?
|
117
|
+
raise ArgumentError, "can not speficy context without request"
|
118
|
+
end
|
119
|
+
|
120
|
+
@normalize_request ||= {}
|
121
|
+
@normalize_request[adapter] ||= []
|
122
|
+
@normalize_request[adapter] << block if block_given?
|
123
|
+
|
124
|
+
if request
|
125
|
+
@normalize_request[adapter].reduce(request) do |req, block|
|
126
|
+
block.call(req, **context)
|
127
|
+
end
|
128
|
+
else
|
129
|
+
@normalize_request[adapter]
|
130
|
+
end
|
131
|
+
end
|
132
|
+
|
106
133
|
# private
|
107
134
|
|
108
135
|
def record(adapter:, action:, destination:, duration:, error:, timeout:, attempts: 1)
|
@@ -291,6 +318,7 @@ module NetworkResiliency
|
|
291
318
|
def reset
|
292
319
|
@enabled = nil
|
293
320
|
@mode = nil
|
321
|
+
@normalize_request = nil
|
294
322
|
Thread.current["network_resiliency"] = nil
|
295
323
|
StatsEngine.reset
|
296
324
|
Syncer.stop
|