Class: Gem::Commands::PushCommand

Inherits:
Gem::Command show all
Includes:
GemcutterUtilities, LocalRemoteOptions
Defined in:
lib/rubygems/commands/push_command.rb

Constant Summary

Constants included from GemcutterUtilities

GemcutterUtilities::ERROR_CODE

Instance Attribute Summary

Attributes included from GemcutterUtilities

#host

Attributes inherited from Gem::Command

#command, #defaults, #options, #program_name, #summary

Instance Method Summary collapse

Methods included from GemcutterUtilities

#add_key_option, #add_otp_option, #api_key, #get_otp, #mfa_unauthorized?, #rubygems_api_request, #set_api_key, #sign_in, #verify_api_key, #with_response

Methods included from Text

#clean_text, #format_text, #levenshtein_distance, #min3, #truncate_text

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=, #check_deprecated_options, common_options, #defaults_str, #deprecate_option, 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

#initializePushCommand

Returns a new instance of PushCommand.



32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# File 'lib/rubygems/commands/push_command.rb', line 32

def initialize
  super 'push', 'Push a gem up to the gem server', :host => self.host

  @user_defined_host = false

  add_proxy_option
  add_key_option
  add_otp_option

  add_option('--host HOST',
             'Push to another gemcutter-compatible host',
             '  (e.g. https://rubygems.org)') do |value, options|
    options[:host] = value
    @user_defined_host = true
  end

  @host = nil
end

Instance Method Details

#argumentsObject

:nodoc:



24
25
26
# File 'lib/rubygems/commands/push_command.rb', line 24

def arguments # :nodoc:
  "GEM       built gem to push up"
end

#descriptionObject

:nodoc:



12
13
14
15
16
17
18
19
20
21
22
# File 'lib/rubygems/commands/push_command.rb', line 12

def description # :nodoc:
  "The push command uploads a gem to the push server (the default is\nhttps://rubygems.org) and adds it to the index.\n\nThe gem can be removed from the index and deleted from the server using the yank\ncommand.  For further discussion see the help for the yank command.\n\nThe push command will use ~/.gem/credentials to authenticate to a server, but you can use the RubyGems environment variable GEM_HOST_API_KEY to set the api key to authenticate.\n  EOF\nend\n"

#executeObject



51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
# File 'lib/rubygems/commands/push_command.rb', line 51

def execute
  gem_name = get_one_gem_name
  default_gem_server, push_host = get_hosts_for(gem_name)

  default_host = nil
  user_defined_host = nil

  if @user_defined_host
    user_defined_host = options[:host]
  else
    default_host = options[:host]
  end

  @host = if user_defined_host
            user_defined_host
          elsif default_gem_server
            default_gem_server
          elsif push_host
            push_host
          else
            default_host
          end

   @host

  send_gem(gem_name)
end

#send_gem(name) ⇒ Object



79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
# File 'lib/rubygems/commands/push_command.rb', line 79

def send_gem(name)
  args = [:post, "api/v1/gems"]

  latest_rubygems_version = Gem.latest_rubygems_version

  if latest_rubygems_version < Gem.rubygems_version and
       Gem.rubygems_version.prerelease? and
       Gem::Version.new('2.0.0.rc.2') != Gem.rubygems_version
    alert_error "You are using a beta release of RubyGems (\#{Gem::VERSION}) which is not\nallowed to push gems.  Please downgrade or upgrade to a release version.\n\nThe latest released RubyGems version is \#{latest_rubygems_version}\n\nYou can upgrade or downgrade to the latest release version with:\n\ngem update --system=\#{latest_rubygems_version}\n\n    ERROR\n    terminate_interaction 1\n  end\n\n  gem_data = Gem::Package.new(name)\n\n  unless @host\n    @host = gem_data.spec.metadata['default_gem_server']\n  end\n\n  push_host = nil\n\n  if gem_data.spec.metadata.has_key?('allowed_push_host')\n    push_host = gem_data.spec.metadata['allowed_push_host']\n  end\n\n  @host ||= push_host\n\n  # Always include @host, even if it's nil\n  args += [ @host, push_host ]\n\n  say \"Pushing gem to \#{@host || Gem.host}...\"\n\n  response = send_push_request(name, args)\n\n  with_response response\nend\n"

#usageObject

:nodoc:



28
29
30
# File 'lib/rubygems/commands/push_command.rb', line 28

def usage # :nodoc:
  "#{program_name} GEM"
end