aboutsummaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorChristopher Baines <mail@cbaines.net>2018-06-24 11:11:49 +0100
committerChristopher Baines <mail@cbaines.net>2018-06-24 11:11:49 +0100
commitac45ed064b096f715805d21638ee9286804d12ef (patch)
treebd0390124a0229d438668c4ae290f2a03ce88047 /app
parent3e3e975df56e6048594b1eaaed5ddbeab80918fb (diff)
downloadgovuk-mini-environment-admin-ac45ed064b096f715805d21638ee9286804d12ef.tar
govuk-mini-environment-admin-ac45ed064b096f715805d21638ee9286804d12ef.tar.gz
Neaten up SSH handling
Explicitly use the specified private key where possible. Also, use a struct for the user, address and private key.
Diffstat (limited to 'app')
-rw-r--r--app/controllers/govuk_guix/revisions_controller.rb6
-rw-r--r--app/models/backends/terraform_aws.rb8
-rw-r--r--app/models/backends/terraform_aws/backend_methods.rb6
-rw-r--r--app/models/backends/terraform_aws/mini_environment_methods.rb10
-rw-r--r--app/services/govuk_guix/build_mini_environment.rb6
5 files changed, 16 insertions, 20 deletions
diff --git a/app/controllers/govuk_guix/revisions_controller.rb b/app/controllers/govuk_guix/revisions_controller.rb
index 6e75e82..17634dd 100644
--- a/app/controllers/govuk_guix/revisions_controller.rb
+++ b/app/controllers/govuk_guix/revisions_controller.rb
@@ -33,12 +33,8 @@ class GovukGuix::RevisionsController < ApplicationController
# Assume that the AWS backend is in use
backend = Backends::TerraformAws.first
- remote_host = backend.backend_latest_terraform_state.output_value(
- 'guix_daemon_public_dns'
- )
-
options = {
- run_remotely_on_host: "ubuntu@#{remote_host}"
+ run_remotely_on_host: backend.build_remote_host
}
end
diff --git a/app/models/backends/terraform_aws.rb b/app/models/backends/terraform_aws.rb
index d0655ee..2bf68a3 100644
--- a/app/models/backends/terraform_aws.rb
+++ b/app/models/backends/terraform_aws.rb
@@ -64,6 +64,14 @@ class Backends::TerraformAws < ApplicationRecord
}
end
+ def build_remote_host
+ RemoteHost.new(
+ 'ubuntu',
+ backend_latest_terraform_state.output_value('guix_daemon_public_dns'),
+ ssh_private_key
+ )
+ end
+
def terraform_state_id
"backend/terraform_aws/#{id}"
end
diff --git a/app/models/backends/terraform_aws/backend_methods.rb b/app/models/backends/terraform_aws/backend_methods.rb
index 7489325..f069d77 100644
--- a/app/models/backends/terraform_aws/backend_methods.rb
+++ b/app/models/backends/terraform_aws/backend_methods.rb
@@ -20,12 +20,8 @@
module Backends::TerraformAws::BackendMethods
def create_data_snapshot
- remote_host = backend_latest_terraform_state.output_value(
- 'guix_daemon_public_dns'
- )
-
GovukGuix::CreateDataSnapshotJob.enqueue(
- run_remotely_on_host: "ubuntu@#{remote_host}",
+ run_remotely_on_host: build_remote_host,
backend_type: self.class.name,
backend_id: id
)
diff --git a/app/models/backends/terraform_aws/mini_environment_methods.rb b/app/models/backends/terraform_aws/mini_environment_methods.rb
index 1885af7..350df2a 100644
--- a/app/models/backends/terraform_aws/mini_environment_methods.rb
+++ b/app/models/backends/terraform_aws/mini_environment_methods.rb
@@ -22,14 +22,6 @@ module Backends::TerraformAws::MiniEnvironmentMethods
def build(mini_environment)
slug = mini_environment.name.parameterize
- remote_build_host =
- mini_environment
- .backend
- .backend_latest_terraform_state
- .output_value(
- 'guix_daemon_public_dns'
- )
-
GovukGuix::BuildMiniEnvironment.build(
mini_environment.id,
services: mini_environment.services.map(&:build_argument_string),
@@ -50,7 +42,7 @@ module Backends::TerraformAws::MiniEnvironmentMethods
'/var/log/govuk-mini-environment-admin=/var/log'
]
},
- run_remotely_on_host: "ubuntu@#{remote_build_host}"
+ run_remotely_on_host: mini_environment.backend.build_remote_host
)
end
diff --git a/app/services/govuk_guix/build_mini_environment.rb b/app/services/govuk_guix/build_mini_environment.rb
index a0361b0..8e2d912 100644
--- a/app/services/govuk_guix/build_mini_environment.rb
+++ b/app/services/govuk_guix/build_mini_environment.rb
@@ -37,12 +37,16 @@ module GovukGuix::BuildMiniEnvironment
remote_host = options[:run_remotely_on_host]
if remote_host && Guix.available_locally?
+ # TODO: This doesn't use the private key specified by the
+ # backend, so it'll only work when the default SSH key has
+ # access to the remote host.
+
# Copy the revision to the remote host, to ensure it's available
# there
run_command(
'guix',
'copy',
- "--to=#{remote_host}",
+ "--to=#{remote_host.user_at_address}",
mini_environment.govuk_guix_revision.store_path
)
end