Class: Bundler::Settings

Inherits:
Object
  • Object
show all
Defined in:
lib/bundler/mirror.rb,
lib/bundler/settings.rb,
lib/bundler/settings/validator.rb

Defined Under Namespace

Classes: Mirror, MirrorConfig, Mirrors, Path, TCPSocketProbe, Validator

Constant Summary collapse

BOOL_KEYS =
%w[
  allow_deployment_source_credential_changes
  allow_offline_install
  auto_clean_without_path
  auto_install
  cache_all
  cache_all_platforms
  clean
  default_install_uses_path
  deployment
  deployment_means_frozen
  disable_checksum_validation
  disable_exec_load
  disable_local_branch_check
  disable_local_revision_check
  disable_shared_gems
  disable_version_check
  force_ruby_platform
  forget_cli_options
  frozen
  gem.changelog
  gem.coc
  gem.mit
  git.allow_insecure
  global_gem_cache
  ignore_messages
  init_gems_rb
  inline
  no_install
  no_prune
  path_relative_to_cwd
  path.system
  plugins
  prefer_patch
  print_only_version_number
  setup_makes_kernel_gem_public
  silence_deprecations
  silence_root_warning
  suppress_install_using_messages
  unlock_source_unlocks_spec
  update_requires_all_flag
  use_gem_version_promoter_for_major_updates
].freeze
NUMBER_KEYS =
%w[
  jobs
  redirect
  retry
  ssl_verify_mode
  timeout
].freeze
ARRAY_KEYS =
%w[
  with
  without
].freeze
STRING_KEYS =
%w[
  bin
  cache_path
  console
  gem.ci
  gem.github_username
  gem.linter
  gem.rubocop
  gem.test
  gemfile
  path
  shebang
  system_bindir
  trust-policy
].freeze
DEFAULT_CONFIG =
{
  "BUNDLE_SILENCE_DEPRECATIONS" => false,
  "BUNDLE_DISABLE_VERSION_CHECK" => true,
  "BUNDLE_PREFER_PATCH" => false,
  "BUNDLE_REDIRECT" => 5,
  "BUNDLE_RETRY" => 3,
  "BUNDLE_TIMEOUT" => 10,
}.freeze

Instance Method Summary collapse

Constructor Details

#initialize(root = nil) ⇒ Settings

Returns a new instance of Settings.



91
92
93
94
95
96
97
# File 'lib/bundler/settings.rb', line 91

def initialize(root = nil)
  @root            = root
  @local_config    = load_config(local_config_file)
  @env_config      = ENV.to_h.select {|key, _value| key =~ /\ABUNDLE_.+/ }
  @global_config   = load_config(global_config_file)
  @temporary       = {}
end

Instance Method Details

#[](name) ⇒ Object



99
100
101
102
103
104
# File 'lib/bundler/settings.rb', line 99

def [](name)
  key = key_for(name)
  value = configs.values.map {|config| config[key] }.compact.first

  converted_value(value, name)
end

#allObject



143
144
145
146
147
148
149
# File 'lib/bundler/settings.rb', line 143

def all
  keys = @temporary.keys | @global_config.keys | @local_config.keys | @env_config.keys

  keys.map do |key|
    key.sub(/^BUNDLE_/, "").gsub(/___/, "-").gsub(/__/, ".").downcase
  end.sort
end

#allow_sudo?Boolean

Returns:

  • (Boolean)


274
275
276
277
278
# File 'lib/bundler/settings.rb', line 274

def allow_sudo?
  key = key_for(:path)
  path_configured = @temporary.key?(key) || @local_config.key?(key)
  !path_configured
end

#app_cache_pathObject



284
285
286
# File 'lib/bundler/settings.rb', line 284

def app_cache_path
  @app_cache_path ||= self[:cache_path] || "vendor/cache"
end

#credentials_for(uri) ⇒ Object



168
169
170
# File 'lib/bundler/settings.rb', line 168

def credentials_for(uri)
  self[uri.to_s] || self[uri.host]
end

#gem_mirrorsObject



172
173
174
175
176
177
# File 'lib/bundler/settings.rb', line 172

def gem_mirrors
  all.inject(Mirrors.new) do |mirrors, k|
    mirrors.parse(k, self[k]) if k.start_with?("mirror.")
    mirrors
  end
end

#ignore_config?Boolean

Returns:

  • (Boolean)


280
281
282
# File 'lib/bundler/settings.rb', line 280

