services 7.2.0 → 7.3.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +3 -3
- data/lib/services.rb +5 -8
- data/lib/services/asyncable.rb +24 -8
- data/lib/services/base.rb +4 -1
- data/lib/services/modules/uniqueness_checker.rb +3 -3
- data/lib/services/query.rb +4 -2
- data/lib/services/version.rb +1 -1
- data/services.gemspec +1 -1
- metadata +7 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 510d4c3f8f8663e0079e9a9cea599cbf4d6173b674531b3c562e86596b510cb8
|
4
|
+
data.tar.gz: b4c3da22b80c5336cb5d1db80f89519847e0057c25a6a9875fe4b4c5693eda05
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ae00b7c9086d4a975e347a57389a179b6c71dece21e16bf6fbd80dfe692b7a85b6204eaff77bf5109a0e02e08e45025ee6b95a3aae2cb4126d8878c575fd12e2
|
7
|
+
data.tar.gz: d98eba78f597b98c1df33a7f87d1d939153af67267246ec0a4c80363863871e48834cb76af59bc97d9c39994e699e554a9710ec634db96c8d97f3d4c1b7e082d
|
data/README.md
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
# Services
|
2
2
|
|
3
3
|
[![Gem Version](https://badge.fury.io/rb/services.png)](http://badge.fury.io/rb/services)
|
4
|
-
[![Build Status](https://secure.travis-ci.org/
|
5
|
-
[![Code Climate](https://codeclimate.com/github/
|
4
|
+
[![Build Status](https://secure.travis-ci.org/manuelmeurer/services.png)](http://travis-ci.org/manuelmeurer/services)
|
5
|
+
[![Code Climate](https://codeclimate.com/github/manuelmeurer/services.png)](https://codeclimate.com/github/manuelmeurer/services)
|
6
6
|
|
7
7
|
Services is a collection of modules and base classes that let you simply add a service layer to your Rails app.
|
8
8
|
|
@@ -28,7 +28,7 @@ Redis is used at several points, e.g. to store information about the currently r
|
|
28
28
|
|
29
29
|
#### Postgres (optional)
|
30
30
|
|
31
|
-
The SQL that `Services::Query` (discussed further down) generates is optimized for Postgres. It might work with other databases but it's not guaranteed. If you're not using Postgres, you can still use all other parts of Services, just don't use `Services::Query` or, even better, submit a [pull request](https://github.com/
|
31
|
+
The SQL that `Services::Query` (discussed further down) generates is optimized for Postgres. It might work with other databases but it's not guaranteed. If you're not using Postgres, you can still use all other parts of Services, just don't use `Services::Query` or, even better, submit a [pull request](https://github.com/manuelmeurer/services/issues) that fixes it to work with your database!
|
32
32
|
|
33
33
|
#### Sidekiq (optional)
|
34
34
|
|
data/lib/services.rb
CHANGED
@@ -5,8 +5,8 @@ require_relative 'services/logger/null'
|
|
5
5
|
module Services
|
6
6
|
include GemConfig::Base
|
7
7
|
|
8
|
-
|
9
|
-
RedisNotFound
|
8
|
+
NoBackgroundProcessorFound = Class.new(StandardError)
|
9
|
+
RedisNotFound = Class.new(StandardError)
|
10
10
|
|
11
11
|
with_configuration do
|
12
12
|
has :logger, default: Services::Logger::Null.new
|
@@ -18,18 +18,15 @@ module Services
|
|
18
18
|
@redis ||= self.configuration.redis || (defined?(Redis.current) && Redis.current) or fail RedisNotFound, 'Redis not configured.'
|
19
19
|
end
|
20
20
|
|
21
|
-
def self.allow_class_method_in_queries(klass, method)
|
22
|
-
(configuration.allowed_class_methods_in_queries[klass.to_s] ||=
|
21
|
+
def self.allow_class_method_in_queries(klass, method, arity = nil)
|
22
|
+
(configuration.allowed_class_methods_in_queries[klass.to_s] ||= {})[method.to_sym] = arity
|
23
23
|
end
|
24
24
|
end
|
25
25
|
|
26
26
|
require_relative 'services/version'
|
27
27
|
require_relative 'services/logger/file'
|
28
28
|
require_relative 'services/logger/redis'
|
29
|
-
|
30
|
-
require_relative 'services/asyncable'
|
31
|
-
rescue Services::BackgroundProcessorNotFound
|
32
|
-
end
|
29
|
+
require_relative 'services/asyncable'
|
33
30
|
require_relative 'services/modules/call_logger'
|
34
31
|
require_relative 'services/modules/exception_wrapper'
|
35
32
|
require_relative 'services/modules/object_class'
|
data/lib/services/asyncable.rb
CHANGED
@@ -1,13 +1,6 @@
|
|
1
1
|
require 'active_support/concern'
|
2
2
|
require 'global_id'
|
3
3
|
|
4
|
-
begin
|
5
|
-
require 'sidekiq'
|
6
|
-
require 'sidekiq/api'
|
7
|
-
rescue LoadError
|
8
|
-
raise Services::BackgroundProcessorNotFound
|
9
|
-
end
|
10
|
-
|
11
4
|
module Services
|
12
5
|
module Asyncable
|
13
6
|
extend ActiveSupport::Concern
|
@@ -15,7 +8,26 @@ module Services
|
|
15
8
|
ASYNC_METHOD_SUFFIXES = %i(async in at).freeze
|
16
9
|
|
17
10
|
included do
|
18
|
-
|
11
|
+
sidekiq_loaded = false
|
12
|
+
|
13
|
+
begin
|
14
|
+
require 'sidekiq'
|
15
|
+
require 'sidekiq/api'
|
16
|
+
rescue LoadError
|
17
|
+
else
|
18
|
+
include Sidekiq::Worker
|
19
|
+
sidekiq_loaded = true
|
20
|
+
end
|
21
|
+
|
22
|
+
unless sidekiq_loaded
|
23
|
+
begin
|
24
|
+
require 'sucker_punch'
|
25
|
+
rescue LoadError
|
26
|
+
raise Services::NoBackgroundProcessorFound
|
27
|
+
else
|
28
|
+
include SuckerPunch::Job
|
29
|
+
end
|
30
|
+
end
|
19
31
|
end
|
20
32
|
|
21
33
|
module ClassMethods
|
@@ -33,18 +45,22 @@ module Services
|
|
33
45
|
args = args.map do |arg|
|
34
46
|
GlobalID::Locator.locate(arg) || arg
|
35
47
|
end
|
48
|
+
|
36
49
|
# If the `call` method takes any kwargs and the last argument is a hash, symbolize the hash keys,
|
37
50
|
# otherwise they won't be recognized as kwards when splatted.
|
38
51
|
# Since the arguments to `perform` are serialized to the database before Sidekiq picks them up,
|
39
52
|
# symbol keys are converted to strings.
|
40
53
|
call_method = method(:call)
|
54
|
+
|
41
55
|
# Find the first class that inherits from `Services::Base`.
|
42
56
|
while !(call_method.owner < Services::Base)
|
43
57
|
call_method = call_method.super_method
|
44
58
|
end
|
59
|
+
|
45
60
|
if call_method.parameters.map(&:first).grep(/\Akey/).any? && args.last.is_a?(Hash)
|
46
61
|
args.last.symbolize_keys!
|
47
62
|
end
|
63
|
+
|
48
64
|
call *args
|
49
65
|
end
|
50
66
|
end
|
data/lib/services/base.rb
CHANGED
@@ -11,7 +11,10 @@ module Services
|
|
11
11
|
def inherited(subclass)
|
12
12
|
subclass.const_set :Error, Class.new(StandardError)
|
13
13
|
subclass.public_send :include, Rails.application.routes.url_helpers if defined?(Rails)
|
14
|
-
|
14
|
+
begin
|
15
|
+
subclass.public_send :include, Asyncable
|
16
|
+
rescue Services::NoBackgroundProcessorFound
|
17
|
+
end
|
15
18
|
subclass.public_send :prepend, CallLogger, ExceptionWrapper, UniquenessChecker
|
16
19
|
end
|
17
20
|
|
@@ -14,7 +14,7 @@ module Services
|
|
14
14
|
).freeze
|
15
15
|
|
16
16
|
MAX_RETRIES = 10.freeze
|
17
|
-
|
17
|
+
THIRTY_DAYS = (60 * 60 * 24 * 30).freeze
|
18
18
|
|
19
19
|
def self.prepended(mod)
|
20
20
|
mod.const_set :NotUniqueError, Class.new(mod::Error)
|
@@ -37,7 +37,7 @@ module Services
|
|
37
37
|
else
|
38
38
|
@_uniqueness_keys ||= []
|
39
39
|
@_uniqueness_keys << new_uniqueness_key
|
40
|
-
Services.redis.setex new_uniqueness_key,
|
40
|
+
Services.redis.setex new_uniqueness_key, THIRTY_DAYS, @id
|
41
41
|
true
|
42
42
|
end
|
43
43
|
end
|
@@ -103,7 +103,7 @@ module Services
|
|
103
103
|
end
|
104
104
|
|
105
105
|
def increase_error_count
|
106
|
-
Services.redis.setex error_count_key, retry_delay +
|
106
|
+
Services.redis.setex error_count_key, retry_delay + THIRTY_DAYS, error_count + 1
|
107
107
|
end
|
108
108
|
|
109
109
|
def uniqueness_key(args)
|
data/lib/services/query.rb
CHANGED
@@ -71,8 +71,10 @@ module Services
|
|
71
71
|
end
|
72
72
|
|
73
73
|
conditions.each do |k, v|
|
74
|
-
|
75
|
-
|
74
|
+
allowed_class_methods = Services.configuration.allowed_class_methods_in_queries[object_class.to_s]
|
75
|
+
if allowed_class_methods&.key?(k)
|
76
|
+
arity = allowed_class_methods[k] || object_class.method(k).arity
|
77
|
+
case arity
|
76
78
|
when 0
|
77
79
|
unless v == true
|
78
80
|
raise ArgumentError, "Method #{k} of class #{self} takes no arguments, so `true` must be passed as the value for this param, not #{v} (#{v.class})."
|
data/lib/services/version.rb
CHANGED
data/services.gemspec
CHANGED
@@ -11,7 +11,7 @@ Gem::Specification.new do |gem|
|
|
11
11
|
gem.email = 'manuel@krautcomputing.com'
|
12
12
|
gem.summary = 'A nifty service layer for your Rails app'
|
13
13
|
gem.description = 'A nifty service layer for your Rails app'
|
14
|
-
gem.homepage = 'http://
|
14
|
+
gem.homepage = 'http://manuelmeurer.github.io/services'
|
15
15
|
gem.license = 'MIT'
|
16
16
|
gem.required_ruby_version = '>= 2.2.5'
|
17
17
|
gem.files = `git ls-files`.split($/)
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: services
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 7.
|
4
|
+
version: 7.3.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Manuel Meurer
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-11-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rake
|
@@ -227,11 +227,11 @@ files:
|
|
227
227
|
- spec/support/redis-server
|
228
228
|
- spec/support/shared.rb
|
229
229
|
- spec/support/test_services.rb
|
230
|
-
homepage: http://
|
230
|
+
homepage: http://manuelmeurer.github.io/services
|
231
231
|
licenses:
|
232
232
|
- MIT
|
233
233
|
metadata: {}
|
234
|
-
post_install_message:
|
234
|
+
post_install_message:
|
235
235
|
rdoc_options: []
|
236
236
|
require_paths:
|
237
237
|
- lib
|
@@ -246,8 +246,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
246
246
|
- !ruby/object:Gem::Version
|
247
247
|
version: '0'
|
248
248
|
requirements: []
|
249
|
-
rubygems_version: 3.
|
250
|
-
signing_key:
|
249
|
+
rubygems_version: 3.1.3
|
250
|
+
signing_key:
|
251
251
|
specification_version: 4
|
252
252
|
summary: A nifty service layer for your Rails app
|
253
253
|
test_files:
|