module Fastlane module Actions class GetPushCertificateAction < Action def self.run(params) require 'pem' require 'pem/options' require 'pem/manager' success_block = params[:new_profile] PEM.config = params if Helper.test? profile_path = './test.pem' else profile_path = PEM::Manager.start end if success_block && profile_path success_block.call(File.expand_path(profile_path)) if success_block end end def self.description "Ensure a valid push profile is active, creating a new one if needed (via _pem_)" end def self.author "KrauseFx" end def self.details [ "Additionally to the available options, you can also specify a block that only gets executed if a new", "profile was created. You can use it to upload the new profile to your server.", "Use it like this: ", "get_push_certificate(", " new_profile: proc do ", " # your upload code", " end", ")" ].join("\n") end def self.available_options require 'pem' require 'pem/options' @options = PEM::Options.available_options @options << FastlaneCore::ConfigItem.new(key: :new_profile, description: "Block that is called if there is a new profile", optional: true, is_string: false) @options end def self.is_supported?(platform) platform == :ios end def self.example_code [ 'get_push_certificate', 'pem # alias for "get_push_certificate"', 'get_push_certificate( force: true, # create a new profile, even if the old one is still valid app_identifier: "net.sunapps.9", # optional app identifier, save_private_key: true, new_profile: proc do |profile_path| # this block gets called when a new profile was generated puts profile_path # the absolute path to the new PEM file # insert the code to upload the PEM file to the server end )' ] end def self.category :push end end end end