Class: Pindo::Command::Utils::Clearcert

Inherits:
Pindo::Command::Utils show all
Defined in:
lib/pindo/command/utils/clearcert.rb

Constant Summary

Constants inherited from Pindo::Command

DEFAULT_OPTIONS, DEFAULT_ROOT_OPTIONS

Instance Attribute Summary

Attributes inherited from Pindo::Command

#args_help_flag

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Pindo::Command

run

Methods included from Funlog::Mixin

#pindo_log_instance

Methods included from Pindoconfig::Mixin

#pindo_single_config

Methods included from Githelper

#add_branch, #add_tag, #add_tag_with_check, #clone_clang_repo, #clone_devclang_repo, #clone_pindo_common_config_repo, #clone_pindo_env_config_repo, #clong_buildconfig_repo, #get_repo_base_name, #getcode_to_dir, #git_addpush_repo, #git_latest_commit_id, #local_branch_exists?, #local_tag_exists?, #prepare_gitenv, #process_need_add_files, #remote_branch_exists?, #remote_tag_exists?, #remove_branch, #remove_tag

Methods included from Executable

capture_command, #executable, execute_command, which, which!

Constructor Details

#initialize(argv) ⇒ Clearcert

Returns a new instance of Clearcert.



29
30
31
32
33
# File 'lib/pindo/command/utils/clearcert.rb', line 29

def initialize(argv)
    
    super(argv)
    @additional_args = argv.remainder!
end

Class Method Details

.optionsObject



23
24
25
26
27
# File 'lib/pindo/command/utils/clearcert.rb', line 23

def self.options
  [
        
  ].concat(super)
end

Instance Method Details

#runObject



39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'lib/pindo/command/utils/clearcert.rb', line 39

def run
    output, _ = Open3.capture2('security find-identity -p codesigning')
    identity_ids_0 = []
    identity_ids_1 = output.split("\n").map { |line| line.split(' ')[1] if line.include?('Apple Development') }.compact
    identity_ids_2 = output.split("\n").map { |line| line.split(' ')[1] if line.include?('Apple Distribution') }.compact
    identity_ids = identity_ids_0 + identity_ids_1 + identity_ids_2
    identity_ids = identity_ids.uniq
    puts identity_ids
    
    identity_ids.each do |identity_id|
        system "security delete-certificate -Z #{identity_id}"
    end

    profile_file_dir = File.expand_path("~/Library/MobileDevice")
    profile_file_patb = File.join(profile_file_dir, "Provisioning Profiles")
    FileUtils.rm_rf(profile_file_patb)
    
end

#validate!Object



35
36
37
# File 'lib/pindo/command/utils/clearcert.rb', line 35

def validate!
    super
end