9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
# File 'pem/lib/pem/options.rb', line 9
def self.available_options
user = CredentialsManager::AppfileConfig.try_fetch_value(:apple_dev_portal_id)
user ||= CredentialsManager::AppfileConfig.try_fetch_value(:apple_id)
[
FastlaneCore::ConfigItem.new(key: :platform,
description: "Set certificate's platform. Used for creation of production & development certificates. Supported platforms: ios, macos",
short_option: "-m",
env_name: "PEM_PLATFORM",
default_value: "ios",
verify_block: proc do |value|
UI.user_error!("The platform can only be ios or macos") unless ['ios', 'macos'].include?(value)
end),
FastlaneCore::ConfigItem.new(key: :development,
env_name: "PEM_DEVELOPMENT",
description: "Renew the development push certificate instead of the production one",
is_string: false,
default_value: false),
FastlaneCore::ConfigItem.new(key: :website_push,
env_name: "PEM_WEBSITE_PUSH",
description: "Create a Website Push certificate",
is_string: false,
conflicting_options: [:development],
default_value: false),
FastlaneCore::ConfigItem.new(key: :generate_p12,
env_name: "PEM_GENERATE_P12_FILE",
description: "Generate a p12 file additionally to a PEM file",
is_string: false,
default_value: true),
FastlaneCore::ConfigItem.new(key: :active_days_limit,
env_name: "PEM_ACTIVE_DAYS_LIMIT",
description: "If the current certificate is active for less than this number of days, generate a new one",
default_value: 30,
is_string: false,
type: Integer,
verify_block: proc do |value|
UI.user_error!("Value of active_days_limit must be a positive integer or left blank") unless value.kind_of?(Integer) && value > 0
end),
FastlaneCore::ConfigItem.new(key: :force,
env_name: "PEM_FORCE",
description: "Create a new push certificate, even if the current one is active for 30 (or PEM_ACTIVE_DAYS_LIMIT) more days",
is_string: false,
default_value: false),
FastlaneCore::ConfigItem.new(key: :save_private_key,
short_option: "-s",
env_name: "PEM_SAVE_PRIVATEKEY",
description: "Set to save the private RSA key",
is_string: false,
default_value: true),
FastlaneCore::ConfigItem.new(key: :app_identifier,
short_option: "-a",
env_name: "PEM_APP_IDENTIFIER",
description: "The bundle identifier of your app",
code_gen_sensitive: true,
default_value: CredentialsManager::AppfileConfig.try_fetch_value(:app_identifier),
default_value_dynamic: true),
FastlaneCore::ConfigItem.new(key: :username,
short_option: "-u",
env_name: "PEM_USERNAME",
description: "Your Apple ID Username",
default_value: user,
default_value_dynamic: true),
FastlaneCore::ConfigItem.new(key: :team_id,
short_option: "-b",
env_name: "PEM_TEAM_ID",
code_gen_sensitive: true,
default_value: CredentialsManager::AppfileConfig.try_fetch_value(:team_id),
default_value_dynamic: true,
description: "The ID of your Developer Portal team if you're in multiple teams",
optional: true,
verify_block: proc do |value|
ENV["FASTLANE_TEAM_ID"] = value.to_s
end),
FastlaneCore::ConfigItem.new(key: :team_name,
short_option: "-l",
env_name: "PEM_TEAM_NAME",
description: "The name of your Developer Portal team if you're in multiple teams",
optional: true,
code_gen_sensitive: true,
default_value: CredentialsManager::AppfileConfig.try_fetch_value(:team_name),
default_value_dynamic: true,
verify_block: proc do |value|
ENV["FASTLANE_TEAM_NAME"] = value.to_s
end),
FastlaneCore::ConfigItem.new(key: :p12_password,
short_option: "-p",
env_name: "PEM_P12_PASSWORD",
sensitive: true,
description: "The password that is used for your p12 file",
optional: true),
FastlaneCore::ConfigItem.new(key: :pem_name,
short_option: "-o",
env_name: "PEM_FILE_NAME",
description: "The file name of the generated .pem file",
optional: true),
FastlaneCore::ConfigItem.new(key: :output_path,
short_option: "-e",
env_name: "PEM_OUTPUT_PATH",
description: "The path to a directory in which all certificates and private keys should be stored",
default_value: ".")
]
end
|