Include the host name in the builder name, so we can have one builder per host/arch across all kamal projects. Inherit from the remote builder. The difference in the hybrid builder is that we create a local buildx instance and append the remote context to it.
60 lines
1.3 KiB
Ruby
60 lines
1.3 KiB
Ruby
require "active_support/core_ext/string/filters"
|
|
|
|
class Kamal::Commands::Builder < Kamal::Commands::Base
|
|
delegate :create, :remove, :push, :clean, :pull, :info, :context_hosts, :config_context_hosts, :validate_image,
|
|
:first_mirror, to: :target
|
|
|
|
include Clone
|
|
|
|
def name
|
|
target.class.to_s.remove("Kamal::Commands::Builder::").underscore.inquiry
|
|
end
|
|
|
|
def target
|
|
case
|
|
when !config.builder.multiarch? && !config.builder.cached?
|
|
local
|
|
when !config.builder.multiarch? && config.builder.cached?
|
|
local
|
|
when config.builder.local? && config.builder.remote?
|
|
hybrid
|
|
when config.builder.remote?
|
|
remote
|
|
else
|
|
local
|
|
end
|
|
end
|
|
|
|
def remote
|
|
@remote ||= Kamal::Commands::Builder::Remote.new(config)
|
|
end
|
|
|
|
def local
|
|
@local ||= Kamal::Commands::Builder::Local.new(config)
|
|
end
|
|
|
|
def hybrid
|
|
@hybrid ||= Kamal::Commands::Builder::Hybrid.new(config)
|
|
end
|
|
|
|
|
|
def ensure_local_dependencies_installed
|
|
if name.native?
|
|
ensure_local_docker_installed
|
|
else
|
|
combine \
|
|
ensure_local_docker_installed,
|
|
ensure_local_buildx_installed
|
|
end
|
|
end
|
|
|
|
private
|
|
def ensure_local_docker_installed
|
|
docker "--version"
|
|
end
|
|
|
|
def ensure_local_buildx_installed
|
|
docker :buildx, "version"
|
|
end
|
|
end
|