Class: Kamal::Configuration

Inherits:
Object
  • Object
show all
Includes:
Validation
Defined in:
lib/kamal/configuration.rb

Defined Under Namespace

Modules: Validation Classes: Accessory, Alias, Boot, Builder, Env, Logging, Proxy, Registry, Role, Servers, Ssh, Sshkit, Validator, Volume

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Validation

#validate!, #validation_yml

Constructor Details

#initialize(raw_config, destination: nil, version: nil, validate: true) ⇒ Configuration

Returns a new instance of Configuration.



46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# File 'lib/kamal/configuration.rb', line 46

def initialize(raw_config, destination: nil, version: nil, validate: true)
  @raw_config = ActiveSupport::InheritableOptions.new(raw_config)
  @destination = destination
  @declared_version = version

  validate! raw_config, example: validation_yml.symbolize_keys, context: "", with: Kamal::Configuration::Validator::Configuration

  @secrets = Kamal::Secrets.new(destination: destination)

  # Eager load config to validate it, these are first as they have dependencies later on
  @servers = Servers.new(config: self)
  @registry = Registry.new(config: @raw_config, secrets: secrets)

  @accessories = @raw_config.accessories&.keys&.collect { |name| Accessory.new(name, config: self) } || []
  @aliases = @raw_config.aliases&.keys&.to_h { |name| [ name, Alias.new(name, config: self) ] } || {}
  @boot = Boot.new(config: self)
  @builder = Builder.new(config: self)
  @env = Env.new(config: @raw_config.env || {}, secrets: secrets)

  @logging = Logging.new(logging_config: @raw_config.logging)
  @proxy = Proxy.new(config: self, proxy_config: @raw_config.proxy, secrets: secrets)
  @proxy_boot = Proxy::Boot.new(config: self)
  @ssh = Ssh.new(config: self)
  @sshkit = Sshkit.new(config: self)

  ensure_destination_if_required
  ensure_required_keys_present
  ensure_valid_kamal_version
  ensure_retain_containers_valid
  ensure_valid_service_name
  ensure_no_traefik_reboot_hooks
  ensure_one_host_for_ssl_roles
  ensure_unique_hosts_for_ssl_roles
  ensure_local_registry_remote_builder_has_ssh_url
end

Instance Attribute Details

#accessoriesObject (readonly)

Returns the value of attribute accessories.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def accessories
  @accessories
end

#aliasesObject (readonly)

Returns the value of attribute aliases.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def aliases
  @aliases
end

#bootObject (readonly)

Returns the value of attribute boot.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def boot
  @boot
end

#builderObject (readonly)

Returns the value of attribute builder.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def builder
  @builder
end

#destinationObject (readonly)

Returns the value of attribute destination.



12
13
14
# File 'lib/kamal/configuration.rb', line 12

def destination
  @destination
end

#envObject (readonly)

Returns the value of attribute env.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def env
  @env
end

#loggingObject (readonly)

Returns the value of attribute logging.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def logging
  @logging
end

#proxyObject (readonly)

Returns the value of attribute proxy.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def proxy
  @proxy
end

#proxy_bootObject (readonly)

Returns the value of attribute proxy_boot.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def proxy_boot
  @proxy_boot
end

#raw_configObject (readonly)

Returns the value of attribute raw_config.



12
13
14
# File 'lib/kamal/configuration.rb', line 12

def raw_config
  @raw_config
end

#registryObject (readonly)

Returns the value of attribute registry.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def registry
  @registry
end

#secretsObject (readonly)

Returns the value of attribute secrets.



12
13
14
# File 'lib/kamal/configuration.rb', line 12

def secrets
  @secrets
end

#serversObject (readonly)

Returns the value of attribute servers.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def servers
  @servers
end

#sshObject (readonly)

Returns the value of attribute ssh.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def ssh
  @ssh
end

#sshkitObject (readonly)

Returns the value of attribute sshkit.



13
14
15
# File 'lib/kamal/configuration.rb', line 13

def sshkit
  @sshkit
end

