From d88c11735ef900020451bdf2fd5d185477703f7d Mon Sep 17 00:00:00 2001 From: Amey Kusurkar Date: Fri, 12 Jul 2024 11:43:08 +0100 Subject: [PATCH] Refactor loading logic Split the logic for loading a value from parsing the value, that way we only need to check if the env var is required in one place. --- lib/prius/registry.rb | 26 +++++++++----------------- 1 file changed, 9 insertions(+), 17 deletions(-) diff --git a/lib/prius/registry.rb b/lib/prius/registry.rb index abe78bf..96ff378 100644 --- a/lib/prius/registry.rb +++ b/lib/prius/registry.rb @@ -17,11 +17,12 @@ def initialize(env) # See Prius.load for documentation. def load(name, env_var: nil, type: :string, required: true) env_var = name.to_s.upcase if env_var.nil? + value = load_value(env_var, required) @registry[name] = case type - when :string then load_string(env_var, required) - when :int then load_int(env_var, required) - when :bool then load_bool(env_var, required) - when :date then load_date(env_var, required) + when :string then value + when :int then parse_int(env_var, value) + when :bool then parse_bool(env_var, value) + when :date then parse_date(env_var, value) else raise ArgumentError, "Invalid type #{type}" end end @@ -35,7 +36,7 @@ def get(name) private - def load_string(name, required) + def load_value(name, required) @env.fetch(name) rescue KeyError return nil unless required @@ -43,10 +44,7 @@ def load_string(name, required) raise MissingValueError, "config value '#{name}' not present" end - def load_int(name, required) - value = load_string(name, required) - return value if value.nil? - + def parse_int(name, value) unless /\A[0-9]+\z/.match?(value) raise TypeMismatchError, "'#{name}' value '#{value}' is not an integer" end @@ -54,10 +52,7 @@ def load_int(name, required) value.to_i end - def load_bool(name, required) - value = load_string(name, required) - return nil if value.nil? - + def parse_bool(name, value) value = value.downcase return true if %w[yes y true t 1].include?(value) return false if %w[no n false f 0].include?(value) @@ -65,10 +60,7 @@ def load_bool(name, required) raise TypeMismatchError, "'#{name}' value '#{value}' is not a boolean" end - def load_date(name, required) - value = load_string(name, required) - return nil if value.nil? - + def parse_date(name, value) Date.parse(value) rescue ArgumentError raise TypeMismatchError, "'#{name}' value '#{value}' is not a date"