In Files
- rubygems/security/trust_dir.rb
 
Parent
Class/Module Index
          ![show/hide quicksearch [+]](../../images/find.png)
        
        - Gem::AvailableSet
 - Gem::BasicSpecification
 - Gem::Command
 - Gem::CommandLineError
 - Gem::CommandManager
 - Gem::Commands
 - Gem::Commands::BuildCommand
 - Gem::Commands::CertCommand
 - Gem::Commands::CheckCommand
 - Gem::Commands::CleanupCommand
 - Gem::Commands::ContentsCommand
 - Gem::Commands::DependencyCommand
 - Gem::Commands::EnvironmentCommand
 - Gem::Commands::FetchCommand
 - Gem::Commands::GenerateIndexCommand
 - Gem::Commands::HelpCommand
 - Gem::Commands::InstallCommand
 - Gem::Commands::ListCommand
 - Gem::Commands::LockCommand
 - Gem::Commands::MirrorCommand
 - Gem::Commands::OpenCommand
 - Gem::Commands::OutdatedCommand
 - Gem::Commands::OwnerCommand
 - Gem::Commands::PristineCommand
 - Gem::Commands::PushCommand
 - Gem::Commands::QueryCommand
 - Gem::Commands::RdocCommand
 - Gem::Commands::SearchCommand
 - Gem::Commands::ServerCommand
 - Gem::Commands::SetupCommand
 - Gem::Commands::SourcesCommand
 - Gem::Commands::SpecificationCommand
 - Gem::Commands::StaleCommand
 - Gem::Commands::UninstallCommand
 - Gem::Commands::UnpackCommand
 - Gem::Commands::UpdateCommand
 - Gem::Commands::WhichCommand
 - Gem::Commands::YankCommand
 - Gem::ConfigFile
 - Gem::ConflictError
 - Gem::ConsoleUI
 - Gem::DefaultUserInteraction
 - Gem::Dependency
 - Gem::DependencyError
 - Gem::DependencyInstaller
 - Gem::DependencyList
 - Gem::DependencyRemovalException
 - Gem::DependencyResolutionError
 - Gem::Deprecate
 - Gem::Doctor
 - Gem::DocumentError
 - Gem::EndOfYAMLException
 - Gem::ErrorReason
 - Gem::Exception
 - Gem::Ext
 - Gem::Ext::BuildError
 - Gem::Ext::Builder
 - Gem::Ext::CmakeBuilder
 - Gem::Ext::ConfigureBuilder
 - Gem::Ext::ExtConfBuilder
 - Gem::Ext::RakeBuilder
 - Gem::FakeFetcher
 - Gem::FilePermissionError
 - Gem::FormatException
 - Gem::GemNotFoundException
 - Gem::GemNotInHomeException
 - Gem::GemRunner
 - Gem::GemcutterUtilities
 - Gem::ImpossibleDependenciesError
 - Gem::Indexer
 - Gem::InstallError
 - Gem::InstallUpdateOptions
 - Gem::Installer
 - Gem::Installer::FakePackage
 - Gem::InstallerTestCase
 - Gem::InvalidSpecificationException
 - Gem::Licenses
 - Gem::List
 - Gem::LoadError
 - Gem::LocalRemoteOptions
 - Gem::MockGemUi
 - Gem::MockGemUi::InputEOFError
 - Gem::MockGemUi::SystemExitException
 - Gem::MockGemUi::TTY
 - Gem::MockGemUi::TermError
 - Gem::NameTuple
 - Gem::NoAliasYAMLTree
 - Gem::OperationNotSupportedError
 - Gem::Package::DigestIO
 - Gem::Package::Error
 - Gem::Package::FormatError
 - Gem::Package::NonSeekableIO
 - Gem::Package::Old
 - Gem::Package::PathError
 - Gem::Package::TarHeader
 - Gem::Package::TarInvalidError
 - Gem::Package::TarReader
 - Gem::Package::TarReader::Entry
 - Gem::Package::TarReader::UnexpectedEOF
 - Gem::Package::TarTestCase
 - Gem::Package::TarWriter
 - Gem::Package::TarWriter::BoundedStream
 - Gem::Package::TarWriter::FileOverflow
 - Gem::Package::TarWriter::RestrictedStream
 - Gem::Package::TooLongFileName
 - Gem::PackageTask
 - Gem::PathSupport
 - Gem::Platform
 - Gem::PlatformMismatch
 - Gem::RemoteError
 - Gem::RemoteFetcher
 - Gem::RemoteFetcher::FetchError
 - Gem::RemoteFetcher::UnknownHostError
 - Gem::RemoteInstallationCancelled
 - Gem::RemoteInstallationSkipped
 - Gem::RemoteSourceException
 - Gem::Request::ConnectionPools
 - Gem::Request::ConnectionPools::Net
 - Gem::RequestSet
 - Gem::RequestSet::GemDependencyAPI
 - Gem::RequestSet::Lockfile
 - Gem::RequestSet::Lockfile::ParseError
 - Gem::RequestSet::Lockfile::Parser
 - Gem::RequestSet::Lockfile::Tokenizer
 - Gem::Requirement
 - Gem::Requirement::BadRequirementError
 - Gem::Resolver
 - Gem::Resolver::APISet
 - Gem::Resolver::APISpecification
 - Gem::Resolver::ActivationRequest
 - Gem::Resolver::BestSet
 - Gem::Resolver::ComposedSet
 - Gem::Resolver::Conflict
 - Gem::Resolver::CurrentSet
 - Gem::Resolver::DependencyRequest
 - Gem::Resolver::GitSet
 - Gem::Resolver::GitSpecification
 - Gem::Resolver::IndexSet
 - Gem::Resolver::IndexSpecification
 - Gem::Resolver::InstalledSpecification
 - Gem::Resolver::InstallerSet
 - Gem::Resolver::LocalSpecification
 - Gem::Resolver::LockSet
 - Gem::Resolver::LockSpecification
 - Gem::Resolver::Molinillo
 - Gem::Resolver::Molinillo::CircularDependencyError
 - Gem::Resolver::Molinillo::DependencyGraph
 - Gem::Resolver::Molinillo::DependencyGraph::Vertex
 - Gem::Resolver::Molinillo::DependencyState
 - Gem::Resolver::Molinillo::NoSuchDependencyError
 - Gem::Resolver::Molinillo::PossibilityState
 - Gem::Resolver::Molinillo::ResolutionState
 - Gem::Resolver::Molinillo::Resolver
 - Gem::Resolver::Molinillo::Resolver::Resolution
 - Gem::Resolver::Molinillo::ResolverError
 - Gem::Resolver::Molinillo::SpecificationProvider
 - Gem::Resolver::Molinillo::UI
 - Gem::Resolver::Molinillo::VersionConflict
 - Gem::Resolver::RequirementList
 - Gem::Resolver::Set
 - Gem::Resolver::SourceSet
 - Gem::Resolver::SpecSpecification
 - Gem::Resolver::Specification
 - Gem::Resolver::Stats
 - Gem::Resolver::VendorSet
 - Gem::Resolver::VendorSpecification
 - Gem::RubyVersionMismatch
 - Gem::Security
 - Gem::Security::Exception
 - Gem::Security::Policy
 - Gem::Security::Signer
 - Gem::Security::TrustDir
 - Gem::Server
 - Gem::SilentUI
 - Gem::Source
 - Gem::Source::Git
 - Gem::Source::Installed
 - Gem::Source::Local
 - Gem::Source::Lock
 - Gem::Source::SpecificFile
 - Gem::Source::Vendor
 - Gem::SourceFetchProblem
 - Gem::SourceList
 - Gem::SpecFetcher
 - Gem::SpecificGemNotFoundException
 - Gem::Specification
 - Gem::StreamUI
 - Gem::StreamUI::SilentDownloadReporter
 - Gem::StreamUI::SilentProgressReporter
 - Gem::StreamUI::SimpleProgressReporter
 - Gem::StreamUI::VerboseDownloadReporter
 - Gem::StreamUI::VerboseProgressReporter
 - Gem::StubSpecification
 - Gem::SystemExitException
 - Gem::TestCase
 - Gem::TestCase::SpecFetcherSetup
 - Gem::TestCase::StaticSet
 - Gem::Text
 - Gem::Uninstaller
 - Gem::UnsatisfiableDependencyError
 - Gem::UriFormatter
 - Gem::UserInteraction
 - Gem::Util
 - Gem::Validator
 - Gem::VerificationError
 - Gem::Version
 - Gem::VersionOption
 - Kernel
 - Object
 - OpenSSL
 - TempIO
 - YAML::Syck
 - YAML::Syck
 
