Class: Command::Maintenance

Inherits:
Base
  • Object
show all
Defined in:
lib/command/maintenance.rb

Constant Summary collapse

NAME =
"maintenance"
OPTIONS =
[
  app_option(required: true),
  domain_option
].freeze
DESCRIPTION =
"Checks if maintenance mode is on or off for an app"
LONG_DESCRIPTION =
<<~DESC
  - Checks if maintenance mode is on or off for an app
  - Outputs 'on' or 'off'
  - Specify the one-off workload through `one_off_workload` in the `.controlplane/controlplane.yml` file
  - Optionally specify the maintenance workload through `maintenance_workload` in the `.controlplane/controlplane.yml` file (defaults to 'maintenance')
  - 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
DESC
WITH_INFO_HEADER =
false

Constants inherited from Base

Base::ACCEPTS_EXTRA_OPTIONS, Base::ALL_VALIDATIONS, Base::DEFAULT_ARGS, Base::EXAMPLES, Base::HIDE, Base::REQUIRES_ARGS, Base::USAGE, Base::VALIDATIONS, Base::VALIDATIONS_WITHOUT_ADDITIONAL_OPTIONS, Base::VALIDATIONS_WITH_ADDITIONAL_OPTIONS

Instance Attribute Summary

Attributes inherited from Base

#config

Instance Method Summary collapse

Methods inherited from Base

add_app_identity_option, all_commands, all_options, all_options_by_key_name, app_option, #args_join, commit_option, common_options, #cp, cpu_option, detached_option, domain_option, #ensure_docker_running!, entrypoint_option, image_option, #initialize, interactive_option, location_option, log_method_option, logs_limit_option, logs_since_option, memory_option, org_option, #progress, replica_option, #run_command_in_latest_image, run_release_phase_option, skip_confirm_option, skip_post_creation_hook_option, skip_pre_deletion_hook_option, skip_secret_access_binding_option, skip_secrets_setup_option, #step, #step_error, #step_finish, terminal_size_option, trace_option, upstream_token_option, use_local_token_option, validations_option, verbose_option, version_option, wait_option, workload_option

Methods included from Helpers

normalize_command_name, normalize_option_name, random_four_digits, strip_str_and_validate

Constructor Details

This class inherits a constructor from Command::Base

Instance Method Details

#callObject

rubocop:disable Metrics/MethodLength



20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/command/maintenance.rb', line 20

def call # rubocop:disable Metrics/MethodLength
  one_off_workload = config[:one_off_workload]
  maintenance_workload = config.current[:maintenance_workload] || "maintenance"

  domain_data = if config.domain
                  cp.fetch_domain(config.domain)
                else
                  cp.find_domain_for([one_off_workload, maintenance_workload])
                end
  unless 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

  if cp.domain_workload_matches?(domain_data, maintenance_workload)
    puts "on"
  else
    puts "off"
  end
end