Class: Kamal::Cli::Main

Inherits:
Base
  • Object
show all
Defined in:
lib/kamal/cli/main.rb

Instance Method Summary collapse

Methods inherited from Base

exit_on_failure?, #initialize

Constructor Details

This class inherits a constructor from Kamal::Cli::Base

Instance Method Details

#auditObject



117
118
119
120
121
# File 'lib/kamal/cli/main.rb', line 117

def audit
  on(KAMAL.hosts) do |host|
    puts_by_host host, capture_with_info(*KAMAL.auditor.reveal)
  end
end

#configObject



124
125
126
127
128
# File 'lib/kamal/cli/main.rb', line 124

def config
  run_locally do
    puts Kamal::Utils.redacted(KAMAL.config.to_h).to_yaml
  end
end

#deployObject



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
# File 'lib/kamal/cli/main.rb', line 24

def deploy
  runtime = print_runtime do
    invoke_options = deploy_options

    say "Log into image registry...", :magenta
    invoke "kamal:cli:registry:login", [], invoke_options.merge(skip_local: options[:skip_push])

    if options[:skip_push]
      say "Pull app image...", :magenta
      invoke "kamal:cli:build:pull", [], invoke_options
    else
      say "Build and push app image...", :magenta
      invoke "kamal:cli:build:deliver", [], invoke_options
    end

    with_lock do
      run_hook "pre-deploy"

      say "Ensure Traefik is running...", :magenta
      invoke "kamal:cli:traefik:boot", [], invoke_options

      say "Detect stale containers...", :magenta
      invoke "kamal:cli:app:stale_containers", [], invoke_options.merge(stop: true)

      invoke "kamal:cli:app:boot", [], invoke_options

      say "Prune old containers and images...", :magenta
      invoke "kamal:cli:prune:all", [], invoke_options
    end
  end

  run_hook "post-deploy", runtime: runtime.round
end

#detailsObject



110
111
112
113
114
# File 'lib/kamal/cli/main.rb', line 110

def details
  invoke "kamal:cli:traefik:details"
  invoke "kamal:cli:app:details"
  invoke "kamal:cli:accessory:details", [ "all" ]
end

#docs(section = nil) ⇒ Object



131
132
133
134
135
136
137
138
139
140
# File 'lib/kamal/cli/main.rb', line 131

def docs(section = nil)
  case section
  when NilClass
    puts Kamal::Configuration.validation_doc
  else
    puts Kamal::Configuration.const_get(section.titlecase.to_sym).validation_doc
  end
rescue NameError
  puts "No documentation found for #{section}"
end

#envifyObject



184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
# File 'lib/kamal/cli/main.rb', line 184

def envify
  if destination = options[:destination]
    env_template_path = ".env.#{destination}.erb"
    env_path          = ".env.#{destination}"
  else
    env_template_path = ".env.erb"
    env_path          = ".env"
  end

  if Pathname.new(File.expand_path(env_template_path)).exist?
    # Ensure existing env doesn't pollute template evaluation
    content = with_original_env { ERB.new(File.read(env_template_path), trim_mode: "-").result }
    File.write(env_path, content, perm: 0600)

    unless options[:skip_push]
      reload_env
      invoke "kamal:cli:env:push", options
    end
  else
    puts "Skipping envify (no #{env_template_path} exist)"
  end
end

#initObject



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
174
175
176
177
178
179
180
# File 'lib/kamal/cli/main.rb', line 144

def init
  require "fileutils"

  if (deploy_file = Pathname.new(File.expand_path("config/deploy.yml"))).exist?
    puts "Config file already exists in config/deploy.yml (remove first to create a new one)"
  else
    FileUtils.mkdir_p deploy_file.dirname
    FileUtils.cp_r Pathname.new(File.expand_path("templates/deploy.yml", __dir__)), deploy_file
    puts "Created configuration file in config/deploy.yml"
  end

  unless (deploy_file = Pathname.new(File.expand_path(".env"))).exist?
    FileUtils.cp_r Pathname.new(File.expand_path("templates/template.env", __dir__)), deploy_file
    puts "Created .env file"
  end

  unless (hooks_dir = Pathname.new(File.expand_path(".kamal/hooks"))).exist?
    hooks_dir.mkpath
    Pathname.new(File.expand_path("templates/sample_hooks", __dir__)).each_child do |sample_hook|
      FileUtils.cp sample_hook, hooks_dir, preserve: true
    end
    puts "Created sample hooks in .kamal/hooks"
  end

  if options[:bundle]
    if (binstub = Pathname.new(File.expand_path("bin/kamal"))).exist?
      puts "Binstub already exists in bin/kamal (remove first to create a new one)"
    else
      puts "Adding Kamal to Gemfile and bundle..."
      run_locally do
        execute :bundle, :add, :kamal
        execute :bundle, :binstubs, :kamal
      end
      puts "Created binstub file in bin/kamal"
    end
  end
end

#redeployObject



60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'lib/kamal/cli/main.rb', line 60

def redeploy
  runtime = print_runtime do
    invoke_options = deploy_options

    if options[:skip_push]
      say "Pull app image...", :magenta
      invoke "kamal:cli:build:pull", [], invoke_options
    else
      say "Build and push app image...", :magenta
      invoke "kamal:cli:build:deliver", [], invoke_options
    end

    with_lock do
      run_hook "pre-deploy"

      say "Detect stale containers...", :magenta
      invoke "kamal:cli:app:stale_containers", [], invoke_options.merge(stop: true)

      invoke "kamal:cli:app:boot", [], invoke_options
    end
  end

  run_hook "post-deploy", runtime: runtime.round
end

#removeObject



209
210
211
212
213
214
215
216
217
218
# File 'lib/kamal/cli/main.rb', line 209

def remove
  confirming "This will remove all containers and images. Are you sure?" do
    with_lock do
      invoke "kamal:cli:traefik:remove", [], options.without(:confirmed)
      invoke "kamal:cli:app:remove", [], options.without(:confirmed)
      invoke "kamal:cli:accessory:remove", [ "all" ], options
      invoke "kamal:cli:registry:logout", [], options.without(:confirmed).merge(skip_local: true)
    end
  end
end

#rollback(version) ⇒ Object



86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# File 'lib/kamal/cli/main.rb', line 86

def rollback(version)
  rolled_back = false
  runtime = print_runtime do
    with_lock do
      invoke_options = deploy_options

      KAMAL.config.version = version
      old_version = nil

      if container_available?(version)
        run_hook "pre-deploy"

        invoke "kamal:cli:app:boot", [], invoke_options.merge(version: version)
        rolled_back = true
      else
        say "The app version '#{version}' is not available as a container (use 'kamal app containers' for available versions)", :red
      end
    end
  end

  run_hook "post-deploy", runtime: runtime.round if rolled_back
end

#setupObject



4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# File 'lib/kamal/cli/main.rb', line 4

def setup
  print_runtime do
    with_lock do
      invoke_options = deploy_options

      say "Ensure Docker is installed...", :magenta
      invoke "kamal:cli:server:bootstrap", [], invoke_options

      say "Evaluate and push env files...", :magenta
      invoke "kamal:cli:main:envify", [], invoke_options
      invoke "kamal:cli:env:push", [], invoke_options

      invoke "kamal:cli:accessory:boot", [ "all" ], invoke_options
      deploy
    end
  end
end

#versionObject



221
222
223
# File 'lib/kamal/cli/main.rb', line 221

def version
  puts Kamal::VERSION
end