eppo-server-sdk 0.2.3 → 0.2.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/lib/eppo_client/rules.rb +34 -2
- data/lib/eppo_client/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 98acb6907559d59d41dabba40eff3cc95404c1d2283144f73a64e05dd94b4688
|
|
4
|
+
data.tar.gz: 86b21cbf7552a6641e34dafedb1c158812777d27821818ee3e067dd6ca1e6eff
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 38d1f7c43ded991c029cd7ac3e3c3c71116862899008d7163d216be45dd585cc7a3ea00ba04870cba2f771aeb589a75b50835c2a4d4e792de3d886879bfda7bd
|
|
7
|
+
data.tar.gz: 2e2e690225134fb4d76d36d605f4d391aeddd3b8d0f831e5f12516ca3d9fab2f5d4267812158d266a243b4d0f53d86a0d752d14a8420e6ad8bc996ded7f13184
|
data/lib/eppo_client/rules.rb
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
|
+
require 'semver'
|
|
4
|
+
|
|
3
5
|
# The helper module for rules
|
|
4
6
|
module EppoClient
|
|
5
7
|
module OperatorType
|
|
@@ -60,7 +62,12 @@ module EppoClient
|
|
|
60
62
|
when OperatorType::NOT_ONE_OF
|
|
61
63
|
!condition.value.map(&:downcase).include?(subject_value.to_s.downcase)
|
|
62
64
|
else
|
|
63
|
-
|
|
65
|
+
# Numeric operator: value could be numeric or semver.
|
|
66
|
+
if subject_value.is_a?(Numeric)
|
|
67
|
+
evaluate_numeric_condition(subject_value, condition)
|
|
68
|
+
elsif valid_semver?(subject_value)
|
|
69
|
+
compare_semver(subject_value, condition.value, condition.operator)
|
|
70
|
+
end
|
|
64
71
|
end
|
|
65
72
|
end
|
|
66
73
|
# rubocop:enable Metrics/AbcSize, Metrics/MethodLength
|
|
@@ -82,6 +89,31 @@ module EppoClient
|
|
|
82
89
|
end
|
|
83
90
|
# rubocop:enable Metrics/MethodLength
|
|
84
91
|
|
|
92
|
+
# rubocop:disable Metrics/MethodLength
|
|
93
|
+
def compare_semver(attribute_value, condition_value, operator)
|
|
94
|
+
unless valid_semver?(attribute_value) && valid_semver?(condition_value)
|
|
95
|
+
return false
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
case operator
|
|
99
|
+
when OperatorType::GT
|
|
100
|
+
SemVer.parse(attribute_value) > SemVer.parse(condition_value)
|
|
101
|
+
when OperatorType::GTE
|
|
102
|
+
SemVer.parse(attribute_value) >= SemVer.parse(condition_value)
|
|
103
|
+
when OperatorType::LT
|
|
104
|
+
SemVer.parse(attribute_value) < SemVer.parse(condition_value)
|
|
105
|
+
when OperatorType::LTE
|
|
106
|
+
SemVer.parse(attribute_value) <= SemVer.parse(condition_value)
|
|
107
|
+
else
|
|
108
|
+
false
|
|
109
|
+
end
|
|
110
|
+
end
|
|
111
|
+
# rubocop:enable Metrics/MethodLength
|
|
112
|
+
|
|
113
|
+
def valid_semver?(string)
|
|
114
|
+
!SemVer.parse(string).nil?
|
|
115
|
+
end
|
|
116
|
+
|
|
85
117
|
module_function :find_matching_rule, :matches_rule, :evaluate_condition,
|
|
86
|
-
:evaluate_numeric_condition
|
|
118
|
+
:evaluate_numeric_condition, :valid_semver?, :compare_semver
|
|
87
119
|
end
|
data/lib/eppo_client/version.rb
CHANGED
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: eppo-server-sdk
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.2.
|
|
4
|
+
version: 0.2.4
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Eppo
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date:
|
|
11
|
+
date: 2024-03-12 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: concurrent-ruby
|