Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
450ac445e4 | |||
56b350ffd0 | |||
a6c4513867 | |||
c50715f258 | |||
77296c4527 | |||
3f419cc41e | |||
60d7ac62a5 |
@@ -12,29 +12,36 @@
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
|
||||
add_svc_rc(){
|
||||
local mnt="$1" name="$2" rlvl="$3"
|
||||
if [[ -f $mnt/etc/init.d/$name ]];then
|
||||
msg2 "Setting %s ..." "$name"
|
||||
chroot $mnt rc-update add $name $rlvl &>/dev/null
|
||||
fi
|
||||
add_svc_openrc(){
|
||||
local mnt="$1" names="$2" rlvl="${3:-default}"
|
||||
for svc in $names; do
|
||||
if [[ -f $mnt/etc/init.d/$svc ]];then
|
||||
msg2 "Setting %s ..." "$svc"
|
||||
[[ $svc == "xdm" ]] && set_xdm "$mnt"
|
||||
chroot $mnt rc-update add $svc $rlvl &>/dev/null
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
add_svc_runit(){
|
||||
local mnt="$1" name="$2"
|
||||
if [[ -d $mnt/etc/runit/sv/$name ]]; then
|
||||
msg2 "Setting %s ..." "$name"
|
||||
chroot $mnt ln -s /etc/runit/sv/$name /etc/runit/runsvdir/default &>/dev/null
|
||||
fi
|
||||
local mnt="$1" names="$2" rlvl="${3:-default}"
|
||||
for svc in $names; do
|
||||
if [[ -d $mnt/etc/runit/sv/$svc ]]; then
|
||||
msg2 "Setting %s ..." "$svc"
|
||||
chroot $mnt ln -s /etc/runit/sv/$svc /etc/runit/runsvdir/$rlvl &>/dev/null
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
add_svc_s6(){
|
||||
local mnt="$1" name="$2"
|
||||
if [[ -d $mnt/etc/s6/sv/$name ]]; then
|
||||
msg2 "Setting %s ..." "$name"
|
||||
# chroot $mnt s6-rc-bundle $name default &>/dev/null
|
||||
# chroot $mnt s6-rc -u change default &>/dev/null
|
||||
fi
|
||||
local mnt="$1" names="$2" valid="" rlvl="${3:-default}"
|
||||
for svc in $names; do
|
||||
if [[ -d $mnt/etc/s6/sv/$svc ]]; then
|
||||
msg2 "Setting %s ..." "$svc"
|
||||
valid=${valid:-}${valid:+' '}${svc}
|
||||
fi
|
||||
done
|
||||
chroot $mnt s6-rc-bundle -c /etc/s6/rc/compiled add $rlvl $valid
|
||||
}
|
||||
|
||||
set_xdm(){
|
||||
@@ -60,44 +67,14 @@ configure_logind(){
|
||||
|
||||
configure_services(){
|
||||
local mnt="$1"
|
||||
info "Configuring [%s]" "${INITSYS}"
|
||||
case ${INITSYS} in
|
||||
'openrc')
|
||||
for svc in ${SERVICES[@]}; do
|
||||
[[ $svc == "xdm" ]] && set_xdm "$mnt"
|
||||
add_svc_rc "$mnt" "$svc" "default"
|
||||
done
|
||||
for svc in ${SERVICES_LIVE[@]}; do
|
||||
add_svc_rc "$mnt" "$svc" "default"
|
||||
done
|
||||
;;
|
||||
'runit')
|
||||
for svc in ${SERVICES[@]}; do
|
||||
add_svc_runit "$mnt" "$svc"
|
||||
done
|
||||
for svc in ${SERVICES_LIVE[@]}; do
|
||||
add_svc_runit "$mnt" "$svc"
|
||||
done
|
||||
;;
|
||||
's6')
|
||||
for svc in ${SERVICES[@]}; do
|
||||
add_svc_s6 "$mnt" "$svc"
|
||||
done
|
||||
for svc in ${SERVICES_LIVE[@]}; do
|
||||
add_svc_s6 "$mnt" "$svc"
|
||||
done
|
||||
;;
|
||||
esac
|
||||
info "Done configuring [%s]" "${INITSYS}"
|
||||
info "Configuring [%s] services" "${INITSYS}"
|
||||
add_svc_${INITSYS} "$mnt" "${SERVICES[*]} ${SERVICES_LIVE[*]}"
|
||||
info "Done configuring [%s] services" "${INITSYS}"
|
||||
}
|
||||
|
||||
configure_system(){
|
||||
local mnt="$1"
|
||||
case ${INITSYS} in
|
||||
'openrc' | 'runit'|'s6')
|
||||
configure_logind "$mnt" "elogind"
|
||||
;;
|
||||
esac
|
||||
configure_logind "$mnt" "elogind"
|
||||
echo ${HOST_NAME} > $mnt/etc/hostname
|
||||
}
|
||||
|
||||
@@ -125,52 +102,33 @@ write_users_conf(){
|
||||
printf '%s' "${yaml}"
|
||||
}
|
||||
|
||||
write_servicescfg_conf(){
|
||||
write_services_conf(){
|
||||
local key1="$1" val1="$2" key2="$3" val2="$4"
|
||||
local yaml=$(write_yaml_header)
|
||||
yaml+=$(write_empty_line)
|
||||
case "${INITSYS}" in
|
||||
'runit')
|
||||
yaml+=$(write_yaml_map 0 'svDir' '/etc/runit/sv')
|
||||
yaml+=$(write_yaml_map 0 'runsvDir' '/etc/runit/runsvdir')
|
||||
yaml+=$(write_yaml_map 0 'services')
|
||||
yaml+=$(write_yaml_map 2 'enabled')
|
||||
for svc in ${SERVICES[@]};do
|
||||
yaml+=$(write_yaml_seq_map 4 'name' "$svc")
|
||||
yaml+=$(write_yaml_map 6 'runlevel' 'default')
|
||||
done
|
||||
;;
|
||||
'openrc')
|
||||
yaml+=$(write_yaml_map 0 'initdDir' '/etc/init.d')
|
||||
yaml+=$(write_yaml_map 0 'runlevelsDir' '/etc/runlevels')
|
||||
yaml+=$(write_yaml_map 0 'services')
|
||||
for svc in ${SERVICES[@]};do
|
||||
yaml+=$(write_yaml_seq_map 2 'name' "$svc")
|
||||
yaml+=$(write_yaml_map 4 'runlevel' 'default')
|
||||
done
|
||||
;;
|
||||
's6')
|
||||
yaml+=$(write_yaml_map 0 'svDir' '/etc/s6/sv')
|
||||
yaml+=$(write_yaml_map 0 'rcDir' '/etc/s6-rc')
|
||||
yaml+=$(write_yaml_map 0 'services')
|
||||
for svc in ${SERVICES[@]};do
|
||||
yaml+=$(write_yaml_seq_map 2 'name' "$svc")
|
||||
yaml+=$(write_yaml_map 4 'bundle' 'default')
|
||||
done
|
||||
;;
|
||||
esac
|
||||
yaml+=$(write_yaml_map 0 "$key1" "$val1")
|
||||
yaml+=$(write_yaml_map 0 "$key2" "$val2")
|
||||
yaml+=$(write_yaml_map 0 'services')
|
||||
for svc in ${SERVICES[@]};do
|
||||
yaml+=$(write_yaml_seq 2 "$svc")
|
||||
done
|
||||
yaml+=$(write_empty_line)
|
||||
printf '%s' "${yaml}"
|
||||
}
|
||||
|
||||
write_unpackfs_conf(){
|
||||
local yaml=$(write_yaml_header)
|
||||
yaml+=$(write_empty_line)
|
||||
yaml+=$(write_yaml_map 0 'unpack')
|
||||
yaml+=$(write_yaml_seq_map 2 'source' "/run/artix/bootmnt/artix/x86_64/rootfs.sfs")
|
||||
yaml+=$(write_yaml_map 4 'sourcefs' 'squashfs')
|
||||
yaml+=$(write_yaml_map 4 'destination' '""')
|
||||
yaml+=$(write_empty_line)
|
||||
printf '%s' "${yaml}"
|
||||
write_services_openrc_conf(){
|
||||
local mods="$1"
|
||||
write_services_conf 'initdDir' '/etc/init.d' 'runlevelsDir' '/etc/runlevels' > "$mods"/services-openrc.conf
|
||||
}
|
||||
|
||||
write_services_runit_conf(){
|
||||
local mods="$1"
|
||||
write_services_conf 'svDir' '/etc/runit/sv' 'runsvDir' '/etc/runit/runsvdir' > "$mods"/services-runit.conf
|
||||
}
|
||||
|
||||
write_services_s6_conf(){
|
||||
local mods="$1"
|
||||
write_services_conf 'svDir' '/etc/s6/sv' 'dbDir' '/etc/s6/rc/compiled' > "$mods"/services-s6.conf
|
||||
}
|
||||
|
||||
configure_calamares(){
|
||||
@@ -178,9 +136,7 @@ configure_calamares(){
|
||||
if [[ -d "$mods" ]];then
|
||||
msg2 "Configuring Calamares"
|
||||
write_users_conf > "$mods"/users.conf
|
||||
write_servicescfg_conf > "$mods"/services-"${INITSYS}".conf
|
||||
write_unpackfs_conf > "$mods"/unpackfs.conf
|
||||
sed -e "s|openrc|${INITSYS}|" -i "$mods"/postcfg.conf
|
||||
write_services_"${INITSYS}"_conf "$mods"
|
||||
sed -e "s|services-openrc|services-${INITSYS}|" -i "$1"/etc/calamares/settings.conf
|
||||
fi
|
||||
}
|
||||
|
Reference in New Issue
Block a user