Sha256: 23f7ad31543f211eee8fa55e41c770c20fdc757ae36c7c72fdb85594f2c56585

Contents?: true

Size: 1.88 KB

Versions: 78

Compression:

Stored size: 1.88 KB

Contents

module Pkg::Util::Gpg
  class << self

    # Please note that this method is not used in determining what key is used
    # to sign the debian repos. That is defined in the freight config that
    # lives on our internal repo staging host. The debian conf/distribution
    # files that are generated with this repo use the default gpg key to
    # reflect that.
    def key
      fail "You need to set `gpg_key` in your build defaults." unless Pkg::Config.gpg_key && !Pkg::Config.gpg_key.empty?
      Pkg::Config.gpg_key
    end

    def keychain
      if @keychain.nil?
        @keychain = Pkg::Util::Tool.find_tool('keychain')
      else
        @keychain
      end
    end

    def load_keychain
      unless @keychain_loaded
        unless ENV['RPM_GPG_AGENT']
          kill_keychain
          start_keychain
        end
        @keychain_loaded = true
      end
    end

    def kill_keychain
      if keychain
        stdout, _, _ = Pkg::Util::Execution.capture3("#{keychain} -k mine")
        stdout
      end
    end

    def start_keychain
      if keychain
        keychain_output, _, _ = Pkg::Util::Execution.capture3("#{keychain} -q --agents gpg --eval #{key}")
        keychain_output.chomp!
        new_env = keychain_output.match(/GPG_AGENT_INFO=([^;]*)/)
        ENV["GPG_AGENT_INFO"] = new_env[1]
      else
        fail "Keychain is not installed, it is required to autosign using gpg."
      end
    end

    def sign_file(file)
      gpg ||= Pkg::Util::Tool.find_tool('gpg')

      if gpg
        if File.exist? "#{file}.asc"
          warn "Signature on #{file} exists, skipping..."
          return true
        end
        use_tty = "--no-tty --use-agent" if ENV['RPM_GPG_AGENT']
        stdout, _, _ = Pkg::Util::Execution.capture3("#{gpg} #{use_tty} --armor --detach-sign -u #{key} #{file}")
        stdout
      else
        fail "No gpg available. Cannot sign #{file}."
      end
    end
  end
end

Version data entries

78 entries across 78 versions & 1 rubygems

Version Path
packaging-0.99.49 lib/packaging/util/gpg.rb
packaging-0.99.48 lib/packaging/util/gpg.rb
packaging-0.99.47 lib/packaging/util/gpg.rb
packaging-0.99.46 lib/packaging/util/gpg.rb
packaging-0.99.45 lib/packaging/util/gpg.rb
packaging-0.99.44 lib/packaging/util/gpg.rb
packaging-0.99.43 lib/packaging/util/gpg.rb
packaging-0.99.42 lib/packaging/util/gpg.rb
packaging-0.99.41 lib/packaging/util/gpg.rb
packaging-0.99.40 lib/packaging/util/gpg.rb
packaging-0.99.39 lib/packaging/util/gpg.rb
packaging-0.99.38 lib/packaging/util/gpg.rb
packaging-0.99.37 lib/packaging/util/gpg.rb
packaging-0.99.36 lib/packaging/util/gpg.rb
packaging-0.99.35 lib/packaging/util/gpg.rb
packaging-0.99.34 lib/packaging/util/gpg.rb
packaging-0.99.33 lib/packaging/util/gpg.rb
packaging-0.99.32 lib/packaging/util/gpg.rb
packaging-0.99.31 lib/packaging/util/gpg.rb
packaging-0.99.30 lib/packaging/util/gpg.rb