X7ROOT File Manager
Current Path:
/opt/alt/ruby26/lib64/ruby/2.6.0/bundler
opt
/
alt
/
ruby26
/
lib64
/
ruby
/
2.6.0
/
bundler
/
ðŸ“
..
📄
build_metadata.rb
(1.61 KB)
📄
capistrano.rb
(879 B)
ðŸ“
cli
📄
cli.rb
(35.12 KB)
ðŸ“
compact_index_client
📄
compact_index_client.rb
(3.27 KB)
📄
compatibility_guard.rb
(518 B)
📄
constants.rb
(212 B)
📄
current_ruby.rb
(2.19 KB)
📄
definition.rb
(36.44 KB)
📄
dep_proxy.rb
(827 B)
📄
dependency.rb
(4.43 KB)
📄
deployment.rb
(3.19 KB)
📄
deprecate.rb
(876 B)
📄
dsl.rb
(21.46 KB)
📄
endpoint_specification.rb
(3.91 KB)
📄
env.rb
(5.22 KB)
📄
environment_preserver.rb
(1.31 KB)
📄
errors.rb
(4.59 KB)
📄
feature_flag.rb
(3.07 KB)
ðŸ“
fetcher
📄
fetcher.rb
(10.83 KB)
📄
friendly_errors.rb
(4.33 KB)
📄
gem_helper.rb
(5.88 KB)
📄
gem_helpers.rb
(3.19 KB)
📄
gem_remote_fetcher.rb
(1.46 KB)
📄
gem_tasks.rb
(137 B)
📄
gem_version_promoter.rb
(6.52 KB)
📄
gemdeps.rb
(423 B)
📄
graph.rb
(5 KB)
📄
index.rb
(5.24 KB)
📄
injector.rb
(8.61 KB)
📄
inline.rb
(2.33 KB)
ðŸ“
installer
📄
installer.rb
(11.85 KB)
📄
lazy_specification.rb
(3.62 KB)
📄
lockfile_generator.rb
(2.18 KB)
📄
lockfile_parser.rb
(8.62 KB)
📄
match_platform.rb
(659 B)
📄
mirror.rb
(5.79 KB)
ðŸ“
plugin
📄
plugin.rb
(9.12 KB)
📄
process_lock.rb
(702 B)
📄
psyched_yaml.rb
(853 B)
📄
remote_specification.rb
(3.46 KB)
ðŸ“
resolver
📄
resolver.rb
(14.2 KB)
📄
retry.rb
(1.6 KB)
📄
ruby_dsl.rb
(761 B)
📄
ruby_version.rb
(4.96 KB)
📄
rubygems_ext.rb
(5.88 KB)
📄
rubygems_gem_installer.rb
(3.49 KB)
📄
rubygems_integration.rb
(25.01 KB)
📄
runtime.rb
(10.95 KB)
ðŸ“
settings
📄
settings.rb
(12.38 KB)
📄
setup.rb
(720 B)
📄
shared_helpers.rb
(12 KB)
📄
similarity_detector.rb
(1.84 KB)
ðŸ“
source
📄
source.rb
(2.66 KB)
📄
source_list.rb
(5.87 KB)
📄
spec_set.rb
(5.34 KB)
ðŸ“
ssl_certs
📄
stub_specification.rb
(2.78 KB)
ðŸ“
templates
ðŸ“
ui
📄
ui.rb
(198 B)
📄
uri_credentials_filter.rb
(1.2 KB)
ðŸ“
vendor
📄
vendored_fileutils.rb
(192 B)
📄
vendored_molinillo.rb
(100 B)
📄
vendored_persistent.rb
(1.61 KB)
📄
vendored_thor.rb
(193 B)
📄
version.rb
(821 B)
📄
version_ranges.rb
(2.86 KB)
📄
vlad.rb
(466 B)
📄
worker.rb
(2.57 KB)
📄
yaml_serializer.rb
(2.41 KB)
Editing: mirror.rb
# frozen_string_literal: true require "socket" module Bundler class Settings # Class used to build the mirror set and then find a mirror for a given URI # # @param prober [Prober object, nil] by default a TCPSocketProbe, this object # will be used to probe the mirror address to validate that the mirror replies. class Mirrors def initialize(prober = nil) @all = Mirror.new @prober = prober || TCPSocketProbe.new @mirrors = {} end # Returns a mirror for the given uri. # # Depending on the uri having a valid mirror or not, it may be a # mirror that points to the provided uri def for(uri) if @all.validate!(@prober).valid? @all else fetch_valid_mirror_for(Settings.normalize_uri(uri)) end end def each @mirrors.each do |k, v| yield k, v.uri.to_s end end def parse(key, value) config = MirrorConfig.new(key, value) mirror = if config.all? @all else @mirrors[config.uri] ||= Mirror.new end config.update_mirror(mirror) end private def fetch_valid_mirror_for(uri) downcased = uri.to_s.downcase mirror = @mirrors[downcased] || @mirrors[URI(downcased).host] || Mirror.new(uri) mirror.validate!(@prober) mirror = Mirror.new(uri) unless mirror.valid? mirror end end # A mirror # # Contains both the uri that should be used as a mirror and the # fallback timeout which will be used for probing if the mirror # replies on time or not. class Mirror DEFAULT_FALLBACK_TIMEOUT = 0.1 attr_reader :uri, :fallback_timeout def initialize(uri = nil, fallback_timeout = 0) self.uri = uri self.fallback_timeout = fallback_timeout @valid = nil end def uri=(uri) @uri = if uri.nil? nil else URI(uri.to_s) end @valid = nil end def fallback_timeout=(timeout) case timeout when true, "true" @fallback_timeout = DEFAULT_FALLBACK_TIMEOUT when false, "false" @fallback_timeout = 0 else @fallback_timeout = timeout.to_i end @valid = nil end def ==(other) !other.nil? && uri == other.uri && fallback_timeout == other.fallback_timeout end def valid? return false if @uri.nil? return @valid unless @valid.nil? false end def validate!(probe = nil) @valid = false if uri.nil? if @valid.nil? @valid = fallback_timeout == 0 || (probe || TCPSocketProbe.new).replies?(self) end self end end # Class used to parse one configuration line # # Gets the configuration line and the value. # This object provides a `update_mirror` method # used to setup the given mirror value. class MirrorConfig attr_accessor :uri, :value def initialize(config_line, value) uri, fallback = config_line.match(%r{\Amirror\.(all|.+?)(\.fallback_timeout)?\/?\z}).captures @fallback = !fallback.nil? @all = false if uri == "all" @all = true else @uri = URI(uri).absolute? ? Settings.normalize_uri(uri) : uri end @value = value end def all? @all end def update_mirror(mirror) if @fallback mirror.fallback_timeout = @value else mirror.uri = Settings.normalize_uri(@value) end end end # Class used for probing TCP availability for a given mirror. class TCPSocketProbe def replies?(mirror) MirrorSockets.new(mirror).any? do |socket, address, timeout| begin socket.connect_nonblock(address) rescue Errno::EINPROGRESS wait_for_writtable_socket(socket, address, timeout) rescue RuntimeError # Connection failed somehow, again false end end end private def wait_for_writtable_socket(socket, address, timeout) if IO.select(nil, [socket], nil, timeout) probe_writtable_socket(socket, address) else # TCP Handshake timed out, or there is something dropping packets false end end def probe_writtable_socket(socket, address) socket.connect_nonblock(address) rescue Errno::EISCONN true rescue StandardError # Connection failed false end end end # Class used to build the list of sockets that correspond to # a given mirror. # # One mirror may correspond to many different addresses, both # because of it having many dns entries or because # the network interface is both ipv4 and ipv5 class MirrorSockets def initialize(mirror) @timeout = mirror.fallback_timeout @addresses = Socket.getaddrinfo(mirror.uri.host, mirror.uri.port).map do |address| SocketAddress.new(address[0], address[3], address[1]) end end def any? @addresses.any? do |address| socket = Socket.new(Socket.const_get(address.type), Socket::SOCK_STREAM, 0) socket.setsockopt(Socket::IPPROTO_TCP, Socket::TCP_NODELAY, 1) value = yield socket, address.to_socket_address, @timeout socket.close unless socket.closed? value end end end # Socket address builder. # # Given a socket type, a host and a port, # provides a method to build sockaddr string class SocketAddress attr_reader :type, :host, :port def initialize(type, host, port) @type = type @host = host @port = port end def to_socket_address Socket.pack_sockaddr_in(@port, @host) end end end
Upload File
Create Folder