lib/rubygems/commands/yank_command.rb in gemcutter-0.7.0 vs lib/rubygems/commands/yank_command.rb in gemcutter-0.7.1
- old
+ new
@@ -14,54 +14,61 @@
def arguments
"GEM name of gem"
end
def usage
- "#{program_name} GEM -v VERSION [-p PLATFORM] [--undo]"
+ "#{program_name} GEM -v VERSION [-p PLATFORM] [--undo] [--key KEY_NAME]"
end
-
+
def initialize
super 'yank', description
add_version_option("remove")
add_platform_option("remove")
add_option('--undo') do |value, options|
options[:undo] = true
end
+
+ add_option('-k', '--key KEY_NAME',
+ 'Use API key from your gem credentials file') do |value, options|
+ options[:key] = value
+ end
end
def execute
sign_in
version = get_version_from_requirements(options[:version])
platform = get_platform_from_requirements(options)
-
+ api_key = Gem.configuration.rubygems_api_key
+ api_key = Gem.configuration.api_keys[options[:key].to_sym] if options[:key]
+
if !version.nil?
if options[:undo]
- unyank_gem(version, platform)
+ unyank_gem(version, platform, api_key)
else
- yank_gem(version, platform)
+ yank_gem(version, platform, api_key)
end
else
say "A version argument is required: #{usage}"
terminate_interaction
end
end
- def yank_gem(version, platform)
+ def yank_gem(version, platform, api_key)
say "Yanking gem from RubyGems.org..."
- yank_api_request(:delete, version, platform, "api/v1/gems/yank")
+ yank_api_request(:delete, version, platform, "api/v1/gems/yank", api_key)
end
-
- def unyank_gem(version, platform)
+
+ def unyank_gem(version, platform, api_key)
say "Unyanking gem from RubyGems.org..."
- yank_api_request(:put, version, platform, "api/v1/gems/unyank")
+ yank_api_request(:put, version, platform, "api/v1/gems/unyank", api_key)
end
-
+
private
- def yank_api_request(method, version, platform, api)
+ def yank_api_request(method, version, platform, api, api_key)
name = get_one_gem_name
response = rubygems_api_request(method, api) do |request|
- request.add_field("Authorization", Gem.configuration.rubygems_api_key)
+ request.add_field("Authorization", api_key)
request.set_form_data({'gem_name' => name, 'version' => version, 'platform' => platform})
end
say response.body
end
@@ -70,10 +77,10 @@
requirements.requirements.first[1].version
rescue
nil
end
end
-
+
def get_platform_from_requirements(requirements)
Gem.platforms[1].to_s if requirements.key? :added_platform
end
end