Class: StatsigDriver
- Inherits:
-
Object
- Object
- StatsigDriver
- Defined in:
- lib/statsig_driver.rb
Instance Method Summary collapse
- #check_gate(user, gate_name) ⇒ Object
- #get_config(user, dynamic_config_name) ⇒ Object
- #get_experiment(user, experiment_name) ⇒ Object
-
#initialize(secret_key, options = nil) ⇒ StatsigDriver
constructor
A new instance of StatsigDriver.
- #log_event(user, event_name, value = nil, metadata = nil) ⇒ Object
- #shutdown ⇒ Object
Constructor Details
#initialize(secret_key, options = nil) ⇒ StatsigDriver
Returns a new instance of StatsigDriver.
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/statsig_driver.rb', line 11 def initialize(secret_key, = nil) super() if !secret_key.is_a?(String) || !secret_key.start_with?('secret-') raise 'Invalid secret key provided. Provide your project secret key from the Statsig console' end if !.nil? && !.instance_of?(StatsigOptions) raise 'Invalid options provided. Either provide a valid StatsigOptions object or nil' end @options = || StatsigOptions.new() @shutdown = false @secret_key = secret_key @net = Network.new(secret_key, @options.api_url_base) @statsig_metadata = { 'sdkType' => 'ruby-server', 'sdkVersion' => Gem::Specification::load('statsig.gemspec')&.version, } @logger = StatsigLogger.new(@net, @statsig_metadata) downloaded_specs = @net.download_config_specs unless downloaded_specs.nil? @initialized = true end @store = SpecStore.new(downloaded_specs) @evaluator = Evaluator.new(@store) @polling_thread = @net.poll_for_changes(-> (config_specs) { @store.process(config_specs) }) end |
Instance Method Details
#check_gate(user, gate_name) ⇒ Object
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 |
# File 'lib/statsig_driver.rb', line 41 def check_gate(user, gate_name) validate_user(user) user = normalize_user(user) if !gate_name.is_a?(String) || gate_name.empty? raise 'Invalid gate_name provided' end check_shutdown unless @initialized return false end res = @evaluator.check_gate(user, gate_name) if res.nil? res = ConfigResult.new(gate_name) end if res == $fetch_from_server res = check_gate_fallback(user, gate_name) # exposure logged by the server else @logger.log_gate_exposure(user, res.name, res.gate_value, res.rule_id, res.secondary_exposures) end res.gate_value end |
#get_config(user, dynamic_config_name) ⇒ Object
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 |
# File 'lib/statsig_driver.rb', line 67 def get_config(user, dynamic_config_name) validate_user(user) user = normalize_user(user) if !dynamic_config_name.is_a?(String) || dynamic_config_name.empty? raise "Invalid dynamic_config_name provided" end check_shutdown unless @initialized return DynamicConfig.new(dynamic_config_name) end res = @evaluator.get_config(user, dynamic_config_name) if res.nil? res = ConfigResult.new(dynamic_config_name) end if res == $fetch_from_server res = get_config_fallback(user, dynamic_config_name) # exposure logged by the server else @logger.log_config_exposure(user, res.name, res.rule_id, res.secondary_exposures) end DynamicConfig.new(res.name, res.json_value, res.rule_id) end |
#get_experiment(user, experiment_name) ⇒ Object
93 94 95 96 97 98 |
# File 'lib/statsig_driver.rb', line 93 def get_experiment(user, experiment_name) if !experiment_name.is_a?(String) || experiment_name.empty? raise "Invalid experiment_name provided" end get_config(user, experiment_name) end |
#log_event(user, event_name, value = nil, metadata = nil) ⇒ Object
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 |
# File 'lib/statsig_driver.rb', line 100 def log_event(user, event_name, value = nil, = nil) if !user.nil? && !user.instance_of?(StatsigUser) raise 'Must provide a valid StatsigUser or nil' end check_shutdown user = normalize_user(user) event = StatsigEvent.new(event_name) event.user = user event.value = value event. = event. = @statsig_metadata @logger.log_event(event) end |
#shutdown ⇒ Object
116 117 118 119 120 |
# File 'lib/statsig_driver.rb', line 116 def shutdown @shutdown = true @logger.flush(true) @polling_thread&.exit end |