Ubuntu Server Installer, and backend for Ubuntu Desktop Installer
Go to file
Dan Bungert b880843a48
Merge pull request #1766 from ogayot/recovery-key
Add API and TUI support for LUKS recovery key
2023-08-30 09:25:50 -06:00
.github/workflows workflow: -kinetic 2023-07-27 12:31:40 -06:00
bin snapcraft: fix probert, add curtin runners 2023-08-01 21:25:48 -06:00
console_conf one-off format of long lines with black 2023-07-25 15:27:49 -06:00
debian update github urls to new organization 2021-02-23 12:03:37 +13:00
doc doc: editorial improvements to autoinstall tutorial 2023-07-13 16:02:21 -06:00
documentation doc: reference update for guided zfs 2023-07-19 14:54:37 -06:00
examples runtests: +zfs 2023-08-28 12:59:24 -06:00
fake_deps tox: Support running tests and flake8 in tox. 2018-06-05 17:59:46 -04:00
font font: allow to display circled white star in console font 2022-05-10 09:45:25 +02:00
kbds kbds: add entries for UDI 2022-08-08 07:54:09 -06:00
po update from newer export 2022-04-14 10:02:51 +12:00
scripts installdeps: use confnew to workaround upgrade 2023-08-28 12:59:24 -06:00
snap/hooks Revert "os-prober: patch instead of sed" 2022-01-24 12:18:41 -07:00
subiquity Merge pull request #1766 from ogayot/recovery-key 2023-08-30 09:25:50 -06:00
subiquitycore utils: add gen_zsys_uuid 2023-08-24 17:42:09 -06:00
system_setup one-off format of long lines with black 2023-07-25 15:27:49 -06:00
.flake8 flake8: compat with black 2023-07-25 15:25:55 -06:00
.git-blame-ignore-revs add .git-blame-ignore-revs 2023-07-25 15:28:44 -06:00
.gitignore Update .gitignore 2022-04-25 07:23:01 -06:00
.pre-commit-config.yaml add .pre-commit-config.yaml 2023-07-25 15:28:44 -06:00
.readthedocs.yaml Add readthedocs config file 2023-07-10 14:49:47 +01:00
CONTRIBUTING.md CONTRIBUTING: update for format requirements 2023-07-25 15:25:55 -06:00
DESIGN.md install: invoke curtin multiple times with different stages 2022-08-11 09:16:06 +02:00
LICENSE Initial commit 2015-06-08 17:57:45 -04:00
Makefile make: add targets format,black,isort 2023-07-25 15:25:55 -06:00
README.md tidy up examples/ directory 2023-07-11 12:49:22 +12:00
apt-deps.txt configure a UEFI boot entry to boot into a reset partition if present 2023-07-17 13:58:55 +12:00
autoinstall-schema.json oem: allow to disable install on desktop and force install on server 2023-06-30 20:53:12 +02:00
autoinstall-system-setup-schema.json Adding WSLSetupOptions API endpoint 2022-08-23 10:45:29 -03:00
languagelist update languagelist and layout suggestions 2022-07-29 14:13:27 -06:00
passwd Added a passwd file copied from a livecd filesystem 2022-05-11 12:58:58 -03:00
pyproject.toml pyproject: create 2023-07-25 15:25:55 -06:00
reserved-usernames reserved-usernames: add sgx group ahead of ubuntu 2022-09-22 11:09:30 +02:00
setup.py setup: fix bdist_wheel 2023-07-25 15:25:55 -06:00
snapcraft.yaml snapcraft: bump curtin for recovery key support 2023-08-30 16:45:42 +02:00
tox.ini tox: use skip_install to speed up black/isort 2023-07-25 18:29:22 -06:00
users-and-groups Ensure first user is in the users group and not in the lxd group. This 2022-11-03 08:22:43 +01:00

README.md

subiquity & console-conf

Ubuntu Server Installer & Snappy first boot experience

The repository contains the source for the new server installer (the "subiquity" part, aka "ubiquity for servers") and for the snappy first boot experience (the "console-conf" part).

We track bugs in Launchpad at https://bugs.launchpad.net/subiquity. Snappy first boot issues can also be discussed in the forum at https://forum.snapcraft.io.

Our localization platform is Launchpad, translations are managed at https://translations.launchpad.net/ubuntu/+source/subiquity/

To update translation template in launchpad:

  • update po/POTFILES.in with any new files that contain translations
  • execute clean target, i.e. $ debuild -S
  • dput subiquity into Ubuntu

To export and update translations in subiquity:

Acquire subiquity from source

git clone https://github.com/canonical/subiquity

cd subiquity && make install_deps

Testing out the installer Text-UI (TUI)

Subiquity's text UI is available for testing without actually installing anything to a system or a VM. Subiquity developers make use of this for rapid development. After checking out subiquity you can start it:

make dryrun

All of the features are present in dry-run mode. The installer will emit its backend configuration files to /tmp/subiquity-config-* but it won't attempt to run any installer commands (which would fail without root privileges). Further, subiquity can load other machine profiles in case you want to test out the installer without having access to the machine. A few sample machine profiles are available in the repository at ./examples/machines and can be loaded via the MACHINE make variable:

make dryrun MACHINE=examples/machines/simple.json

Generating machine profiles

Machine profiles are generated from the probert tool. To collect a machine profile:

PYTHONPATH=probert ./probert/bin/probert --all > mymachine.json

Testing changes in KVM

To try out your changes for real, it is necessary to install them into an ISO. Rather than building one from scratch, it's much easier to install your version of subiquity into the daily image. Here's how to do this:

  1. Build your change into a snap:

    $ snapcraft snap --output subiquity_test.snap
    
  2. Grab the current version of the installer:

    $ urlbase=http://cdimage.ubuntu.com/ubuntu-server/daily-live/current
    $ isoname=$(distro-info -d)-live-server-$(dpkg --print-architecture).iso
    $ zsync ${urlbase}/${isoname}.zsync
    
  3. Run the provided script to make a copy of the downloaded installer that has your version of subiquity:

    $ sudo ./scripts/inject-subiquity-snap.sh ${isoname} subiquity_test.snap custom.iso
    
  4. Boot the new iso in KVM:

    $ qemu-img create -f raw target.img 10G
    $ kvm -m 1024 -boot d -cdrom custom.iso -hda target.img -serial stdio
    
  5. Finally, boot the installed image:

    $ kvm -m 1024 -hda target.img -serial stdio
    

The first three steps are bundled into the script ./scripts/test-this-branch.sh.