2019-02-06 16:03:40 -05:00
|
|
|
### SSH key pair automation
|
|
|
|
|
|
|
|
The VirtualBox builders can inject the current SSH key pair's public key into
|
2020-12-01 18:30:31 -05:00
|
|
|
the template using the `SSHPublicKey` template engine. This is the SSH public
|
2020-09-04 19:55:58 -04:00
|
|
|
key as a line in OpenSSH authorized_keys format.
|
2019-02-06 16:03:40 -05:00
|
|
|
|
|
|
|
When a private key is provided using `ssh_private_key_file`, the key's
|
2020-09-04 19:55:58 -04:00
|
|
|
corresponding public key can be accessed using the above engine.
|
|
|
|
|
2020-12-01 18:30:31 -05:00
|
|
|
@include 'packer-plugin-sdk/communicator/SSH-Private-Key-File-not-required.mdx'
|
2019-02-06 16:03:40 -05:00
|
|
|
|
|
|
|
If `ssh_password` and `ssh_private_key_file` are not specified, Packer will
|
|
|
|
automatically generate en ephemeral key pair. The key pair's public key can
|
2020-09-04 19:55:58 -04:00
|
|
|
be accessed using the template engine.
|
2019-02-06 16:03:40 -05:00
|
|
|
|
2019-02-28 17:06:51 -05:00
|
|
|
For example, the public key can be provided in the boot command as a URL
|
|
|
|
encoded string by appending `| urlquery` to the variable:
|
2019-04-17 12:55:21 -04:00
|
|
|
|
2020-08-20 09:43:38 -04:00
|
|
|
In JSON:
|
2019-02-06 16:03:40 -05:00
|
|
|
```json
|
2020-08-20 09:43:38 -04:00
|
|
|
"boot_command": [
|
|
|
|
"<up><wait><tab> text ks=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ks.cfg PACKER_USER={{ user `username` }} PACKER_AUTHORIZED_KEY={{ .SSHPublicKey | urlquery }}<enter>"
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
|
|
|
In HCL2:
|
|
|
|
```hcl
|
|
|
|
boot_command = [
|
|
|
|
"<up><wait><tab> text ks=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ks.cfg PACKER_USER={{ user `username` }} PACKER_AUTHORIZED_KEY={{ .SSHPublicKey | urlquery }}<enter>"
|
|
|
|
]
|
2019-02-06 16:03:40 -05:00
|
|
|
```
|
|
|
|
|
2019-02-28 17:06:51 -05:00
|
|
|
A kickstart could then leverage those fields from the kernel command line by
|
|
|
|
decoding the URL-encoded public key:
|
2019-04-17 12:55:21 -04:00
|
|
|
|
2020-05-29 17:12:05 -04:00
|
|
|
```shell
|
2019-02-06 16:03:40 -05:00
|
|
|
%post
|
|
|
|
|
|
|
|
# Newly created users need the file/folder framework for SSH key authentication.
|
|
|
|
umask 0077
|
|
|
|
mkdir /etc/skel/.ssh
|
|
|
|
touch /etc/skel/.ssh/authorized_keys
|
|
|
|
|
|
|
|
# Loop over the command line. Set interesting variables.
|
|
|
|
for x in $(cat /proc/cmdline)
|
|
|
|
do
|
|
|
|
case $x in
|
|
|
|
PACKER_USER=*)
|
|
|
|
PACKER_USER="${x#*=}"
|
|
|
|
;;
|
|
|
|
PACKER_AUTHORIZED_KEY=*)
|
|
|
|
# URL decode $encoded into $PACKER_AUTHORIZED_KEY
|
2019-02-28 17:06:51 -05:00
|
|
|
encoded=$(echo "${x#*=}" | tr '+' ' ')
|
2019-02-06 16:03:40 -05:00
|
|
|
printf -v PACKER_AUTHORIZED_KEY '%b' "${encoded//%/\\x}"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
# Create/configure packer user, if any.
|
|
|
|
if [ -n "$PACKER_USER" ]
|
|
|
|
then
|
|
|
|
useradd $PACKER_USER
|
|
|
|
echo "%$PACKER_USER ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers.d/$PACKER_USER
|
|
|
|
[ -n "$PACKER_AUTHORIZED_KEY" ] && echo $PACKER_AUTHORIZED_KEY >> $(eval echo ~"$PACKER_USER")/.ssh/authorized_keys
|
|
|
|
fi
|
|
|
|
|
|
|
|
%end
|
|
|
|
```
|