Class Method Details

.create_from(config_file:, destination: nil, version: nil) ⇒ Object



18
19
20
21
22
23
24
# File 'lib/kamal/configuration.rb', line 18

def create_from(config_file:, destination: nil, version: nil)
  ENV["KAMAL_DESTINATION"] = destination

  raw_config = load_config_files(config_file, *destination_config_file(config_file, destination))

  new raw_config, destination: destination, version: version
end

Instance Method Details

#abbreviated_versionObject



90
91
92
93
94
95
96
97
98
99
# File 'lib/kamal/configuration.rb', line 90

def abbreviated_version
  if version
    # Don't abbreviate <sha>_uncommitted_<etc>
    if version.include?("_")
      version
    else
      version[0...7]
    end
  end
end

#absolute_imageObject



172
173
174
# File 'lib/kamal/configuration.rb', line 172

def absolute_image
  "#{repository}:#{version}"
end

#accessory(name) ⇒ Object



117
118
119
# File 'lib/kamal/configuration.rb', line 117

def accessory(name)
  accessories.detect { |a| a.name == name.to_s }
end

#all_hostsObject



121
122
123
# File 'lib/kamal/configuration.rb', line 121

def all_hosts
  (roles + accessories).flat_map(&:hosts).uniq
end

#allow_empty_roles?Boolean

Returns:

  • (Boolean)


141
142
143
# File 'lib/kamal/configuration.rb', line 141

def allow_empty_roles?
  raw_config.allow_empty_roles
end

#app_directoryObject



228
229
230
# File 'lib/kamal/configuration.rb', line 228

def app_directory
  File.join apps_directory, service_and_destination
end

#app_hostsObject



125
126
127
# File 'lib/kamal/configuration.rb', line 125

def app_hosts
  roles.flat_map(&:hosts).uniq
end

#apps_directoryObject



224
225
226
# File 'lib/kamal/configuration.rb', line 224

def apps_directory
  File.join run_directory, "apps"
end

#asset_pathObject



244
245
246
# File 'lib/kamal/configuration.rb', line 244

def asset_path
  raw_config.asset_path
end

#assets_directoryObject



236
237
238
# File 'lib/kamal/configuration.rb', line 236

def assets_directory
  File.join app_directory, "assets"
end

#deploy_timeoutObject



212
213
214
# File 'lib/kamal/configuration.rb', line 212

def deploy_timeout
  raw_config.deploy_timeout || 30
end

#drain_timeoutObject



216
217
218
# File 'lib/kamal/configuration.rb', line 216

def drain_timeout
  raw_config.drain_timeout || 30
end

#env_directoryObject



232
233
234
# File 'lib/kamal/configuration.rb', line 232

def env_directory
  File.join app_directory, "env"
end

#env_tag(name) ⇒ Object



260
261
262
# File 'lib/kamal/configuration.rb', line 260

def env_tag(name)
  env_tags.detect { |t| t.name == name.to_s }
end

#env_tagsObject



252
253
254
255
256
257
258
# File 'lib/kamal/configuration.rb', line 252

def env_tags
  @env_tags ||= if (tags = raw_config.env["tags"])
    tags.collect { |name, config| Env::Tag.new(name, config: config, secrets: secrets) }
  else
    []
  end
end

#error_pages_pathObject



248
249
250
# File 'lib/kamal/configuration.rb', line 248

def error_pages_path
  raw_config.error_pages_path
end

#hooks_pathObject



240
241
242
# File 'lib/kamal/configuration.rb', line 240

def hooks_path
  raw_config.hooks_path || ".kamal/hooks"
end

#imageObject



161
162
163
164
165
166
# File 'lib/kamal/configuration.rb', line 161

def image
  name = raw_config&.image.presence
  name ||= raw_config&.service if registry.local?

  name
end

#latest_imageObject



176
177
178
# File 'lib/kamal/configuration.rb', line 176

def latest_image
  "#{repository}:#{latest_tag}"
end

#latest_tagObject



180
181
182
# File 'lib/kamal/configuration.rb', line 180

