#!@BINDIR@/bash
# Copyright (c) 2015-2021 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution.
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.

sourcing(){

    local list

    for list in /tmp/obarun-install-tmp/install.conf /usr/lib/obarun/util.sh; do
        if [[ -f "${list}" ]]; then
            source "${list}"
        else
            oblog -f "Missing file : ${list}"
            exit
        fi
    done

    unset list
}
sourcing

custo_once() {
    local _tmp cmd
    cmd="${1}"
    _tmp="/tmp/obarun-install-tmp"

    if [[ ! -d $_tmp ]]; then
        mkdir -p -m0755 $_tmp || die "Impossible to create $_tmp"
    fi
    if [[ ! -e $_tmp/customize.${cmd} ]]; then
        "${cmd}" || die "Cannot execute $_"
        touch $_tmp/customize.${cmd}
    else
        return
    fi
    unset _tmp
}

############################## only modifie this script after this line ############################

check_tree(){

    local tree="${1}"

    if ! [[ -d /var/lib/66/system/"${tree}" ]]; then
        return 1 ;
    else
        oblog "Tree ${tree} already exists"
        return 0 ;
    fi

}

create_log_user(){
    oblog "add ${NEWUSER} at log group"
    gpasswd -a "$NEWUSER" log
}

config_tree_boot(){

    if ! check_tree "boot"; then

        oblog "Create tree boot"

        66-tree -zv3 -n boot || die "unable to create boot tree"
    fi
}

config_enable_boot(){

    oblog "Enable boot@system service at tree boot"

    66-enable -zv3 -t boot -F boot@system || die "unable to enable boot@system"

    # By default the configuration file is prefixed with a dot.
    # 66-env -r do not know about it, so copy it without the prefix
    BOOT_CONF="$(readlink /etc/66/conf/boot@system/version)"

    cp "${BOOT_CONF}/.boot@system" "${BOOT_CONF}/boot@system" || die "unable to cp boot@system configuration file"

    oblog "Configure boot@system service"

    66-env -t boot -r "HOSTNAME=!${HOSTNAME}" -r "KEYMAP=!${KEYMAP}" -r "TZ=${ZONE}/${SUBZONE}" boot@system || die "unable to configure boot@system service"

    oblog "Apply change to the boot@system service"

    66-enable -zv3 -t boot -F boot@system || die "unable to apply boot changes"
}

config_tree_root(){

    if ! check_tree "root"; then

        oblog "Create tree root and enable it"

        66-tree -zv3 -cnE root || die "unable to create root tree"
    fi
}

config_enable_root(){

    oblog "Enable consolekit, dbus, openntpd, connmand and wpa_supplicant on tree root"

    66-enable -zv3 consolekit dbus openntpd connmand wpa_supplicant || die "unable to enable dbus openntpd connmand wpa_supplicant"
}

config_tree_boot_user(){

    if ! check_tree "boot-user"; then

        oblog "Create boot-user tree"

        66-tree -zv3 -En boot-user || die "unable to create boot-user tree"
    fi
}

config_enable_boot_user(){

    oblog "Enable boot-user@${NEWUSER} at boot-user tree"

    66-enable -zv3 -t boot-user -F boot-user@${NEWUSER} || die "unable to enable boot-user@${NEWUSER} service"
}

config_tree_base_user(){

    oblog "Create base tree for ${NEWUSER}, enables and makes it current"

    su "${NEWUSER}" -c "if ! s6-test -d /home/${NEWUSER}/.66/system/base; then \
                            66-tree -zv3 -Ecn base ; \
                        fi" || die "unable to create base tree"
}

config_enable_base_user(){

    oblog "Enable xdg-user-dirs, dbus-session@${NEWUSER} on base tree"

    su "${NEWUSER}" -c "66-enable -zv3 xdg-user-dirs dbus-session@${NEWUSER}" || die "unable to enable xdg-user-dirs dbus-session@${NEWUSER} service"
}

custo_once create_log_user
custo_once config_tree_boot
custo_once config_enable_boot
custo_once config_tree_root
custo_once config_enable_root
custo_once config_tree_boot_user
custo_once config_enable_boot_user
custo_once config_tree_base_user
custo_once config_enable_base_user

oblog "Customization terminate"