Class: Gem::Commands::OwnerCommand
- Inherits:
-
Gem::Command
- Object
- Gem::Command
- Gem::Commands::OwnerCommand
- Includes:
- GemcutterUtilities, LocalRemoteOptions
- Defined in:
- lib/rubygems/commands/owner_command.rb
Instance Attribute Summary
Attributes included from GemcutterUtilities
Attributes inherited from Gem::Command
#command, #defaults, #options, #program_name, #summary
Instance Method Summary collapse
- #add_owners(name, owners) ⇒ Object
-
#arguments ⇒ Object
:nodoc:.
-
#description ⇒ Object
:nodoc:.
- #execute ⇒ Object
-
#initialize ⇒ OwnerCommand
constructor
A new instance of OwnerCommand.
- #manage_owners(method, name, owners) ⇒ Object
- #remove_owners(name, owners) ⇒ Object
- #show_owners(name) ⇒ Object
-
#usage ⇒ Object
:nodoc:.
Methods included from GemcutterUtilities
#add_key_option, #api_key, #rubygems_api_request, #sign_in, #verify_api_key, #with_response
Methods included from LocalRemoteOptions
#accept_uri_http, #add_bulk_threshold_option, #add_clear_sources_option, #add_local_remote_options, #add_proxy_option, #add_source_option, #add_update_sources_option, #both?, #local?, #remote?
Methods inherited from Gem::Command
add_common_option, #add_extra_args, #add_option, add_specific_extra_args, #begins?, build_args, build_args=, common_options, #defaults_str, extra_args, extra_args=, #get_all_gem_names, #get_all_gem_names_and_versions, #get_one_gem_name, #get_one_optional_argument, #handle_options, #handles?, #invoke, #invoke_with_build_args, #merge_options, #remove_option, #show_help, #show_lookup_failure, specific_extra_args, specific_extra_args_hash, #when_invoked
Methods included from UserInteraction
#alert, #alert_error, #alert_warning, #ask, #ask_for_password, #ask_yes_no, #choose_from_list, #say, #terminate_interaction, #verbose
Methods included from DefaultUserInteraction
ui, #ui, ui=, #ui=, use_ui, #use_ui
Constructor Details
#initialize ⇒ OwnerCommand
Returns a new instance of OwnerCommand.
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 |
# File 'lib/rubygems/commands/owner_command.rb', line 28 def initialize super 'owner', 'Manage gem owners of a gem on the push server' add_proxy_option add_key_option defaults.merge! :add => [], :remove => [] add_option '-a', '--add EMAIL', 'Add an owner' do |value, | [:add] << value end add_option '-r', '--remove EMAIL', 'Remove an owner' do |value, | [:remove] << value end add_option '-h', '--host HOST', 'Use another gemcutter-compatible host' do |value, | [:host] = value end end |
Instance Method Details
#add_owners(name, owners) ⇒ Object
73 74 75 |
# File 'lib/rubygems/commands/owner_command.rb', line 73 def add_owners name, owners manage_owners :post, name, owners end |
#arguments ⇒ Object
:nodoc:
20 21 22 |
# File 'lib/rubygems/commands/owner_command.rb', line 20 def arguments # :nodoc: "GEM gem to manage owners for" end |
#description ⇒ Object
:nodoc:
9 10 11 12 13 14 15 16 17 18 |
# File 'lib/rubygems/commands/owner_command.rb', line 9 def description # :nodoc: <<-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 end |
#execute ⇒ Object
47 48 49 50 51 52 53 54 55 56 |
# File 'lib/rubygems/commands/owner_command.rb', line 47 def execute @host = [:host] sign_in name = get_one_gem_name add_owners name, [:add] remove_owners name, [:remove] show_owners name end |
#manage_owners(method, name, owners) ⇒ Object
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# File 'lib/rubygems/commands/owner_command.rb', line 81 def manage_owners method, name, owners owners.each do |owner| 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 action = method == :delete ? "Removing" : "Adding" with_response response, "#{action} #{owner}" rescue # ignore end end end |
#remove_owners(name, owners) ⇒ Object
77 78 79 |
# File 'lib/rubygems/commands/owner_command.rb', line 77 def remove_owners name, owners manage_owners :delete, name, owners end |
#show_owners(name) ⇒ Object
58 59 60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/rubygems/commands/owner_command.rb', line 58 def show_owners name response = rubygems_api_request :get, "api/v1/gems/#{name}/owners.yaml" do |request| request.add_field "Authorization", api_key end with_response response do |resp| owners = YAML.load resp.body say "Owners for gem: #{name}" owners.each do |owner| say "- #{owner['email']}" end end end |
#usage ⇒ Object
:nodoc:
24 25 26 |
# File 'lib/rubygems/commands/owner_command.rb', line 24 def usage # :nodoc: "#{program_name} GEM" end |