2016-02-01 07:43:26 -05:00
|
|
|
# frozen_string_literal: true
|
2010-02-21 21:52:35 -05:00
|
|
|
require 'rubygems/command'
|
|
|
|
require 'rubygems/local_remote_options'
|
|
|
|
require 'rubygems/gemcutter_utilities'
|
|
|
|
|
|
|
|
class Gem::Commands::OwnerCommand < Gem::Command
|
|
|
|
include Gem::LocalRemoteOptions
|
|
|
|
include Gem::GemcutterUtilities
|
|
|
|
|
|
|
|
def description # :nodoc:
|
2013-09-14 04:59:02 -04:00
|
|
|
<<-EOF
|
|
|
|
The owner command lets you add and remove owners of a gem on a push
|
|
|
|
server (the default is https://rubygems.org).
|
|
|
|
|
|
|
|
The owner of a gem has the permission to push new versions, yank existing
|
|
|
|
versions or edit the HTML page of the gem. Be careful of who you give push
|
|
|
|
permission to.
|
|
|
|
EOF
|
2010-02-21 21:52:35 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def arguments # :nodoc:
|
|
|
|
"GEM gem to manage owners for"
|
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
def usage # :nodoc:
|
|
|
|
"#{program_name} GEM"
|
|
|
|
end
|
|
|
|
|
2010-02-21 21:52:35 -05:00
|
|
|
def initialize
|
2013-09-14 04:59:02 -04:00
|
|
|
super 'owner', 'Manage gem owners of a gem on the push server'
|
2010-02-21 21:52:35 -05:00
|
|
|
add_proxy_option
|
2011-03-01 04:41:32 -05:00
|
|
|
add_key_option
|
2010-02-21 21:52:35 -05:00
|
|
|
defaults.merge! :add => [], :remove => []
|
|
|
|
|
|
|
|
add_option '-a', '--add EMAIL', 'Add an owner' do |value, options|
|
|
|
|
options[:add] << value
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option '-r', '--remove EMAIL', 'Remove an owner' do |value, options|
|
|
|
|
options[:remove] << value
|
|
|
|
end
|
2013-09-14 04:59:02 -04:00
|
|
|
|
2017-10-07 21:32:18 -04:00
|
|
|
add_option '-h', '--host HOST',
|
|
|
|
'Use another gemcutter-compatible host',
|
|
|
|
' (e.g. https://rubygems.org)' do |value, options|
|
2013-09-14 04:59:02 -04:00
|
|
|
options[:host] = value
|
|
|
|
end
|
2010-02-21 21:52:35 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
2013-09-14 04:59:02 -04:00
|
|
|
@host = options[:host]
|
|
|
|
|
2010-02-21 21:52:35 -05:00
|
|
|
sign_in
|
|
|
|
name = get_one_gem_name
|
|
|
|
|
|
|
|
add_owners name, options[:add]
|
|
|
|
remove_owners name, options[:remove]
|
|
|
|
show_owners name
|
|
|
|
end
|
|
|
|
|
|
|
|
def show_owners name
|
|
|
|
response = rubygems_api_request :get, "api/v1/gems/#{name}/owners.yaml" do |request|
|
2011-03-01 04:41:32 -05:00
|
|
|
request.add_field "Authorization", api_key
|
2010-02-21 21:52:35 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
with_response response do |resp|
|
2018-02-16 03:08:06 -05:00
|
|
|
owners = Gem::SafeYAML.load resp.body
|
2010-02-21 21:52:35 -05:00
|
|
|
|
|
|
|
say "Owners for gem: #{name}"
|
|
|
|
owners.each do |owner|
|
2016-04-06 02:01:14 -04:00
|
|
|
say "- #{owner['email'] || owner['handle'] || owner['id']}"
|
2010-02-21 21:52:35 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def add_owners name, owners
|
|
|
|
manage_owners :post, name, owners
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_owners name, owners
|
|
|
|
manage_owners :delete, name, owners
|
|
|
|
end
|
|
|
|
|
|
|
|
def manage_owners method, name, owners
|
|
|
|
owners.each do |owner|
|
2012-11-29 01:52:18 -05:00
|
|
|
begin
|
|
|
|
response = rubygems_api_request method, "api/v1/gems/#{name}/owners" do |request|
|
|
|
|
request.set_form_data 'email' => owner
|
|
|
|
request.add_field "Authorization", api_key
|
|
|
|
end
|
|
|
|
|
2014-09-13 23:30:02 -04:00
|
|
|
action = method == :delete ? "Removing" : "Adding"
|
|
|
|
|
|
|
|
with_response response, "#{action} #{owner}"
|
2012-11-29 01:52:18 -05:00
|
|
|
rescue
|
|
|
|
# ignore
|
2010-02-21 21:52:35 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|