def latest_tag
  [ "latest", *destination ].join("-")
end

#logging_argsObject



204
205
206
# File 'lib/kamal/configuration.rb', line 204

def logging_args
  logging.args
end

#minimum_versionObject



101
102
103
# File 'lib/kamal/configuration.rb', line 101

def minimum_version
  raw_config.minimum_version
end

#primary_hostObject



129
130
131
# File 'lib/kamal/configuration.rb', line 129

def primary_host
  primary_role&.primary_host
end

#primary_roleObject



137
138
139
# File 'lib/kamal/configuration.rb', line 137

def primary_role
  role(primary_role_name)
end

#primary_role_nameObject



133
134
135
# File 'lib/kamal/configuration.rb', line 133

def primary_role_name
  raw_config.primary_role || "web"
end

#proxy_accessoriesObject



153
154
155
# File 'lib/kamal/configuration.rb', line 153

def proxy_accessories
  accessories.select(&:running_proxy?)
end

#proxy_hostsObject



157
158
159
# File 'lib/kamal/configuration.rb', line 157

def proxy_hosts
  (proxy_roles.flat_map(&:hosts) + proxy_accessories.flat_map(&:hosts)).uniq
end

#proxy_role_namesObject



149
150
151
# File 'lib/kamal/configuration.rb', line 149

def proxy_role_names
  proxy_roles.flat_map(&:name)
end

#proxy_rolesObject



145
146
147
# File 'lib/kamal/configuration.rb', line 145

def proxy_roles
  roles.select(&:running_proxy?)
end

#readiness_delayObject



208
209
210
# File 'lib/kamal/configuration.rb', line 208

def readiness_delay
  raw_config.readiness_delay || 7
end

#repositoryObject



168
169
170
# File 'lib/kamal/configuration.rb', line 168

def repository
  [ registry.server, image ].compact.join("/")
end

#require_destination?Boolean

Returns:

  • (Boolean)


188
189
190
# File 'lib/kamal/configuration.rb', line 188

def require_destination?
  raw_config.require_destination
end

#retain_containersObject



192
193
194
# File 'lib/kamal/configuration.rb', line 192

def retain_containers
  raw_config.retain_containers || 5
end

#role(name) ⇒ Object



113
114
115
# File 'lib/kamal/configuration.rb', line 113

def role(name)
  roles.detect { |r| r.name == name.to_s }
end

#rolesObject



109
110
111
# File 'lib/kamal/configuration.rb', line 109

def roles
  servers.roles
end

#run_directoryObject



220
221
222
# File 'lib/kamal/configuration.rb', line 220

def run_directory
  ".kamal"
end

#service_and_destinationObject



105
106
107
# File 'lib/kamal/configuration.rb', line 105

def service_and_destination
  [ service, destination ].compact.join("-")
end

#service_with_versionObject



184
185
186
# File 'lib/kamal/configuration.rb', line 184

def service_with_version
  "#{service}-#{version}"
end

#to_hObject



264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
# File 'lib/kamal/configuration.rb', line 264

def to_h
  {
    roles: role_names,
    hosts: all_hosts,
    primary_host: primary_host,
    version: version,
    repository: repository,
    absolute_image: absolute_image,
    service_with_version: service_with_version,
    volume_args: volume_args,
    ssh_options: ssh.to_h,
    sshkit: sshkit.to_h,
    builder: builder.to_h,
    accessories: raw_config.accessories,
    logging: logging_args
  }.compact
end

#versionObject



86
87
88
# File 'lib/kamal/configuration.rb', line 86

def version
  @declared_version.presence || ENV["VERSION"] || git_version
end

#version=(version) ⇒ Object



82
83
84
# File 'lib/kamal/configuration.rb', line 82

def version=(version)
  @declared_version = version
end

#volume_argsObject



196
197
198
199
200
201
202
# File 'lib/kamal/configuration.rb', line 196

def volume_args
  if raw_config.volumes.present?
    argumentize "--volume", raw_config.volumes
  else
    []
  end
end