statsig 1.23.0 → 1.24.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/lib/config_result.rb +7 -1
- data/lib/dynamic_config.rb +10 -2
- data/lib/evaluator.rb +38 -7
- data/lib/spec_store.rb +1 -1
- data/lib/statsig.rb +1 -1
- data/lib/statsig_driver.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: 7a9c35b84fa7229be35e083126f1b498855e993fd2b6df379771040b6762d9c5
|
4
|
+
data.tar.gz: 92c19b6298b724706a6fc1f1157609b314f0c1b37a9942917259e21ad77d440d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3e0e9e2d0dc6677065baf7311f3978b247ffdabe63285644480c349155296b176fc0abeab704ed331eb61f9d0586904f3c8f2ef2bee31f91d303642b225e50c8
|
7
|
+
data.tar.gz: 84b0030cb12cc0409ffb14097d750205ce0291a2bc409744a74b8e4ccc38c9d5bdd71a40930a035a42ba24d69f864c8fb5b870b4a4b79c357abe80d59a90fd91
|
data/lib/config_result.rb
CHANGED
@@ -11,6 +11,8 @@ module Statsig
|
|
11
11
|
attr_accessor :explicit_parameters
|
12
12
|
attr_accessor :is_experiment_group
|
13
13
|
attr_accessor :evaluation_details
|
14
|
+
attr_accessor :group_name
|
15
|
+
attr_accessor :id_type
|
14
16
|
|
15
17
|
def initialize(
|
16
18
|
name,
|
@@ -21,7 +23,9 @@ module Statsig
|
|
21
23
|
config_delegate = '',
|
22
24
|
explicit_parameters = [],
|
23
25
|
is_experiment_group: false,
|
24
|
-
evaluation_details: nil
|
26
|
+
evaluation_details: nil,
|
27
|
+
group_name: nil,
|
28
|
+
id_type: '')
|
25
29
|
@name = name
|
26
30
|
@gate_value = gate_value
|
27
31
|
@json_value = json_value
|
@@ -32,6 +36,8 @@ module Statsig
|
|
32
36
|
@explicit_parameters = explicit_parameters
|
33
37
|
@is_experiment_group = is_experiment_group
|
34
38
|
@evaluation_details = evaluation_details
|
39
|
+
@group_name = group_name
|
40
|
+
@id_type = id_type
|
35
41
|
end
|
36
42
|
end
|
37
43
|
end
|
data/lib/dynamic_config.rb
CHANGED
@@ -20,11 +20,19 @@ class DynamicConfig
|
|
20
20
|
sig { returns(String) }
|
21
21
|
attr_accessor :rule_id
|
22
22
|
|
23
|
-
sig {
|
24
|
-
|
23
|
+
sig { returns(T.nilable(String)) }
|
24
|
+
attr_accessor :group_name
|
25
|
+
|
26
|
+
sig { returns(String) }
|
27
|
+
attr_accessor :id_type
|
28
|
+
|
29
|
+
sig { params(name: String, value: T::Hash[String, T.untyped], rule_id: String, group_name: T.nilable(String), id_type: String).void }
|
30
|
+
def initialize(name, value = {}, rule_id = '', group_name = nil, id_type = '')
|
25
31
|
@name = name
|
26
32
|
@value = value
|
27
33
|
@rule_id = rule_id
|
34
|
+
@group_name = group_name
|
35
|
+
@id_type = id_type
|
28
36
|
end
|
29
37
|
|
30
38
|
sig { params(index: String, default_value: T.untyped).returns(T.untyped) }
|
data/lib/evaluator.rb
CHANGED
@@ -53,14 +53,20 @@ module Statsig
|
|
53
53
|
end
|
54
54
|
|
55
55
|
def get_config(user, config_name)
|
56
|
-
if @config_overrides.
|
56
|
+
if @config_overrides.key?(config_name)
|
57
|
+
id_type = @spec_store.has_config?(config_name) ? @spec_store.get_config(config_name)['idType'] : ''
|
57
58
|
return Statsig::ConfigResult.new(
|
58
59
|
config_name,
|
59
60
|
false,
|
60
61
|
@config_overrides[config_name],
|
61
62
|
'override',
|
62
63
|
[],
|
63
|
-
evaluation_details: EvaluationDetails.local_override(
|
64
|
+
evaluation_details: EvaluationDetails.local_override(
|
65
|
+
@spec_store.last_config_sync_time,
|
66
|
+
@spec_store.initial_config_sync_time
|
67
|
+
),
|
68
|
+
id_type: id_type
|
69
|
+
)
|
64
70
|
end
|
65
71
|
|
66
72
|
if @spec_store.init_reason == EvaluationReason::UNINITIALIZED
|
@@ -68,7 +74,13 @@ module Statsig
|
|
68
74
|
end
|
69
75
|
|
70
76
|
unless @spec_store.has_config?(config_name)
|
71
|
-
return Statsig::ConfigResult.new(
|
77
|
+
return Statsig::ConfigResult.new(
|
78
|
+
config_name,
|
79
|
+
evaluation_details: EvaluationDetails.unrecognized(
|
80
|
+
@spec_store.last_config_sync_time,
|
81
|
+
@spec_store.initial_config_sync_time
|
82
|
+
)
|
83
|
+
)
|
72
84
|
end
|
73
85
|
|
74
86
|
eval_spec(user, @spec_store.get_config(config_name))
|
@@ -159,8 +171,14 @@ module Statsig
|
|
159
171
|
pass ? result.json_value : config['defaultValue'],
|
160
172
|
result.rule_id,
|
161
173
|
exposures,
|
162
|
-
evaluation_details: EvaluationDetails.new(
|
174
|
+
evaluation_details: EvaluationDetails.new(
|
175
|
+
@spec_store.last_config_sync_time,
|
176
|
+
@spec_store.initial_config_sync_time,
|
177
|
+
@spec_store.init_reason
|
178
|
+
),
|
163
179
|
is_experiment_group: result.is_experiment_group,
|
180
|
+
group_name: result.group_name,
|
181
|
+
id_type: config['idType']
|
164
182
|
)
|
165
183
|
end
|
166
184
|
|
@@ -176,7 +194,14 @@ module Statsig
|
|
176
194
|
config['defaultValue'],
|
177
195
|
default_rule_id,
|
178
196
|
exposures,
|
179
|
-
evaluation_details: EvaluationDetails.new(
|
197
|
+
evaluation_details: EvaluationDetails.new(
|
198
|
+
@spec_store.last_config_sync_time,
|
199
|
+
@spec_store.initial_config_sync_time,
|
200
|
+
@spec_store.init_reason
|
201
|
+
),
|
202
|
+
group_name: nil,
|
203
|
+
id_type: config['idType']
|
204
|
+
)
|
180
205
|
end
|
181
206
|
|
182
207
|
private
|
@@ -206,8 +231,14 @@ module Statsig
|
|
206
231
|
rule['returnValue'],
|
207
232
|
rule['id'],
|
208
233
|
exposures,
|
209
|
-
evaluation_details: EvaluationDetails.new(
|
210
|
-
|
234
|
+
evaluation_details: EvaluationDetails.new(
|
235
|
+
@spec_store.last_config_sync_time,
|
236
|
+
@spec_store.initial_config_sync_time,
|
237
|
+
@spec_store.init_reason
|
238
|
+
),
|
239
|
+
is_experiment_group: rule["isExperimentGroup"] == true,
|
240
|
+
group_name: rule['groupName']
|
241
|
+
)
|
211
242
|
end
|
212
243
|
|
213
244
|
def eval_delegate(name, user, rule, exposures)
|
data/lib/spec_store.rb
CHANGED
@@ -199,7 +199,7 @@ module Statsig
|
|
199
199
|
unless response.nil?
|
200
200
|
init_diagnostics&.mark("download_config_specs", "start", "process")
|
201
201
|
|
202
|
-
if process_specs(response.body)
|
202
|
+
if process_specs(response.body.to_s)
|
203
203
|
@init_reason = EvaluationReason::NETWORK
|
204
204
|
@rules_updated_callback.call(response.body.to_s, @last_config_sync_time) unless response.body.nil? or @rules_updated_callback.nil?
|
205
205
|
end
|
data/lib/statsig.rb
CHANGED
data/lib/statsig_driver.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: statsig
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.24.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Statsig, Inc
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-03-
|
11
|
+
date: 2023-03-24 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|