Sha256: 4cf175e550732c475435b3bc580f267e89b3a8d654ca91cfb72c450057e602f8

Contents?: true

Size: 1.92 KB

Versions: 7

Compression:

Stored size: 1.92 KB

Contents

require 'puppet/application'

class Puppet::Application::Cert < Puppet::Application

  should_parse_config
  run_mode :master

  attr_accessor :cert_mode, :all, :ca, :digest, :signed

  def find_mode(opt)
    require 'puppet/ssl/certificate_authority'
    modes = Puppet::SSL::CertificateAuthority::Interface::INTERFACE_METHODS
    tmp = opt.sub("--", '').to_sym
    @cert_mode = modes.include?(tmp) ? tmp : nil
  end

  option("--clean", "-c") do
    @cert_mode = :destroy
  end

  option("--all", "-a") do
    @all = true
  end

  option("--digest DIGEST") do |arg|
    @digest = arg
  end

  option("--signed", "-s") do
    @signed = true
  end

  option("--debug", "-d") do |arg|
    Puppet::Util::Log.level = :debug
  end

  require 'puppet/ssl/certificate_authority/interface'
  Puppet::SSL::CertificateAuthority::Interface::INTERFACE_METHODS.reject {|m| m == :destroy }.each do |method|
    option("--#{method}", "-#{method.to_s[0,1]}") do
      find_mode("--#{method}")
    end
  end

  option("--verbose", "-v") do
    Puppet::Util::Log.level = :info
  end

  def main
    if @all
      hosts = :all
    elsif @signed
      hosts = :signed
    else
      hosts = command_line.args.collect { |h| h.downcase }
    end
    begin
      @ca.apply(:revoke, :to => hosts) if @cert_mode == :destroy
      @ca.apply(@cert_mode, :to => hosts, :digest => @digest)
    rescue => detail
      puts detail.backtrace if Puppet[:trace]
      puts detail.to_s
      exit(24)
    end
  end

  def setup
    exit(Puppet.settings.print_configs ? 0 : 1) if Puppet.settings.print_configs?

    Puppet::Util::Log.newdestination :console

    if [:generate, :destroy].include? @cert_mode
      Puppet::SSL::Host.ca_location = :local
    else
      Puppet::SSL::Host.ca_location = :only
    end

    begin
      @ca = Puppet::SSL::CertificateAuthority.new
    rescue => detail
      puts detail.backtrace if Puppet[:trace]
      puts detail.to_s
      exit(23)
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
puppet-2.6.6 lib/puppet/application/cert.rb
puppet-2.6.5 lib/puppet/application/cert.rb
puppet-2.6.4 lib/puppet/application/cert.rb
puppet-2.6.3 lib/puppet/application/cert.rb
puppet-2.6.2 lib/puppet/application/cert.rb
puppet-2.6.1 lib/puppet/application/cert.rb
puppet-2.6.0 lib/puppet/application/cert.rb