#!/bin/sh
# postinst script for test-0.1
#
# see: dh_installdeb(1)

set -e

SYSTEMD_ENABLED=false
if [ -d /run/systemd/system ]; then
    SYSTEMD_ENABLED=true
fi

# summary of how this script can be called:
#        * <postinst> `configure' <most-recently-configured-version>
#        * <old-postinst> `abort-upgrade' <new version>
#        * <conflictor's-postinst> `abort-remove' `in-favour' <package>
#          <new-version>
#        * <postinst> `abort-remove'
#        * <deconfigured's-postinst> `abort-deconfigure' `in-favour'
#          <failed-install-package> <version> `removing'
#          <conflicting-package> <version>
# for details, see http://www.debian.org/doc/debian-policy/ or
# the debian-policy package

case "$1" in
    configure)

    CURRENT_ENV=$(cat "/etc/yandex/environment.type")

    echo "Running yav-deploy."
    yav-deploy --force \
        -c /etc/yandex/yav-deploy/pkg/yandex-passport-logstoreapi/ \
        || true

    ## common
    chown -R www-data: /etc/yandex/passport-logstoreapi
    chown -R www-data: /storage/logs
    chown -R www-data: /var/log/yandex/passport-logstoreapi

    ## xunistater
    echo "Restarting xunistater."
    if $SYSTEMD_ENABLED; then
        if ! systemctl is-enabled yandex-passport-xunistater@logstoreapi > /dev/null; then
            systemctl enable yandex-passport-xunistater@logstoreapi || true
        fi
        deb-systemd-invoke restart yandex-passport-xunistater@logstoreapi || true
    else
        update-rc.d yandex-passport-xunistater defaults || true
        invoke-rc.d yandex-passport-xunistater restart || true
    fi

    ## nginx
    echo "Generating nginx config."
    python3 /etc/yandex/passport-logstoreapi/prepare_nginx.py \
        "/etc/yandex/passport-logstoreapi/template_nginx.txt" \
        "$CURRENT_ENV" \
        "$(hostname -f)" > /etc/nginx/sites-enabled/logstoreapi.conf

    echo "Reloading nginx."
    if $SYSTEMD_ENABLED; then
        systemctl reload nginx || true
    else
        service nginx reload || true
    fi

    ## cfg
    echo "Generating config."
    python3 /etc/yandex/passport-logstoreapi/prepare.py \
        "/etc/yandex/passport-logstoreapi/template.json" \
        "$CURRENT_ENV" > /etc/yandex/passport-logstoreapi/logstoreapi.conf

    ## monrun
    echo "Restarting monrun."
    regenerate-monrun-tasks
    service juggler-client restart

    ## yasm
    echo "Restarting yasmagent."
    YENV_PROJECT="passport.logstoreapi" /usr/share/passport-admin-config-golovan/passport_golovan_config.py \
        --itype="passportlogstoreapi2" > \
        /etc/yandex/yasmagent/instances.d/passport.logstoreapi.instance
    YENV_PROJECT="passport.logstoreapi" /usr/share/passport-admin-config-golovan/passport_golovan_config.py \
        --itype="common" >> \
        /etc/yandex/yasmagent/instances.d/passport.logstoreapi.instance
    invoke-rc.d yasmagent restart || /bin/true

    ## logstoreapi
    if $SYSTEMD_ENABLED; then
        echo "Updating sysmtemctl."
        if ! systemctl is-enabled yandex-passport-logstoreapi >/dev/null; then
            systemctl enable yandex-passport-logstoreapi || true
        fi
        systemctl --system daemon-reload || true
    fi

    echo "Restarting API."
    service yandex-passport-logstoreapi restart

    ;;

    abort-upgrade|abort-remove|abort-deconfigure)
    ;;

    *)
        echo "postinst called with unknown argument \`$1'" >&2
        exit 1
    ;;
esac

# dh_installdeb will replace this with shell code automatically
# generated by other debhelper scripts.

#DEBHELPER#

exit 0
