2020-10-23 20:13:52 +00:00
=======
profile
=======
An archiso profile consists of several configuration files and a directory for files to be added to the resulting image.
2021-03-22 13:40:34 +00:00
.. code :: plaintext
2020-10-28 20:57:15 +00:00
2021-03-22 13:40:34 +00:00
profile/
├── airootfs/
├── efiboot/
├── syslinux/
2022-05-25 14:49:02 +00:00
├── grub/
2021-05-02 18:32:24 +00:00
├── bootstrap_packages.arch
2021-03-22 13:40:34 +00:00
├── packages.arch
├── pacman.conf
└── profiledef.sh
2020-10-28 20:57:15 +00:00
The required files and directories are explained in the following sections.
profiledef.sh
=============
This file describes several attributes of the resulting image and is a place for customization to the general behavior
of the image.
2021-03-22 13:40:34 +00:00
The image file is constructed from some of the variables in `` profiledef.sh `` : `` <iso_name>-<iso_version>-<arch>.iso ``
(e.g. `` archlinux-202010-x86_64.iso `` ).
* `` iso_name `` : The first part of the name of the resulting image (defaults to `` mkarchiso `` )
* `` iso_label `` : The ISO's volume label (defaults to `` MKARCHISO `` )
* `` iso_publisher `` : A free-form string that states the publisher of the resulting image (defaults to `` mkarchiso `` )
* `` iso_application `` : A free-form string that states the application (i.e. its use-case) of the resulting image (defaults
to `` mkarchiso iso `` )
* `` iso_version `` : A string that states the version of the resulting image (defaults to `` "" `` )
* `` install_dir `` : A string (maximum eight characters long, which **must** consist of `` [a-z0-9] `` ) that states the
directory on the resulting image into which all files will be installed (defaults to `` mkarchiso `` )
2021-05-02 18:32:24 +00:00
* `` buildmodes `` : An optional list of strings, that state the build modes that the profile uses. Only the following are
understood:
- `` bootstrap `` : Build a compressed file containing a minimal system to bootstrap from
- `` iso `` : Build a bootable ISO image (implicit default, if no `` buildmodes `` are set)
2021-05-09 21:01:43 +00:00
- `` netboot `` : Build artifacts required for netboot using iPXE
2021-03-22 13:40:34 +00:00
* `` bootmodes `` : A list of strings, that state the supported boot modes of the resulting image. Only the following are
2020-10-28 20:57:15 +00:00
understood:
2020-11-01 13:39:27 +00:00
2021-03-22 13:40:34 +00:00
- `` bios.syslinux.mbr `` : Syslinux for x86 BIOS booting from a disk
- `` bios.syslinux.eltorito `` : Syslinux for x86 BIOS booting from an optical disc
2022-05-25 14:49:02 +00:00
- `` uefi-ia32.grub.esp `` : GRUB for IA32 UEFI booting from a disk
- `` uefi-ia32.grub.eltorito `` : GRUB for IA32 UEFI booting from an optical disc
2023-09-11 15:35:08 +00:00
- `` uefi-x64.grub.esp `` : GRUB for x64 UEFI booting from a disk
- `` uefi-x64.grub.eltorito `` : GRUB for x64 UEFI booting from an optical disc
- `` uefi-ia32.systemd-boot.esp `` : systemd-boot for IA32 UEFI booting from a disk
- `` uefi-ia32.systemd-boot.eltorito `` : systemd-boot for IA32UEFI booting from an optical disc
- `` uefi-x64.systemd-boot.esp `` : systemd-boot for x64 UEFI booting from a disk
- `` uefi-x64.systemd-boot.eltorito `` : systemd-boot for x64 UEFI booting from an optical disc
2021-05-02 18:32:24 +00:00
Note that BIOS El Torito boot mode must always be listed before UEFI El Torito boot mode.
2021-03-22 13:40:34 +00:00
* `` arch `` : The architecture (e.g. `` x86_64 `` ) to build the image for. This is also used to resolve the name of the packages
file (e.g. `` packages.x86_64 `` )
* `` pacman_conf `` : The `` pacman.conf `` to use to install packages to the work directory when creating the image (defaults to
the host's `` /etc/pacman.conf `` )
* `` airootfs_image_type `` : The image type to create. The following options are understood (defaults to `` squashfs `` ):
- `` squashfs `` : Create a squashfs image directly from the airootfs work directory
- `` ext4+squashfs `` : Create an ext4 partition, copy the airootfs work directory to it and create a squashfs image from it
- `` erofs `` : Create an EROFS image for the airootfs work directory
* `` airootfs_image_tool_options `` : An array of options to pass to the tool to create the airootfs image. `` mksquashfs `` and
`` mkfs.erofs `` are supported. See `` mksquashfs --help `` or `` mkfs.erofs --help `` for all possible options
* `` file_permissions `` : An associative array that lists files and/or directories who need specific ownership or
2020-11-14 09:43:13 +00:00
permissions. The array's keys contain the path and the value is a colon separated list of owner UID, owner GID and
2021-03-22 13:40:34 +00:00
access mode. E.g. `` file_permissions=(["/etc/shadow"]="0:0:400") `` . When directories are listed with a trailing backslash (`` / `` ) **all** files and directories contained within the listed directory will have the same owner UID, owner GID, and access mode applied recursively.
2020-10-28 20:57:15 +00:00
2021-05-02 18:32:24 +00:00
bootstrap_packages.arch
=======================
All packages to be installed into the environment of a bootstrap image have to be listed in an architecture specific
file (e.g. `` bootstrap_packages.x86_64 `` ), which resides top-level in the profile.
Packages have to be listed one per line. Lines starting with a `` # `` and blank lines are ignored.
This file is required when generating bootstrap images using the `` bootstrap `` build mode.
2020-10-28 20:57:15 +00:00
packages.arch
=============
2021-05-02 18:32:24 +00:00
All packages to be installed into the environment of an ISO image have to be listed in an architecture specific file
(e.g. `` packages.x86_64 `` ), which resides top-level in the profile.
2020-10-28 20:57:15 +00:00
2021-05-02 18:32:24 +00:00
Packages have to be listed one per line. Lines starting with a `` # `` and blank lines are ignored.
2020-10-28 20:57:15 +00:00
.. note ::
The **mkinitcpio** and **mkinitcpio-archiso** packages are mandatory (see `#30
<https://gitlab.archlinux.org/archlinux/archiso/-/issues/30>`_).
2021-05-09 21:01:43 +00:00
This file is required when generating ISO images using the `` iso `` or `` netboot `` build modes.
2021-05-02 18:32:24 +00:00
2020-10-23 20:13:52 +00:00
pacman.conf
===========
A configuration for pacman is required per profile.
Some configuration options will not be used or will be modified:
2021-03-22 13:40:34 +00:00
* `` CacheDir `` : the profile's option is **only** used if it is not the default (i.e. `` /var/cache/pacman/pkg `` ) and if it is
2020-10-23 20:13:52 +00:00
not the same as the system's option. In all other cases the system's pacman cache is used.
2021-03-22 13:40:34 +00:00
* `` HookDir `` : it is **always** set to the `` /etc/pacman.d/hooks `` directory in the work directory's airootfs to allow
2020-10-28 20:57:15 +00:00
modification via the profile and ensure interoparability with hosts using dracut (see `#73
<https://gitlab.archlinux.org/archlinux/archiso/-/issues/73>`_)
2021-03-22 13:40:34 +00:00
* `` RootDir `` : it is **always** removed, as setting it explicitely otherwise refers to the host's root filesystem (see
`` man 8 pacman `` for further information on the `` -r `` option used by `` pacstrap `` )
* `` LogFile `` : it is **always** removed, as setting it explicitely otherwise refers to the host's pacman log file (see
`` man 8 pacman `` for further information on the `` -r `` option used by `` pacstrap `` )
* `` DBPath `` : it is **always** removed, as setting it explicitely otherwise refers to the host's pacman database (see
`` man 8 pacman `` for further information on the `` -r `` option used by `` pacstrap `` )
2020-10-28 20:57:15 +00:00
airootfs
========
2021-03-22 13:40:34 +00:00
This optional directory may contain files and directories that will be copied to the work directory of the resulting
2020-10-28 20:57:15 +00:00
image's root filesystem.
The files are copied before packages are being installed to work directory location.
2021-03-22 13:40:34 +00:00
Ownership and permissions of files and directories from the profile's `` airootfs `` directory are not preserved. The mode
will be `` 644 `` for files and `` 755 `` for directories, all of them will be owned by root. To set custom ownership and/or
permissions, use `` file_permissions `` in `` profiledef.sh `` .
2020-10-28 20:57:15 +00:00
With this overlay structure it is possible to e.g. create users and set passwords for them, by providing
2021-03-22 13:40:34 +00:00
`` airootfs/etc/passwd `` , `` airootfs/etc/shadow `` , `` airootfs/etc/gshadow `` (see `` man 5 passwd `` , `` man 5 shadow `` and `` man 5 gshadow `` respectively).
If user home directories exist in the profile's `` airootfs `` , their ownership and (and top-level) permissions will be
2020-10-28 20:57:15 +00:00
altered according to the provided information in the password file.
Boot loader configuration
=========================
A profile may contain configuration for several boot loaders. These reside in specific top-level directories, which are
explained in the following subsections.
The following *custom template identifiers* are understood and will be replaced according to the assignments of the
2021-03-22 13:40:34 +00:00
respective variables in `` profiledef.sh `` :
2020-10-28 20:57:15 +00:00
2021-03-22 13:40:34 +00:00
* `` %ARCHISO_LABEL% `` : Set this using the `` iso_label `` variable in `` profiledef.sh `` .
2022-12-22 20:58:49 +00:00
* `` %INSTALL_DIR% `` : Set this using the `` install_dir `` variable in `` profiledef.sh `` .
2021-03-22 13:40:34 +00:00
* `` %ARCH% `` : Set this using the `` arch `` variable in `` profiledef.sh `` .
2020-10-28 20:57:15 +00:00
2023-03-19 11:34:54 +00:00
Additionally there are also *custom template identifiers* have harcoded values set by `` mkarchiso `` that cannot be
overridden:
* `` %ARCHISO_UUID% `` : the ISO 9660 modification date in UTC, i.e. its "UUID",
* `` %ARCHISO_SEARCH_FILENAME% `` : file path on ISO 9660 that can be used by GRUB to find the ISO volume
(**for GRUB ``.cfg`` files only** ).
2020-10-28 20:57:15 +00:00
efiboot
-------
2021-03-22 13:40:34 +00:00
This directory is mandatory when the `` uefi-x64.systemd-boot.esp `` or `` uefi-x64.systemd-boot.eltorito `` bootmodes are
selected in `` profiledef.sh `` . It contains configuration for `systemd-boot
2020-10-28 20:57:15 +00:00
<https://www.freedesktop.org/wiki/Software/systemd/systemd-boot/> `_.
.. note ::
The directory is a top-level representation of the systemd-boot configuration directories and files found in the
root of an EFI system partition.
The *custom template identifiers* are **only** understood in the boot loader entry `.conf` files (i.e. **not** in
2021-03-22 13:40:34 +00:00
`` loader.conf `` ).
2020-10-28 20:57:15 +00:00
syslinux
--------
2021-03-22 13:40:34 +00:00
This directory is mandatory when the `` bios.syslinux.mbr `` or the `` bios.syslinux.eltorito `` bootmodes are selected in
`` profiledef.sh `` .
2020-11-17 12:10:21 +00:00
It contains configuration files for `syslinux <https://wiki.syslinux.org/wiki/index.php?title=SYSLINUX> `_ or `isolinux
<https://wiki.syslinux.org/wiki/index.php?title=ISOLINUX> `_ , or ` pxelinux
2022-05-25 14:49:02 +00:00
<https://wiki.syslinux.org/wiki/index.php?title=PXELINUX> `_ used in the resulting image.
2020-10-28 20:57:15 +00:00
The *custom template identifiers* are understood in all `.cfg` files in this directory.
2022-05-25 14:49:02 +00:00
grub
----
2022-06-10 05:38:18 +00:00
This directory is mandatory when any of the following bootmodes is used in `` profiledef.sh `` :
- `` uefi-ia32.grub.esp `` or
- `` uefi-ia32.grub.eltorito `` or
- `` uefi-x64.grub.esp `` or
- `` uefi-x64.grub.eltorito ``
2022-05-25 14:49:02 +00:00
It contains configuration files for `GRUB <https://www.gnu.org/software/grub/> `_
used in the resulting image.