optimizely-sdk 5.0.0.pre.beta → 5.0.1

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.
Files changed (64) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +202 -202
  3. data/lib/optimizely/audience.rb +127 -127
  4. data/lib/optimizely/bucketer.rb +156 -156
  5. data/lib/optimizely/condition_tree_evaluator.rb +123 -123
  6. data/lib/optimizely/config/datafile_project_config.rb +48 -32
  7. data/lib/optimizely/config/proxy_config.rb +34 -34
  8. data/lib/optimizely/config_manager/async_scheduler.rb +95 -95
  9. data/lib/optimizely/config_manager/http_project_config_manager.rb +340 -338
  10. data/lib/optimizely/config_manager/project_config_manager.rb +25 -25
  11. data/lib/optimizely/config_manager/static_project_config_manager.rb +55 -54
  12. data/lib/optimizely/decide/optimizely_decide_option.rb +28 -28
  13. data/lib/optimizely/decide/optimizely_decision.rb +60 -60
  14. data/lib/optimizely/decide/optimizely_decision_message.rb +26 -26
  15. data/lib/optimizely/decision_service.rb +563 -563
  16. data/lib/optimizely/error_handler.rb +39 -39
  17. data/lib/optimizely/event/batch_event_processor.rb +235 -235
  18. data/lib/optimizely/event/entity/conversion_event.rb +44 -44
  19. data/lib/optimizely/event/entity/decision.rb +38 -38
  20. data/lib/optimizely/event/entity/event_batch.rb +86 -86
  21. data/lib/optimizely/event/entity/event_context.rb +50 -50
  22. data/lib/optimizely/event/entity/impression_event.rb +48 -48
  23. data/lib/optimizely/event/entity/snapshot.rb +33 -33
  24. data/lib/optimizely/event/entity/snapshot_event.rb +48 -48
  25. data/lib/optimizely/event/entity/user_event.rb +22 -22
  26. data/lib/optimizely/event/entity/visitor.rb +36 -36
  27. data/lib/optimizely/event/entity/visitor_attribute.rb +38 -38
  28. data/lib/optimizely/event/event_factory.rb +156 -156
  29. data/lib/optimizely/event/event_processor.rb +25 -25
  30. data/lib/optimizely/event/forwarding_event_processor.rb +44 -44
  31. data/lib/optimizely/event/user_event_factory.rb +88 -88
  32. data/lib/optimizely/event_builder.rb +221 -221
  33. data/lib/optimizely/event_dispatcher.rb +69 -69
  34. data/lib/optimizely/exceptions.rb +193 -149
  35. data/lib/optimizely/helpers/constants.rb +459 -459
  36. data/lib/optimizely/helpers/date_time_utils.rb +30 -30
  37. data/lib/optimizely/helpers/event_tag_utils.rb +132 -132
  38. data/lib/optimizely/helpers/group.rb +31 -31
  39. data/lib/optimizely/helpers/http_utils.rb +68 -68
  40. data/lib/optimizely/helpers/sdk_settings.rb +61 -61
  41. data/lib/optimizely/helpers/validator.rb +236 -238
  42. data/lib/optimizely/helpers/variable_type.rb +67 -67
  43. data/lib/optimizely/logger.rb +46 -46
  44. data/lib/optimizely/notification_center.rb +174 -174
  45. data/lib/optimizely/notification_center_registry.rb +71 -71
  46. data/lib/optimizely/odp/lru_cache.rb +114 -114
  47. data/lib/optimizely/odp/odp_config.rb +102 -102
  48. data/lib/optimizely/odp/odp_event.rb +75 -75
  49. data/lib/optimizely/odp/odp_event_api_manager.rb +70 -70
  50. data/lib/optimizely/odp/odp_event_manager.rb +286 -286
  51. data/lib/optimizely/odp/odp_manager.rb +159 -159
  52. data/lib/optimizely/odp/odp_segment_api_manager.rb +122 -122
  53. data/lib/optimizely/odp/odp_segment_manager.rb +97 -97
  54. data/lib/optimizely/optimizely_config.rb +273 -271
  55. data/lib/optimizely/optimizely_factory.rb +184 -186
  56. data/lib/optimizely/optimizely_user_context.rb +238 -238
  57. data/lib/optimizely/params.rb +31 -31
  58. data/lib/optimizely/project_config.rb +99 -99
  59. data/lib/optimizely/semantic_version.rb +166 -166
  60. data/lib/optimizely/user_condition_evaluator.rb +391 -391
  61. data/lib/optimizely/user_profile_service.rb +35 -35
  62. data/lib/optimizely/version.rb +21 -21
  63. data/lib/optimizely.rb +1262 -1262
  64. metadata +12 -10
