You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
132 lines
4.3 KiB
132 lines
4.3 KiB
# The top level settings are used as module
|
|
# and system configuration.
|
|
|
|
# A set of users which may be applied and/or used by various modules
|
|
# when a 'default' entry is found it will reference the 'default_user'
|
|
# from the distro configuration specified below
|
|
users:
|
|
- default
|
|
|
|
# If this is set, 'root' will not be able to ssh in and they
|
|
# will get a message to login instead as the default $user
|
|
disable_root: true
|
|
|
|
# This will cause the set+update hostname module to not operate (if true)
|
|
preserve_hostname: true
|
|
|
|
ssh_pwauth: yes
|
|
chpasswd:
|
|
expire: false
|
|
list:
|
|
- installer:RANDOM
|
|
|
|
# This is the initial network config.
|
|
# It can be overwritten by cloud-init or subiquity.
|
|
network:
|
|
version: 2
|
|
ethernets:
|
|
all-en:
|
|
match:
|
|
name: "en*"
|
|
dhcp4: true
|
|
all-eth:
|
|
match:
|
|
name: "eth*"
|
|
dhcp4: true
|
|
|
|
final_message: "## template: jinja\nCloud-init v. {{version}} finished at {{timestamp}}. Datasource {{datasource}}. Up {{uptime}} seconds\n\n\nWelcome to Ubuntu Server Installer!\n\nAbove you will find SSH host keys and a random password set for the `installer` user. You can use these credentials to ssh-in and complete the installation. If you provided SSH keys in the cloud-init datasource, they were also provisioned to the installer user.\n\nIf you have access to the graphical console, like TTY1 or HMC ASCII terminal you can complete the installation there too."
|
|
|
|
# Example datasource config
|
|
# datasource:
|
|
# Ec2:
|
|
# metadata_urls: [ 'blah.com' ]
|
|
# timeout: 5 # (defaults to 50 seconds)
|
|
# max_wait: 10 # (defaults to 120 seconds)
|
|
|
|
# The modules that run in the 'init' stage
|
|
cloud_init_modules:
|
|
- bootcmd
|
|
- write-files
|
|
- ca-certs
|
|
- rsyslog
|
|
- users-groups
|
|
- ssh
|
|
|
|
# The modules that run in the 'config' stage
|
|
cloud_config_modules:
|
|
# Emit the cloud config ready event
|
|
# this can be used by upstart jobs for 'start on cloud-config'.
|
|
- ssh-import-id
|
|
- set-passwords
|
|
- timezone
|
|
- disable-ec2-metadata
|
|
- runcmd
|
|
|
|
# The modules that run in the 'final' stage
|
|
cloud_final_modules:
|
|
- scripts-per-once
|
|
- scripts-user
|
|
- ssh-authkey-fingerprints
|
|
- keys-to-console
|
|
- phone-home
|
|
- final-message
|
|
|
|
# System and/or distro specific settings
|
|
# (not accessible to handlers/transforms)
|
|
system_info:
|
|
# This will affect which distro class gets used
|
|
distro: ubuntu
|
|
# Default user name + that default users groups (if added/used)
|
|
default_user:
|
|
name: installer
|
|
lock_passwd: false
|
|
gecos: Ubuntu
|
|
groups: [adm, audio, cdrom, dialout, dip, floppy, lxd, netdev, plugdev, sudo, video]
|
|
sudo: ["ALL=(ALL) NOPASSWD:ALL"]
|
|
shell: /usr/bin/subiquity-shell
|
|
# Automatically discover the best ntp_client
|
|
ntp_client: auto
|
|
# Other config here will be given to the distro class and/or path classes
|
|
paths:
|
|
cloud_dir: /var/lib/cloud/
|
|
templates_dir: /etc/cloud/templates/
|
|
upstart_dir: /etc/init/
|
|
package_mirrors:
|
|
- arches: [i386, amd64]
|
|
failsafe:
|
|
primary: http://archive.ubuntu.com/ubuntu
|
|
security: http://security.ubuntu.com/ubuntu
|
|
search:
|
|
primary:
|
|
- http://%(ec2_region)s.ec2.archive.ubuntu.com/ubuntu/
|
|
- http://%(availability_zone)s.clouds.archive.ubuntu.com/ubuntu/
|
|
- http://%(region)s.clouds.archive.ubuntu.com/ubuntu/
|
|
security: []
|
|
- arches: [arm64, armel, armhf]
|
|
failsafe:
|
|
primary: http://ports.ubuntu.com/ubuntu-ports
|
|
security: http://ports.ubuntu.com/ubuntu-ports
|
|
search:
|
|
primary:
|
|
- http://%(ec2_region)s.ec2.ports.ubuntu.com/ubuntu-ports/
|
|
- http://%(availability_zone)s.clouds.ports.ubuntu.com/ubuntu-ports/
|
|
- http://%(region)s.clouds.ports.ubuntu.com/ubuntu-ports/
|
|
security: []
|
|
- arches: [default]
|
|
failsafe:
|
|
primary: http://ports.ubuntu.com/ubuntu-ports
|
|
security: http://ports.ubuntu.com/ubuntu-ports
|
|
ssh_svcname: ssh
|
|
|
|
runcmd:
|
|
- - "python3"
|
|
- "-c"
|
|
- |
|
|
import subprocess, sys, yaml
|
|
user_data = yaml.safe_load(subprocess.run([
|
|
"cloud-init", "query", "userdata"],
|
|
check=True, stdout=subprocess.PIPE, encoding='utf-8').stdout)
|
|
if user_data is not None and 'autoinstall' in user_data:
|
|
with open("/autoinstall.yaml", "w") as fp:
|
|
yaml.dump(user_data['autoinstall'], fp)
|