class Gem::Commands::YankCommand
def arguments # :nodoc:
def arguments # :nodoc: "GEM name of gem" end
def description # :nodoc:
def description # :nodoc: <<-EOF e yank command permanently removes a gem you pushed to a server. ce you have pushed a gem several downloads will happen automatically a the webhooks. If you accidentally pushed passwords or other sensitive ta you will need to change them immediately and yank your gem. EOF end
def execute
def execute @host = options[:host] sign_in @host, scope: get_yank_scope version = get_version_from_requirements(options[:version]) platform = get_platform_from_requirements(options) if version yank_gem(version, platform) else say "A version argument is required: #{usage}" terminate_interaction end end
def get_version_from_requirements(requirements)
def get_version_from_requirements(requirements) requirements.requirements.first[1].version rescue nil end
def get_yank_scope
def get_yank_scope :yank_rubygem end
def initialize
def initialize super 'yank', 'Remove a pushed gem from the index' add_version_option("remove") add_platform_option("remove") add_otp_option add_option('--host HOST', 'Yank from another gemcutter-compatible host', ' (e.g. https://rubygems.org)') do |value, options| options[:host] = value end add_key_option @host = nil end
def usage # :nodoc:
def usage # :nodoc: "#{program_name} -v VERSION [-p PLATFORM] [--key KEY_NAME] [--host HOST] GEM" end
def yank_api_request(method, version, platform, api)
def yank_api_request(method, version, platform, api) name = get_one_gem_name response = rubygems_api_request(method, api, host, scope: get_yank_scope) do |request| request.add_field("Authorization", api_key) data = { 'gem_name' => name, 'version' => version, } data['platform'] = platform if platform request.set_form_data data end response end
def yank_gem(version, platform)
def yank_gem(version, platform) say "Yanking gem from #{self.host}..." args = [:delete, version, platform, "api/v1/gems/yank"] response = yank_api_request(*args) say response.body end