the_help 3.1.0 → 3.3.2
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 +11 -0
- data/Gemfile.lock +26 -21
- data/lib/the_help/service.rb +49 -11
- data/lib/the_help/version.rb +1 -1
- data/the_help.gemspec +1 -1
- metadata +5 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: dc4395e67a6bb231d32bce3a2663791e8e5626b186df2cf8801bfbef60f4808d
|
4
|
+
data.tar.gz: 3ff62f7e6df84f25611e7a742bcb1122468af481153c13affb1c8feafd405758
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 184272bb541578a4da8b7c97b52febe1b45ce1f87596c7f609f5fedb2d74aaff3240c04a1560adab0f9858a776c0953b531a255e83bf0071b90f87d509003f40
|
7
|
+
data.tar.gz: 7528614f77a172d920e9cf943fc4fa54f7630d341d2fb39b97b57780b5476a56399091780c421d1484048a08c472154b619136fb5f8368ac96a7451e7c41c813
|
data/CHANGELOG.md
ADDED
@@ -0,0 +1,11 @@
|
|
1
|
+
# TheHelp Changelog #
|
2
|
+
|
3
|
+
## 3.3.0 ##
|
4
|
+
|
5
|
+
* Calling `#stop!` with no arguments in a service definition will now check that a result was set
|
6
|
+
with either `#result.success` or `#result.error` and raise `TheHelp::NoResultError` if no result
|
7
|
+
was set.
|
8
|
+
|
9
|
+
* You can now call `#stop!` with both a `type:` and `value:` argument. `type:` can be either
|
10
|
+
`:error` (the default) or `:success`, and `value:` can be any object. Calling in this manner
|
11
|
+
will set the service result to the specified type and value.
|
data/Gemfile.lock
CHANGED
@@ -1,50 +1,55 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
the_help (3.
|
4
|
+
the_help (3.3.2)
|
5
5
|
|
6
6
|
GEM
|
7
7
|
remote: https://rubygems.org/
|
8
8
|
specs:
|
9
|
-
ast (2.4.
|
10
|
-
byebug (11.
|
11
|
-
diff-lcs (1.
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
ast (~> 2.4.0)
|
9
|
+
ast (2.4.1)
|
10
|
+
byebug (11.1.3)
|
11
|
+
diff-lcs (1.4.4)
|
12
|
+
parallel (1.19.2)
|
13
|
+
parser (2.7.2.0)
|
14
|
+
ast (~> 2.4.1)
|
16
15
|
rainbow (3.0.0)
|
17
|
-
rake (
|
16
|
+
rake (13.0.1)
|
17
|
+
regexp_parser (1.8.2)
|
18
|
+
rexml (3.2.4)
|
18
19
|
rspec (3.9.0)
|
19
20
|
rspec-core (~> 3.9.0)
|
20
21
|
rspec-expectations (~> 3.9.0)
|
21
22
|
rspec-mocks (~> 3.9.0)
|
22
|
-
rspec-core (3.9.
|
23
|
-
rspec-support (~> 3.9.
|
24
|
-
rspec-expectations (3.9.
|
23
|
+
rspec-core (3.9.3)
|
24
|
+
rspec-support (~> 3.9.3)
|
25
|
+
rspec-expectations (3.9.3)
|
25
26
|
diff-lcs (>= 1.2.0, < 2.0)
|
26
27
|
rspec-support (~> 3.9.0)
|
27
|
-
rspec-mocks (3.9.
|
28
|
+
rspec-mocks (3.9.1)
|
28
29
|
diff-lcs (>= 1.2.0, < 2.0)
|
29
30
|
rspec-support (~> 3.9.0)
|
30
|
-
rspec-support (3.9.
|
31
|
-
rubocop (0.
|
32
|
-
jaro_winkler (~> 1.5.1)
|
31
|
+
rspec-support (3.9.4)
|
32
|
+
rubocop (0.93.1)
|
33
33
|
parallel (~> 1.10)
|
34
|
-
parser (>= 2.
|
34
|
+
parser (>= 2.7.1.5)
|
35
35
|
rainbow (>= 2.2.2, < 4.0)
|
36
|
+
regexp_parser (>= 1.8)
|
37
|
+
rexml
|
38
|
+
rubocop-ast (>= 0.6.0)
|
36
39
|
ruby-progressbar (~> 1.7)
|
37
|
-
unicode-display_width (>= 1.4.0, <
|
40
|
+
unicode-display_width (>= 1.4.0, < 2.0)
|
41
|
+
rubocop-ast (1.1.0)
|
42
|
+
parser (>= 2.7.1.5)
|
38
43
|
ruby-progressbar (1.10.1)
|
39
|
-
unicode-display_width (1.
|
40
|
-
yard (0.9.
|
44
|
+
unicode-display_width (1.7.0)
|
45
|
+
yard (0.9.25)
|
41
46
|
|
42
47
|
PLATFORMS
|
43
48
|
ruby
|
44
49
|
|
45
50
|
DEPENDENCIES
|
46
51
|
byebug
|
47
|
-
rake (~>
|
52
|
+
rake (~> 13.0)
|
48
53
|
rspec (~> 3.0)
|
49
54
|
rubocop (~> 0.50)
|
50
55
|
the_help!
|
data/lib/the_help/service.rb
CHANGED
@@ -150,18 +150,42 @@ module TheHelp
|
|
150
150
|
self
|
151
151
|
end
|
152
152
|
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
153
|
+
# Defines a service input
|
154
|
+
#
|
155
|
+
# The specified input becomes a named parameter for the service's `#call` method.
|
156
|
+
#
|
157
|
+
# @param name [Symbol] This becomes the name of the input parameter
|
158
|
+
#
|
159
|
+
# @param block [Proc] If a block is provided, the contents of the block will be executed in
|
160
|
+
# the scope of the service instance in order to provide the default
|
161
|
+
# value of the input. This is different than providing a Proc to the
|
162
|
+
# `:default` option, which would simply return the Proc itself as the
|
163
|
+
# default value rather than calling it.
|
164
|
+
#
|
165
|
+
# @option options [Object] :default If specified (and no block is given), this becomes the
|
166
|
+
# literal default value for the input.
|
167
|
+
def input(name, **options, &block)
|
168
|
+
if options.key?(:default) || block
|
169
|
+
make_optional_input(name, options[:default], &block)
|
160
170
|
else
|
171
|
+
attr_accessor name, make_private: true
|
161
172
|
required_inputs << name
|
162
173
|
end
|
163
174
|
self
|
164
175
|
end
|
176
|
+
|
177
|
+
private
|
178
|
+
|
179
|
+
def make_optional_input(name, default, &block)
|
180
|
+
attr_writer name
|
181
|
+
private "#{name}="
|
182
|
+
default_routine = block || -> { default }
|
183
|
+
define_method("_#{name}", &default_routine)
|
184
|
+
define_method(name) do
|
185
|
+
instance_variable_get("@#{name}") || send("_#{name}")
|
186
|
+
end
|
187
|
+
required_inputs.delete(name)
|
188
|
+
end
|
165
189
|
end
|
166
190
|
|
167
191
|
# Holds the result of running a service as well as the execution status
|
@@ -239,16 +263,21 @@ module TheHelp
|
|
239
263
|
# @return [TheHelp::Service::Result]
|
240
264
|
def call
|
241
265
|
validate_service_definition
|
266
|
+
|
242
267
|
catch(:stop) do
|
243
268
|
authorize
|
244
269
|
log_service_call
|
245
270
|
main
|
246
271
|
check_result!
|
247
|
-
self.block_result = yield result if block_given?
|
248
272
|
end
|
273
|
+
|
274
|
+
self.block_result = yield result if block_given?
|
275
|
+
|
249
276
|
throw :stop if stop_caller
|
277
|
+
|
250
278
|
return block_result if block_given?
|
251
|
-
|
279
|
+
|
280
|
+
result
|
252
281
|
end
|
253
282
|
|
254
283
|
private
|
@@ -291,11 +320,20 @@ module TheHelp
|
|
291
320
|
return if authorized?
|
292
321
|
logger.warn("Unauthorized attempt to access #{self.class.name}/#{__id__} " \
|
293
322
|
"as #{context.inspect}")
|
294
|
-
run_callback(not_authorized, service: self.class, context: context)
|
323
|
+
result.error run_callback(not_authorized, service: self.class, context: context)
|
295
324
|
stop!
|
296
325
|
end
|
297
326
|
|
298
|
-
def stop!
|
327
|
+
def stop!(type: :error, **opts)
|
328
|
+
value = opts.fetch(:value) { |key|
|
329
|
+
check_result!
|
330
|
+
throw :stop
|
331
|
+
}
|
332
|
+
if type == :success
|
333
|
+
result.success value
|
334
|
+
else
|
335
|
+
result.error value
|
336
|
+
end
|
299
337
|
throw :stop
|
300
338
|
end
|
301
339
|
|
data/lib/the_help/version.rb
CHANGED
data/the_help.gemspec
CHANGED
@@ -23,7 +23,7 @@ Gem::Specification.new do |spec|
|
|
23
23
|
spec.require_paths = ['lib']
|
24
24
|
|
25
25
|
spec.add_development_dependency 'byebug'
|
26
|
-
spec.add_development_dependency 'rake', '~>
|
26
|
+
spec.add_development_dependency 'rake', '~> 13.0'
|
27
27
|
spec.add_development_dependency 'rspec', '~> 3.0'
|
28
28
|
spec.add_development_dependency 'rubocop', '~> 0.50'
|
29
29
|
spec.add_development_dependency 'yard'
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: the_help
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.
|
4
|
+
version: 3.3.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- John Wilger
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-10-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: byebug
|
@@ -30,14 +30,14 @@ dependencies:
|
|
30
30
|
requirements:
|
31
31
|
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '
|
33
|
+
version: '13.0'
|
34
34
|
type: :development
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: '
|
40
|
+
version: '13.0'
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: rspec
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
@@ -93,6 +93,7 @@ files:
|
|
93
93
|
- ".rubocop.yml"
|
94
94
|
- ".tool-versions"
|
95
95
|
- ".travis.yml"
|
96
|
+
- CHANGELOG.md
|
96
97
|
- CODE_OF_CONDUCT.md
|
97
98
|
- Gemfile
|
98
99
|
- Gemfile.lock
|