Gem::Security::TrustDir
frozen_string_literal: true
The TrustDir manages the trusted certificates for gem signature verification.
Constants
- DEFAULT_PERMISSIONS
 Default permissions for the trust directory and its contents
Public Class Methods
            new(dir, permissions = DEFAULT_PERMISSIONS)
            
          
          
          Creates a new TrustDir using dir
where the directory and file permissions will be checked according to
permissions
 
               # File rubygems/security/trust_dir.rb, line 25
def initialize dir, permissions = DEFAULT_PERMISSIONS
  @dir = dir
  @permissions = permissions
  @digester = Gem::Security::DIGEST_ALGORITHM
end
             
            Public Instance Methods
            cert_path(certificate)
            
          
          
          Returns the path to the trusted certificate
 
               # File rubygems/security/trust_dir.rb, line 35
def cert_path certificate
  name_path certificate.subject
end
             
            
            each_certificate()
            
          
          
          Enumerates trusted certificates.
 
               # File rubygems/security/trust_dir.rb, line 42
def each_certificate
  return enum_for __method__ unless block_given?
  glob = File.join @dir, '*.pem'
  Dir[glob].each do |certificate_file|
    begin
      certificate = load_certificate certificate_file
      yield certificate, certificate_file
    rescue OpenSSL::X509::CertificateError
      next # HACK warn
    end
  end
