endef
endif
+fstype := ext4
+
ifdef disk
VOLUME := ${disk}
PBOOT := ${disk}1
deb http://archive.raspberrypi.org/debian ${release} main
endef
- PACKAGES += firmware-brcm80211 libraspberrypi-bin libraspberrypi0 pi-bluetooth raspberrypi-bootloader raspberrypi-kernel
+ PACKAGES += firmware-brcm80211 libraspberrypi-bin libraspberrypi0 pi-bluetooth raspberrypi-bootloader raspberrypi-kernel initramfs-tools nilfs-tools
+ fstype := nilfs2
_target: _umount _config
_config: ${CFGROOT}
ln -sf /dev/null "$${CFGROOT}/etc/systemd/network/99-default.link"
printf '\nsession optional pam_mkhomedir.so umask=0027\n' >>"$${CFGROOT}/etc/pam.d/common-session"
- printf 'LABEL=FSROOT / ext4 auto,nofail,rw 0 0\nLABEL=BOOT /boot vfat auto,nofail,ro 0 0\n' \
+ printf 'LABEL=FSROOT / ${fstype} auto,nofail,rw 0 0\nLABEL=BOOT /boot vfat auto,nofail,ro 0 0\n' \
>"$${CFGROOT}/etc/fstab"
chroot "$${CFGROOT}" update-initramfs -u
-${SQUASH}: ${CFGROOT} .FORCE
+${SQUASH}: ${CFGROOT}
-rm "$${SQUASH}"
mksquashfs "$${CFGROOT}" "$${SQUASH}" -comp xz
_isosquash: ${ISOROOT}/live/live.squashfs
${ISOROOT}/live/live.squashfs: ${CFGROOT} ${ISOROOT} .FORCE
-rm "$@"
- printf '%s\n' boot |mksquashfs "$${CFGROOT}" "$@" -comp xz -ef /dev/stdin
+ { cd "$${CFGROOT}"; printf '%s\n' boot/*; } \
+ | mksquashfs "$${CFGROOT}" "$@" -comp xz -ef /dev/stdin
${VOLUME}: .FORCE
! printf '%s\n' "$${VOLUME}" |grep -q '^/dev/' # abort if volume should be real device
_sparse: ${PBOOT} ${PROOT}
+ifdef raspi
+_format_root: ${PROOT}
+ -umount "$${CFGROOT}/boot" "$${CFGROOT}" "${PROOT}"
+ mkfs.nilfs2 -f -L FSROOT "$${PROOT}"
+else
_format_root: ${PROOT}
-umount "$${CFGROOT}/boot" "$${CFGROOT}" "${PROOT}"
mkfs.ext4 -F -L FSROOT "$${PROOT}"
+endif
_format_boot: ${PBOOT}
-umount "$${CFGROOT}/boot" "${PBOOT}"
_format: _format_root _format_boot
-_iso_image: ${ISOROOT} # _efi_iso _efi_umount
- xorriso -as mkisofs -o "$${ISO}" -isohybrid-mbr /usr/lib/ISOLINUX/isohdpfx.bin \
- -b isolinux.bin -c boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table \
- "$${ISOROOT}"
- # -eltorito-alt-boot -e efi.img -no-emul-boot -isohybrid-gpt-basdat \
+_iso_image: ${ISOROOT}
+ grub-mkrescue -o "$${ISO}" "$${ISOROOT}"
.PHONY: _syslinux_efi32 _syslinux_efi64 _syslinux_bios
.PHONY: _grub_efi32 _grub_efi64
grub-mkimage -p / -O x86_64-efi fat part_gpt normal linux all_video >"$${CFGROOT}/boot/EFI/BOOT/BOOTX64.EFI"
${CFGROOT}/boot/cmdline.txt: ${CFGROOT}
- printf 'root=/dev/mmcblk0p2 rootfstype=ext4 fsck.repair=yes rootwait' >"$@"
+ printf 'root=/dev/mmcblk0p2 rootfstype=${fstype} fsck.repair=yes rootwait' >"$@"
_bootloader_raspi: ${CFGROOT} ${CFGROOT}/boot/cmdline.txt
"$$k" "$$i" >>"$${CFGROOT}/boot/grub.cfg"
_bootloader_iso: ${CFGROOT} ${ISOROOT}
- # grub-mkimage -p / -O i386-pc-eltorito biosdisk iso9660 normal linux all_video >"$${ISOROOT}/grub.bin"
+ mkdir -p "$${ISOROOT}/boot/grub/"
cp -L "$${CFGROOT}/vmlinuz" "$${CFGROOT}/initrd.img" "$${ISOROOT}"
- cp /usr/lib/ISOLINUX/isolinux.bin $(addprefix /usr/lib/syslinux/modules/bios/, ldlinux.c32 menu.c32 libutil.c32) "$${ISOROOT}"
- # printf '%s\n' "set timeout=10" "default=buster" \
- # "menuentry 'Debian Buster' --id 'buster' {" \
- # "linux '/vmlinuz' boot=live" "initrd '/initrd.img'" "}" \
- # >"$${ISOROOT}/grub.cfg"
- printf '%s\n' "UI menu.c32" "DEFAULT buster" "TIMEOUT 100" \
- "LABEL buster" " MENU LABEL Debian Buster 64bit" \
- " KERNEL /vmlinuz" " APPEND initrd=/initrd.img boot=live" \
- >"$${ISOROOT}/syslinux.cfg"
+ printf '%s\n' "set timeout=10" "default=buster" \
+ "menuentry 'Debian Buster' --id 'buster' {" \
+ "linux '/vmlinuz' boot=live" "initrd '/initrd.img'" "}" \
+ >"$${ISOROOT}/boot/grub/grub.cfg"
+ -[ -f "$${ISOROOT}/install/initrd.gz" -a -f "$${ISOROOT}/install/linux" ] && \
+ printf '%s\n' "menuentry 'Install Debian' --id 'install' {" \
+ "linux '/install/linux'" "initrd '/install/initrd.gz'" "}" \
+ >>"$${ISOROOT}/boot/grub/grub.cfg"
_efi_mount: ${PBOOT}
-umount "efi/"
_efi_umount: _efi_mount
umount efi/ && rmdir efi/
-_efi_iso: _efi_mount _grub_efi32 _grub_efi64
- cp -r "$${CFGROOT}/boot/EFI/." "efi/EFI/"
-
.PHONY: _syslinux_mbr _grub_mbr
_syslinux_mbr: ${VOLUME}
dd conv=notrunc,sparse bs=1M seek=$$((2 + ${BOOT_MB})) if="$${PROOT}" of="$${VOLUME}"
_mount_root: ${PROOT} ${CFGROOT}
- mount -t ext4 "$${PROOT}" "$${CFGROOT}"
+ mountpoint "$${CFGROOT}" \
+ || mount -t ${fstype} "$${PROOT}" "$${CFGROOT}"
chmod 755 "$${CFGROOT}"
_mount_boot: ${PBOOT}
mkdir -p -m 755 "$${CFGROOT}/boot"
- mount -t vfat "$${PBOOT}" "$${CFGROOT}/boot"
+ mountpoint "$${CFGROOT}/boot" \
+ || mount -t vfat "$${PBOOT}" "$${CFGROOT}/boot"
ifdef disk
_mount_boot: _mount_root
_mount: _mount_root _mount_boot
-_img_mount:
- mount -o loop,offset="$$((${BOOT_MB} + 2))"M,sizelimit=${ROOT_MB}M \
- -t ext4 "$${VOLUME}" "$${CFGROOT}"
+_img_mount: ${CFGROOT}
+ mountpoint "$${CFGROOT}" \
+ || mount -o loop,offset="$$((${BOOT_MB} + 2))"M,sizelimit=${ROOT_MB}M \
+ -t ${fstype} "$${VOLUME}" "$${CFGROOT}"
chmod 755 "$${CFGROOT}"
mkdir -p -m 755 "$${CFGROOT}/boot"
- mount -o loop,offset=2M,sizelimit=${BOOT_MB}M \
- -t vfat "$${VOLUME}" "$${CFGROOT}/boot"
+ mountpoint "$${CFGROOT}/boot" \
+ || mount -o loop,offset=2M,sizelimit=${BOOT_MB}M \
+ -t vfat "$${VOLUME}" "$${CFGROOT}/boot"
_umount_boot: ${CFGROOT}
-umount "$${CFGROOT}/boot"
## Comma separated list of locales, first one will become default locale
# locales=de_DE.UTF-8,en_US.UTF-8
+## Keyboard as used in debconfs keyboard-configuration/variant
+## Use debconf-get-selections to find out the exact string
+# keyboard=German
+
## If nodm is installed, you can choose a user to login automatically
## If no user is given here, then nodm will default to root
# nodm_user=adam
## In nodm, use full screen chromium web browser as session
# webui=http://localhost/
-## When using NIS modules the directory server should be given
+## When using NIS modules the directory server and NIS domain should be given
# nis_server=nismaster
+# nis_domain=example.com
+
+## also when using SMB the main server must be given
+# smb_server=smbmaster
## If the approxmodule is enabled, then one (and only one) apt-source
## can be choosen to install packages from
endef
export approx_original_sources
+ifndef approxhost
+ approxhost := localhost
+endif
+
ifdef approx
BOOTSTRAP := ${approx}
define SOURCES =
else ifdef raspi
BOOTSTRAP := http://localhost/raspbian
define SOURCES :=
- deb http://localhost/raspbian stretch main non-free firmware rpi
- deb http://localhost/rpidebian stretch main
- deb http://localhost/raspbian buster main non-free firmware rpi
- deb http://localhost/rpidebian buster main
+ deb http://${approxhost}/raspbian stretch main non-free firmware rpi
+ deb http://${approxhost}/rpidebian stretch main
+ deb http://${approxhost}/raspbian buster main non-free firmware rpi
+ deb http://${approxhost}/rpidebian buster main
endef
else
BOOTSTRAP := http://localhost/debian
define SOURCES :=
- deb http://localhost/debian ${release} main
+ deb http://${approxhost}/debian ${release} main
endef
endif
#!/bin/sh
rootfs="$$(mount |grep -w / |cut -d' ' -f1)"
+roottype="$$(mount |grep -w / |cut -d' ' -f5)"
case $$rootfs in
/dev/mmcblk?p2) rootdev="$${rootfs%p2}";;
if [ "$$before" = "$$after" ]; then
# second stage
- resize2fs "$$rootfs"
+ case $$roottype in
+ ext[234]) resize2fs "$$rootfs";;
+ btrfs) btrfs filesystem resize max /;;
+ nilfs2) nilfs-resize "$$rootfs";;
+ esac
systemctl disable autoresize
else
# finish first stage
define autoresize_unit :=
[Unit]
-Description=Resize root filesystem at boot
+Description=Resize root filesystem during first boot
[Service]
ExecStart=/opt/autoresize.sh
dtoverlay=vc4-fkms-v3d,cma-256
endef
-.PHONY: _debconf_selections _raspberry_config
+.PHONY: _debconf_selections _raspberry_config _keyboard
_install: _debconf_selections
_debconf_selections: ${SYSROOT}
printf '%s\n' "$${DEBCONF}" |chroot "$${SYSROOT}" debconf-set-selections
+ifdef keyboard
+ _config: _keyboard
+endif
+_keyboard: ${CFGROOT}
+ -sed -Ei 's;^XKBLAYOUT=.*$$;XKBLAYOUT="${keyboard}";;' "$${CFGROOT}/etc/default/keyboard"
+
ifdef raspi
- _config: _raspberry_config
+ _config: _raspberry_config _raspberry_initrd
endif
+
_raspberry_config: ${CFGROOT}
printf '%s\n' "$${RPICONFIG}" >>"$${CFGROOT}/boot/config.txt"
+_raspberry_initrd: ${CFGROOT}
+ printf 'nilfs2\n' >>"$${CFGROOT}/etc/initramfs-tools/modules"
+ k="$$(echo "$${CFGROOT}"/lib/modules/*-v7+)"; \
+ chroot $${CFGROOT} update-initramfs -c -k "$${k##*/}"; \
+ printf 'initramfs initrd.img-%s\n' "$${k##*/}" >>"$${CFGROOT}/boot/config.txt"
+
.PHONY: _timezone _locales
ifdef timezone
_hostname: ${CFGROOT}
printf '%s\n' "$${hostname}" >"$${CFGROOT}/etc/hostname"
+ sed -Ei "s;^127\.0\.0\.1.*$$;& $${hostname};" "$${CFGROOT}/etc/hosts"
ifdef wifi
_config: ${CFGROOT}/etc/network/interfaces.d/wifi
.PHONY: _nodm_user _nodm_cfg
_nodm_cfg: ${CFGROOT}
+ sed -Ei 's;^TimeoutStopSec=.*$$;TimeoutStopSec=1;' "$${CFGROOT}/lib/systemd/system/nodm.service"
rm "$${CFGROOT}/etc/default/nodm"
chroot "$${CFGROOT}" dpkg-reconfigure --default-priority -u nodm
${CFGROOT}/srv/gummikraken: gummikraken/ ${CFGROOT}
cp -au "$</." "$@"
+ sed -i 's;http://141.45.146.235:8200;http://oktopus:8200;' "$@/oktopus_frontend/dist/bundle.js"
.PHONY: gummikraken_clone
gummikraken_clone:
-PACKAGES += cifs-utils libpam-mount libpam-script lxdm nis nscd samba-common-bin usermode
+PACKAGES += cifs-utils libpam-mount libpam-script lightdm nis nscd samba-common-bin usermode
ifndef nis_server
nis_server := nismaster
endif
+ifndef nis_domain
+ nis_domain := ${nis_server}
+endif
+ifndef smb_server
+ smb_server := ${nis_server}
+endif
define DEBCONF +=
-nis nis/domain string .${nis_server}
+nis nis/domain string ${nis_domain}
endef
export smb_nis_pamscript smb_nis_pammount
define smb_nis_pamscript :=
#!/bin/sh
+# forced through bash, to hide euid from smbpasswd
/bin/bash -c '
printf "%s\n" "$$PAM_OLDAUTHTOK" "$$PAM_AUTHTOK" "$$PAM_AUTHTOK" \
- | smbpasswd -sr ${nis_server} -U "$$PAM_USER"
+ | smbpasswd -sr ${smb_server} -U "$$PAM_USER"
'
exit $?
define smb_nis_pammount :=
<pam_mount> <debug enable="0" />
<!-- Volume definitions -->
- <volume options="user=%(USER)" fstype="cifs" server="${nis_server}" path="%(USER)" mountpoint="~" />
+ <volume options="user=%(USER)" fstype="cifs" server="${smb_server}" path="%(USER)" mountpoint="~" />
<mntoptions require="nosuid,nodev" />
<logout wait="0" hup="no" term="no" kill="no" />
<mkmountpoint enable="1" remove="true" />
_smb_nis: ${CFGROOT}/etc/yp.conf ${CFGROOT}/etc/defaultdomain
_smb_nis: ${CFGROOT}
- sed -Ei 's;^(passwd:|group:|shadow:|gshadow:) *;\1 nis ;' $${CFGROOT}/etc/nsswitch.conf
+ sed -Ei 's;^(passwd:|group:|shadow:|gshadow:).*$$;\1 files nis;' $${CFGROOT}/etc/nsswitch.conf
+ sed -Ei '/pam_(script|mount).so/d' $${CFGROOT}/etc/pam.d/common-*
printf '\nauth optional pam_mount.so\n' >>$${CFGROOT}/etc/pam.d/common-auth
printf '\nsession optional pam_mount.so\n' >>$${CFGROOT}/etc/pam.d/common-session
printf '\npassword required pam_script.so dir=/opt/pam_script\n' >$${CFGROOT}/etc/pam.d/common-password
-${CFGROOT}/opt/pam_script/pam_script_passwd: ${CFGROOT}
+${CFGROOT}/opt/pam_script/pam_script_passwd: ${CFGROOT} .FORCE
mkdir -p "$(dir $@)"
printf '%s' "$${smb_nis_pamscript}" >"$@"
-${CFGROOT}/etc/security/pam_mount.conf.xml: ${CFGROOT}
+${CFGROOT}/etc/security/pam_mount.conf.xml: ${CFGROOT} .FORCE
mkdir -p "$(dir $@)"
printf '%s' "$${smb_nis_pammount}" >"$@"
-${CFGROOT}/etc/yp.conf: ${CFGROOT}
+${CFGROOT}/etc/yp.conf: ${CFGROOT} .FORCE
printf 'ypserver %s\n' "${nis_server}" >"$@"
-${CFGROOT}/etc/defaultdomain: ${CFGROOT}
- printf '.%s\n' "${nis_server}" >"$@"
+${CFGROOT}/etc/defaultdomain: ${CFGROOT} .FORCE
+ printf '%s\n' "${nis_domain}" >"$@"
--- /dev/null
+[settings]
+gtk-print-preview-command = okular %f