Class: Browserctl::SecretResolverRegistry

Inherits:
Object
  • Object
show all
Defined in:
lib/browserctl/secret_resolver_registry.rb

Class Method Summary collapse

Class Method Details

.record_resolved_value(value) ⇒ Object



49
50
51
52
53
# File 'lib/browserctl/secret_resolver_registry.rb', line 49

def self.record_resolved_value(value)
  return unless value.is_a?(String) && !value.empty?

  @mutex.synchronize { @resolved_values << value unless @resolved_values.include?(value) }
end

.register(resolver_class) ⇒ Object



11
12
13
14
# File 'lib/browserctl/secret_resolver_registry.rb', line 11

def self.register(resolver_class)
  instance = resolver_class.new
  @mutex.synchronize { @registry[resolver_class.scheme] = instance }
end

.registered?(scheme) ⇒ Boolean

Returns:

  • (Boolean)


38
39
40
# File 'lib/browserctl/secret_resolver_registry.rb', line 38

def self.registered?(scheme)
  @mutex.synchronize { @registry.key?(scheme) }
end

.reset!Object



55
56
57
58
59
60
# File 'lib/browserctl/secret_resolver_registry.rb', line 55

def self.reset!
  @mutex.synchronize do
    @registry.clear
    @resolved_values.clear
  end
end

.resolve(secret_ref) ⇒ Object



16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/browserctl/secret_resolver_registry.rb', line 16

def self.resolve(secret_ref)
  scheme, reference = secret_ref.split("://", 2)
  resolver = @mutex.synchronize { @registry[scheme] }
  raise SecretResolverError, "unknown secret resolver scheme '#{scheme}'" unless resolver

  unless resolver.available?
    msg = "'#{scheme}://' resolver is not available in this environment"
    if scheme == "keychain"
      msg += "\n  Use env://YOUR_VAR_NAME to source secrets from environment variables instead."
    end
    raise SecretResolverError, msg
  end

  value = resolver.resolve(reference)
  record_resolved_value(value)
  value
rescue SecretResolverError
  raise
rescue StandardError => e
  raise SecretResolverError, "secret resolution failed for #{secret_ref.inspect}: #{e.message}"
end

.resolved_valuesObject

In-memory record of values resolved during this process. Used by the Redactor so trace output never leaks values that flowed through the registry. Never persisted.



45
46
47
# File 'lib/browserctl/secret_resolver_registry.rb', line 45

def self.resolved_values
  @mutex.synchronize { @resolved_values.dup }
end