end
             
            
            issuer_of(certificate)
            
          
          
          Returns the issuer certificate of the given certificate if it
exists in the trust directory.
 
               # File rubygems/security/trust_dir.rb, line 62
def issuer_of certificate
  path = name_path certificate.issuer
  return unless File.exist? path
  load_certificate path
end
             
            
            load_certificate(certificate_file)
            
          
          
          Loads the given certificate_file
 
               # File rubygems/security/trust_dir.rb, line 82
def load_certificate certificate_file
  pem = File.read certificate_file
  OpenSSL::X509::Certificate.new pem
end
             
            
            name_path(name)
            
          
          
          Returns the path to the trusted certificate with the given ASN.1
name
 
               # File rubygems/security/trust_dir.rb, line 73
def name_path name
  digest = @digester.hexdigest name.to_s
  File.join @dir, "cert-#{digest}.pem"
end
             
            
            trust_cert(certificate)
            
          
          
          Add a certificate to trusted certificate list.
 
               # File rubygems/security/trust_dir.rb, line 91
def trust_cert certificate
  verify
  destination = cert_path certificate
  open destination, 'wb', @permissions[:trusted_cert] do |io|
    io.write certificate.to_pem
  end
end
             
            
            verify()
            
          
          
          Make sure the trust directory exists. If it does exist, make sure it’s actually a directory. If not, then create it with the appropriate permissions.
 
               # File rubygems/security/trust_dir.rb, line 106
def verify
  if File.exist? @dir then
    raise Gem::Security::Exception,
      "trust directory #{@dir} is not a directory" unless
        File.directory? @dir
    FileUtils.chmod 0700, @dir
  else
    FileUtils.mkdir_p @dir, :mode => @permissions[:trust_dir]
  end
end