@@ -1,95 +1,95 @@
1
- # frozen_string_literal: true
2
-
3
- #
4
- # Copyright 2019-2020, Optimizely and contributors
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
- #
18
- module Optimizely
19
- class AsyncScheduler
20
- attr_reader :running
21
-
22
- def initialize(callback, interval, auto_update, logger = nil, error_handler = nil)
23
- # Sets up AsyncScheduler to execute a callback periodically.
24
- #
25
- # callback - Main function to be executed periodically.
26
- # interval - How many seconds to wait between executions.
27
- # auto_update - boolean indicates to run infinitely or only once.
28
- # logger - Optional Provides a logger instance.
29
- # error_handler - Optional Provides a handle_error method to handle exceptions.
30
-
31
- @callback = callback
32
- @interval = interval
33
- @auto_update = auto_update
34
- @running = false
35
- @thread = nil
36
- @logger = logger || NoOpLogger.new
37
- @error_handler = error_handler || NoOpErrorHandler.new
38
- end
39
-
40
- def start!
41
- # Starts the async scheduler.
42
-
43
- if @running
44
- @logger.log(
45
- Logger::WARN,
46
- 'Scheduler is already running. Ignoring .start() call.'
47
- )
48
- return
49
- end
50
-
51
- begin
52
- @running = true
53
- @thread = Thread.new { execution_wrapper(@callback) }
54
- rescue StandardError => e
55
- @logger.log(
56
- Logger::ERROR,
57
- "Couldn't create a new thread for async scheduler. #{e.message}"
58
- )
59
- @error_handler.handle_error(e)
60
- end
61
- end
62
-
63
- def stop!
64
- # Stops the async scheduler.
65
-
66
- # If the scheduler is not running do nothing.
67
- return unless @running
68
-
69
- @running = false
70
- @thread.exit
71
- end
72
-
73
- private
74
-
75
- def execution_wrapper(callback)
76
- # Executes the given callback periodically
77
-
78
- loop do
79
- begin
80
- callback.call
81
- rescue StandardError => e
82
- @logger.log(
83
- Logger::ERROR,
84
- "Something went wrong when executing passed callback. #{e.message}"
85
- )
86
- @error_handler.handle_error(e)
87
- stop!
88
- end
89
- break unless @auto_update
90
-
91
- sleep @interval
92
- end
93
- end
94
- end
95
- end
1
+ # frozen_string_literal: true
2
+
3
+ #
4
+ # Copyright 2019-2020, Optimizely and contributors
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+ module Optimizely
19
+ class AsyncScheduler
20
+ attr_reader :running
21
+
22
+ def initialize(callback, interval, auto_update, logger = nil, error_handler = nil)
23
+ # Sets up AsyncScheduler to execute a callback periodically.
24
+ #
25
+ # callback - Main function to be executed periodically.
26
+ # interval - How many seconds to wait between executions.
27
+ # auto_update - boolean indicates to run infinitely or only once.
28
+ # logger - Optional Provides a logger instance.
29
+ # error_handler - Optional Provides a handle_error method to handle exceptions.
30
+
31
+ @callback = callback
32
+ @interval = interval
33
+ @auto_update = auto_update
34
+ @running = false
35
+ @thread = nil
36
+ @logger = logger || NoOpLogger.new
37
+ @error_handler = error_handler || NoOpErrorHandler.new
38
+ end
39
+
40
+ def start!
41
+ # Starts the async scheduler.
42
+
43
+ if @running
44
+ @logger.log(
45
+ Logger::WARN,
46
+ 'Scheduler is already running. Ignoring .start() call.'
47
+ )
48
+ return
49
+ end
50
+
51
+ begin
52
+ @running = true
53
+ @thread = Thread.new { execution_wrapper(@callback) }
54
+ rescue StandardError => e
55
+ @logger.log(
56
+ Logger::ERROR,
57
+ "Couldn't create a new thread for async scheduler. #{e.message}"
58
+ )
59
+ @error_handler.handle_error(e)
60
+ end
61
+ end
62
+
63
+ def stop!
64
+ # Stops the async scheduler.
65
+
66
+ # If the scheduler is not running do nothing.
67
+ return unless @running
68
+
69
+ @running = false
70
+ @thread.exit
71
+ end
72
+
73
+ private
74
+
75
+ def execution_wrapper(callback)
76
+ # Executes the given callback periodically
77
+
78
+ loop do
79
+ begin
80
+ callback.call
81
+ rescue StandardError => e
82
+ @logger.log(
83
+ Logger::ERROR,
84
+ "Something went wrong when executing passed callback. #{e.message}"
85
+ )
86
+ @error_handler.handle_error(e)
87
+ stop!
88
+ end
89
+ break unless @auto_update
90
+
91
+ sleep @interval
92
+ end
93
+ end
94
+ end
95
+ end