Class: Heroku::Command::Apps
Overview
manage apps (create, destroy)
Instance Attribute Summary
Attributes inherited from Base
Instance Method Summary collapse
-
#create ⇒ Object
apps:create [NAME].
-
#destroy ⇒ Object
apps:destroy.
-
#downgrade ⇒ Object
apps:downgrade TIER.
-
#index ⇒ Object
apps.
-
#info ⇒ Object
apps:info.
-
#open ⇒ Object
apps:open.
-
#rename ⇒ Object
apps:rename NEWNAME.
-
#upgrade ⇒ Object
apps:upgrade TIER.
Methods inherited from Base
#api, #app, #heroku, #initialize, namespace
Methods included from Helpers
#action, #ask, #confirm, #confirm_billing, #confirm_command, #create_git_remote, #deprecate, #display, #display_header, #display_object, #display_row, #display_table, #error, error_with_failure, error_with_failure=, extended, extended_into, #fail, #format_bytes, #format_date, #format_error, #format_with_bang, #get_terminal_environment, #git, #has_git?, #home_directory, #host_name, #hprint, #hputs, included, included_into, #json_decode, #json_encode, #launchy, #line_formatter, #longest, #output_with_bang, #quantify, #redisplay, #retry_on_exception, #run_command, #running_on_a_mac?, #running_on_windows?, #set_buffer, #shell, #spinner, #status, #string_distance, #styled_array, #styled_error, #styled_hash, #styled_header, #suggestion, #time_ago, #truncate, #with_tty
Constructor Details
This class inherits a constructor from Heroku::Command::Base
Instance Method Details
#create ⇒ Object
apps:create [NAME]
create a new app
--addons ADDONS # a comma-delimited list of addons to install
-b, –buildpack BUILDPACK # a buildpack url to use for this app -n, –no-remote # don’t create a git remote -r, –remote REMOTE # the git remote to create, default “heroku” -s, –stack STACK # the stack on which to create the app
--region REGION # specify region for this app to run in
-t, –tier TIER # HIDDEN: the tier for this app
Examples:
$ pogo apps:create Creating floating-dragon-42… done, stack is cedar floating-dragon-42.heroku.com/ | [email protected]:floating-dragon-42.git
$ pogo apps:create -s bamboo Creating floating-dragon-42… done, stack is bamboo-mri-1.9.2 floating-dragon-42.herokuapp.com/ | [email protected]:floating-dragon-42.git
# specify a name $ pogo apps:create example Creating example… done, stack is cedar example.heroku.com/ | [email protected]:example.git
# create a staging app $ pogo apps:create example-staging –remote staging
# create an app in the eu region $ pogo apps:create –region eu
210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 |
# File 'lib/heroku/command/apps.rb', line 210 def create name = shift_argument || [:app] || ENV['HEROKU_APP'] validate_arguments! info = api.post_app({ "name" => name, "region" => [:region], "stack" => [:stack], "tier" => [:tier] }).body begin action("Creating #{info['name']}") do if info['create_status'] == 'creating' Timeout::timeout([:timeout].to_i) do loop do break if api.get_app(info['name']).body['create_status'] == 'complete' sleep 1 end end end if info['region'] status("region is #{info['region']}") else status("stack is #{info['stack']}") end end ([:addons] || "").split(",").each do |addon| addon.strip! action("Adding #{addon} to #{info["name"]}") do api.post_addon(info["name"], addon) end end if buildpack = [:buildpack] api.put_config_vars(info["name"], "BUILDPACK_URL" => buildpack) display("BUILDPACK_URL=#{buildpack}") end hputs([ info["web_url"], info["git_url"] ].join(" | ")) rescue Timeout::Error hputs("Timed Out! Run `pogo status` to check for known platform issues.") end unless [:no_remote].is_a? FalseClass create_git_remote([:remote] || "pogoapp", info["git_url"]) end end |
#destroy ⇒ Object
apps:destroy
permanently destroy an app
Example:
$ pogo apps:destroy -a example –confirm example Destroying example (including all add-ons)… done
326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 |
# File 'lib/heroku/command/apps.rb', line 326 def destroy @app = shift_argument || [:app] || [:confirm] validate_arguments! unless @app error("Usage: pogo apps:destroy --app APP\nMust specify APP to destroy.") end api.get_app(@app) # fail fast if no access or doesn't exist = "WARNING: Potentially Destructive Action\nThis command will destroy #{@app} (including all add-ons)." if confirm_command(@app, ) action("Destroying #{@app} (including all add-ons)") do api.delete_app(@app) if remotes = git_remotes(Dir.pwd) remotes.each do |remote_name, remote_app| next if @app != remote_app git "remote rm #{remote_name}" end end end end end |
#downgrade ⇒ Object
apps:downgrade TIER
HIDDEN: downgrade an app’s pricing tier
373 374 375 376 377 378 379 380 381 |
# File 'lib/heroku/command/apps.rb', line 373 def downgrade tier = shift_argument error("Usage: pogo apps:downgrade TIER\nMust specify TIER to downgrade.") if tier.nil? || tier.empty? validate_arguments! action("Upgrading #{app} to #{tier}") do api.put_app(app, "tier" => tier) end end |
#index ⇒ Object
apps
list your apps
Example:
$ pogo apps
My Apps
example example2
Collaborated Apps
theirapp [email protected]
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/heroku/command/apps.rb', line 21 def index validate_arguments! apps = api.get_apps.body unless apps.empty? my_apps, collaborated_apps = apps.partition do |app| app["owner_email"] == Heroku::Auth.user end unless my_apps.empty? non_legacy_apps = my_apps.select do |app| app["tier"] != "legacy" end unless non_legacy_apps.empty? production_basic_apps, dev_legacy_apps = my_apps.partition do |app| ["production", "basic"].include?(app["tier"]) end unless production_basic_apps.empty? styled_header("Basic & Production Apps") styled_array(production_basic_apps.map { |app| regionized_app_name(app) }) end unless dev_legacy_apps.empty? styled_header("Dev & Legacy Apps") styled_array(dev_legacy_apps.map { |app| regionized_app_name(app) }) end else styled_header("My Apps") styled_array(my_apps.map { |app| regionized_app_name(app) }) end end unless collaborated_apps.empty? styled_header("Collaborated Apps") styled_array(collaborated_apps.map { |app| [regionized_app_name(app), app["owner_email"]] }) end else display("You have no apps.") end end |
#info ⇒ Object
apps:info
show detailed app information
-s, –shell # output more shell friendly key/value pairs
Examples:
$ pogo apps:info
example
Git URL: [email protected]:example.git Repo Size: 5M …
$ pogo apps:info –shell [email protected]:example.git repo_size=5000000 …
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 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 |
# File 'lib/heroku/command/apps.rb', line 84 def info validate_arguments! app_data = api.get_app(app).body unless [:shell] styled_header(app_data["name"]) end addons_data = api.get_addons(app).body.map {|addon| addon['name']}.sort collaborators_data = api.get_collaborators(app).body.map {|collaborator| collaborator["email"]}.sort collaborators_data.reject! {|email| email == app_data["owner_email"]} if [:shell] if app_data['domain_name'] app_data['domain_name'] = app_data['domain_name']['domain'] end unless addons_data.empty? app_data['addons'] = addons_data.join(',') end unless collaborators_data.empty? app_data['collaborators'] = collaborators_data.join(',') end app_data.keys.sort_by { |a| a.to_s }.each do |key| hputs("#{key}=#{app_data[key]}") end else data = {} unless addons_data.empty? data["Addons"] = addons_data end data["Collaborators"] = collaborators_data if app_data["create_status"] && app_data["create_status"] != "complete" data["Create Status"] = app_data["create_status"] end if app_data["cron_finished_at"] data["Cron Finished At"] = format_date(app_data["cron_finished_at"]) end if app_data["cron_next_run"] data["Cron Next Run"] = format_date(app_data["cron_next_run"]) end if app_data["database_size"] data["Database Size"] = format_bytes(app_data["database_size"]) end data["Git URL"] = app_data["git_url"] if app_data["database_tables"] data["Database Size"].gsub!('(empty)', '0K') + " in #{quantify("table", app_data["database_tables"])}" end if app_data["dyno_hours"].is_a?(Hash) data["Dyno Hours"] = app_data["dyno_hours"].keys.map do |type| "%s - %0.2f dyno-hours" % [ type.to_s.capitalize, app_data["dyno_hours"][type] ] end end data["Owner Email"] = app_data["owner_email"] if app_data["region"] data["Region"] = app_data["region"] end if app_data["repo_size"] data["Repo Size"] = format_bytes(app_data["repo_size"]) end if app_data["slug_size"] data["Slug Size"] = format_bytes(app_data["slug_size"]) end data["Stack"] = app_data["stack"] if data["Stack"] != "cedar" data.merge!("Dynos" => app_data["dynos"], "Workers" => app_data["workers"]) end data["Web URL"] = app_data["web_url"] if app_data["tier"] data["Tier"] = app_data["tier"].capitalize end styled_hash(data) end end |
#open ⇒ Object
apps:open
open the app in a web browser
Example:
$ pogo apps:open Opening example… done
308 309 310 311 312 313 |
# File 'lib/heroku/command/apps.rb', line 308 def open validate_arguments! app_data = api.get_app(app).body launchy("Opening #{app}", app_data['web_url']) end |
#rename ⇒ Object
apps:rename NEWNAME
rename the app
Example:
$ pogo apps:rename example-newname example-newname.herokuapp.com/ | [email protected]:example-newname.git Git remote heroku updated
271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 |
# File 'lib/heroku/command/apps.rb', line 271 def rename newname = shift_argument if newname.nil? || newname.empty? error("Usage: pogo apps:rename NEWNAME\nMust specify NEWNAME to rename.") end validate_arguments! action("Renaming #{app} to #{newname}") do api.put_app(app, "name" => newname) end app_data = api.get_app(newname).body hputs([ app_data["web_url"], app_data["git_url"] ].join(" | ")) if remotes = git_remotes(Dir.pwd) remotes.each do |remote_name, remote_app| next if remote_app != app git "remote rm #{remote_name}" git "remote add #{remote_name} #{app_data["git_url"]}" hputs("Git remote #{remote_name} updated") end else hputs("Don't forget to update your Git remotes on any local checkouts.") end end |
#upgrade ⇒ Object
apps:upgrade TIER
HIDDEN: upgrade an app’s pricing tier
357 358 359 360 361 362 363 364 365 |
# File 'lib/heroku/command/apps.rb', line 357 def upgrade tier = shift_argument error("Usage: pogo apps:upgrade TIER\nMust specify TIER to upgrade.") if tier.nil? || tier.empty? validate_arguments! action("Upgrading #{app} to #{tier}") do api.put_app(app, "tier" => tier) end end |