Sha256: 8023a558614642464e55a935be51288a016e190e45c3c76ebbe992f3d68ed82e
Contents?: true
Size: 1.83 KB
Versions: 15
Compression:
Stored size: 1.83 KB
Contents
module Pkg::Sign::Dmg module_function def sign(target_dir = 'pkg') use_identity = "-i #{Pkg::Config.osx_signing_ssh_key}" unless Pkg::Config.osx_signing_ssh_key.nil? if Pkg::Config.osx_signing_server =~ /@/ host_string = "#{Pkg::Config.osx_signing_server}" else host_string = "#{ENV['USER']}@#{Pkg::Config.osx_signing_server}" end ssh_host_string = "#{use_identity} #{host_string}" rsync_host_string = "-e 'ssh #{use_identity}' #{host_string}" work_dir = "/tmp/#{Pkg::Util.rand_string}" mount = File.join(work_dir, "mount") signed = File.join(work_dir, "signed") Pkg::Util::Net.remote_ssh_cmd(ssh_host_string, "mkdir -p #{mount} #{signed}") dmgs = Dir.glob("#{target_dir}/apple/**/*.dmg") Pkg::Util::Net.rsync_to(dmgs.join(" "), rsync_host_string, work_dir) Pkg::Util::Net.remote_ssh_cmd(ssh_host_string, %Q[for dmg in #{dmgs.map { |d| File.basename(d, ".dmg") }.join(" ")}; do /usr/bin/hdiutil attach #{work_dir}/$dmg.dmg -mountpoint #{mount} -nobrowse -quiet ; /usr/bin/security -q unlock-keychain -p "#{Pkg::Config.osx_signing_keychain_pw}" "#{Pkg::Config.osx_signing_keychain}" ; for pkg in $(ls #{mount}/*.pkg | xargs -n 1 basename); do /usr/bin/productsign --keychain "#{Pkg::Config.osx_signing_keychain}" --sign "#{Pkg::Config.osx_signing_cert}" #{mount}/$pkg #{signed}/$pkg ; done /usr/bin/hdiutil detach #{mount} -quiet ; /bin/rm #{work_dir}/$dmg.dmg ; /usr/bin/hdiutil create -volname $dmg -srcfolder #{signed}/ #{work_dir}/$dmg.dmg ; /bin/rm #{signed}/* ; done]) dmgs.each do | dmg | Pkg::Util::Net.rsync_from("#{work_dir}/#{File.basename(dmg)}", rsync_host_string, File.dirname(dmg)) end Pkg::Util::Net.remote_ssh_cmd(ssh_host_string, "if [ -d '#{work_dir}' ]; then rm -rf '#{work_dir}'; fi") end end
Version data entries
15 entries across 15 versions & 1 rubygems