def ignore_config?
  ENV["BUNDLE_IGNORE_CONFIG"]
end

#key_for(key) ⇒ Object



297
298
299
# File 'lib/bundler/settings.rb', line 297

def key_for(key)
  self.class.key_for(key)
end

#local_overridesObject



151
152
153
154
155
156
157
# File 'lib/bundler/settings.rb', line 151

def local_overrides
  repos = {}
  all.each do |k|
    repos[$'] = self[k] if k =~ /^local\./
  end
  repos
end

#locations(key) ⇒ Object



179
180
181
182
183
184
185
186
# File 'lib/bundler/settings.rb', line 179

def locations(key)
  key = key_for(key)
  configs.keys.inject({}) do |partial_locations, level|
    value_on_level = configs[level][key]
    partial_locations[level] = value_on_level unless value_on_level.nil?
    partial_locations
  end
end

#mirror_for(uri) ⇒ Object



159
160
161
162
163
164
165
166
# File 'lib/bundler/settings.rb', line 159

def mirror_for(uri)
  if uri.is_a?(String)
    require_relative "vendored_uri"
    uri = Bundler::URI(uri)
  end

  gem_mirrors.for(uri.to_s).uri
end

#pathObject

for legacy reasons, in Bundler 2, we do not respect :disable_shared_gems



214
215
216
217
218
219
220
221
222
223
224
225
# File 'lib/bundler/settings.rb', line 214

def path
  configs.each do |_level, settings|
    path = value_for("path", settings)
    path_system = value_for("path.system", settings)
    disabled_shared_gems = value_for("disable_shared_gems", settings)
    next if path.nil? && path_system.nil? && disabled_shared_gems.nil?
    system_path = path_system || (disabled_shared_gems == false)
    return Path.new(path, system_path)
  end

  Path.new(nil, false)
end

#pretty_values_for(exposed_key) ⇒ Object



188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
# File 'lib/bundler/settings.rb', line 188

def pretty_values_for(exposed_key)
  key = key_for(exposed_key)

  locations = []

  if value = @temporary[key]
    locations << "Set for the current command: #{printable_value(value, exposed_key).inspect}"
  end

  if value = @local_config[key]
    locations << "Set for your local app (#{local_config_file}): #{printable_value(value, exposed_key).inspect}"
  end

  if value = @env_config[key]
    locations << "Set via #{key}: #{printable_value(value, exposed_key).inspect}"
  end

  if value = @global_config[key]
    locations << "Set for the current user (#{global_config_file}): #{printable_value(value, exposed_key).inspect}"
  end

  return ["You have not configured a value for `#{exposed_key}`"] if locations.empty?
  locations
end

#set_command_option(key, value) ⇒ Object



106
107
108
109
110
111
112
113
# File 'lib/bundler/settings.rb', line 106

def set_command_option(key, value)
  if Bundler.feature_flag.forget_cli_options?
    temporary(key => value)
    value
  else
    set_local(key, value)
  end
end

#set_command_option_if_given(key, value) ⇒ Object



115
116
117
118
# File 'lib/bundler/settings.rb', line 115

def set_command_option_if_given(key, value)
  return if value.nil?
  set_command_option(key, value)
end

#set_global(key, value) ⇒ Object



139
140
141
# File 'lib/bundler/settings.rb', line 139

def set_global(key, value)
  set_key(key, value, @global_config, global_config_file)
end

#set_local(key, value) ⇒ Object



120
121
122
123
124
# File 'lib/bundler/settings.rb', line 120

def set_local(key, value)
  local_config_file || raise(GemfileNotFound, "Could not locate Gemfile")

  set_key(key, value, @local_config, local_config_file)
end

#temporary(update) ⇒ Object



126
127
128
129
130
131
132
133
134
135
136
137
# File 'lib/bundler/settings.rb', line 126

def temporary(update)
  existing = Hash[update.map {|k, _| [k, @temporary[key_for(k)]] }]
  update.each do |k, v|
    set_key(k, v, @temporary, nil)
  end
  return unless block_given?
  begin
    yield
  ensure
    existing.each {|k, v| set_key(k, v, @temporary, nil) }
  end
end

#validate!Object



288
289
290
291
292
293
294
295
# File 'lib/bundler/settings.rb', line 288

def validate!
  all.each do |raw_key|
    [@local_config, @env_config, @global_config].each do |settings|
      value = value_for(raw_key, settings)
      Validator.validate!(raw_key, value, settings.dup)
    end
  end
end