-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Refactor maintenance commands (#212)
* Refactor maintenance commands
- Loading branch information
Showing
9 changed files
with
202 additions
and
206 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
# frozen_string_literal: true | ||
|
||
require "forwardable" | ||
|
||
class MaintenanceMode | ||
extend Forwardable | ||
|
||
def_delegators :@command, :config, :progress, :cp, :step, :run_cpflow_command | ||
|
||
def initialize(command) | ||
@command = command | ||
end | ||
|
||
def enabled? | ||
validate_domain_exists! | ||
cp.domain_workload_matches?(domain_data, maintenance_workload) | ||
end | ||
|
||
def disabled? | ||
validate_domain_exists! | ||
cp.domain_workload_matches?(domain_data, one_off_workload) | ||
end | ||
|
||
def enable! | ||
if enabled? | ||
progress.puts("Maintenance mode is already enabled for app '#{config.app}'.") | ||
else | ||
enable_maintenance_mode | ||
end | ||
end | ||
|
||
def disable! | ||
if disabled? | ||
progress.puts("Maintenance mode is already disabled for app '#{config.app}'.") | ||
else | ||
disable_maintenance_mode | ||
end | ||
end | ||
|
||
private | ||
|
||
def enable_maintenance_mode | ||
validate_maintenance_workload_exists! | ||
|
||
start_or_stop_maintenance_workload(:start) | ||
switch_domain_workload(to: maintenance_workload) | ||
start_or_stop_all_workloads(:stop) | ||
|
||
progress.puts("\nMaintenance mode enabled for app '#{config.app}'.") | ||
end | ||
|
||
def disable_maintenance_mode | ||
validate_maintenance_workload_exists! | ||
|
||
start_or_stop_maintenance_workload(:start) | ||
switch_domain_workload(to: one_off_workload) | ||
start_or_stop_all_workloads(:stop) | ||
|
||
progress.puts("\nMaintenance mode disabled for app '#{config.app}'.") | ||
end | ||
|
||
def validate_domain_exists! | ||
return if domain_data | ||
|
||
raise "Can't find domain. " \ | ||
"Maintenance mode is only supported for domains that use path based routing mode " \ | ||
"and have a route configured for the prefix '/' on either port 80 or 443." | ||
end | ||
|
||
def validate_maintenance_workload_exists! | ||
cp.fetch_workload!(maintenance_workload) | ||
end | ||
|
||
def start_or_stop_all_workloads(action) | ||
run_cpflow_command("ps:#{action}", "-a", config.app, "--wait") | ||
|
||
progress.puts | ||
end | ||
|
||
def start_or_stop_maintenance_workload(action) | ||
run_cpflow_command("ps:#{action}", "-a", config.app, "-w", maintenance_workload, "--wait") | ||
|
||
progress.puts | ||
end | ||
|
||
def switch_domain_workload(to:) | ||
step("Switching workload for domain '#{domain_data['name']}' to '#{to}'") do | ||
cp.set_domain_workload(domain_data, to) | ||
|
||
# Give it a bit of time for the domain to update | ||
Kernel.sleep(30) | ||
end | ||
|
||
progress.puts | ||
end | ||
|
||
def domain_data | ||
@domain_data ||= | ||
if config.domain | ||
cp.fetch_domain(config.domain) | ||
else | ||
cp.find_domain_for([one_off_workload, maintenance_workload]) | ||
end | ||
end | ||
|
||
def one_off_workload | ||
@one_off_workload ||= config[:one_off_workload] | ||
end | ||
|
||
def maintenance_workload | ||
@maintenance_workload ||= config.current[:maintenance_workload] || "maintenance" | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.