# For using the alias import-office-tables, # copy these exports to .environment (ignored by git) 
# and amend them according to your external DB:
export HSADMINNG_POSTGRES_JDBC_URL=jdbc:tc:postgresql:15.5-bookworm:///spring_boot_testcontainers
export HSADMINNG_POSTGRES_ADMIN_USERNAME=admin
export HSADMINNG_POSTGRES_ADMIN_PASSWORD=
export HSADMINNG_POSTGRES_RESTRICTED_USERNAME=restricted

gradleWrapper () {
    if [ ! -f gradlew ]; then
        echo "No 'gradlew' found. Maybe you are not in the root dir of a gradle project?"
        return 1
    fi

    TEMPFILE=$(mktemp /tmp/gw.XXXXXX)
    unbuffer ./gradlew "$@" | tee $TEMPFILE

    echo
    grep --color=never "Report:" $TEMPFILE
    rm $TEMPFILE
}

postgresAutodoc () {
	if ! [ -x "$(command -v postgresql_autodoc)" ]; then
        echo "Program 'postgresql_autodoc' not found. Please install, e.g. via: sudo apt install postgresql-autodoc" >&2
		echo "See also https://github.com/cbbrowne/autodoc" >&2
        return 1
    fi

	if ! [ -x "$(command -v dot)" ]; then
        echo "Program 'graphviz dot' not found. Please install, e.g. via: sudo apt install graphviz" >&2
		echo "See also https://graphviz.org" >&2
        return 1
    fi
	postgresql_autodoc -d postgres -f build/postgres-autodoc -h localhost -u postgres --password=password \
		-m '(rbacobject|hs).*' \
		-l /usr/share/postgresql-autodoc -t neato && 
	dot -Tsvg build/postgres-autodoc.neato >build/postgres-autodoc-hs.svg && \
	echo "generated: $PWD/build/postgres-autodoc-hs.svg"

	postgresql_autodoc -d postgres -f build/postgres-autodoc -h localhost -u postgres --password=password \
		-m '(global|rbac).*' \
		-l /usr/share/postgresql-autodoc -t neato && 
	dot -Tsvg build/postgres-autodoc.neato >build/postgres-autodoc-rbac.svg && \
	echo "generated $PWD/build/postgres-autodoc-rbac.svg"
}
alias postgres-autodoc=postgresAutodoc

function importOfficeData() {
	export HSADMINNG_POSTGRES_JDBC_URL=jdbc:tc:postgresql:15.5-bookworm:///spring_boot_testcontainers
	export HSADMINNG_POSTGRES_ADMIN_USERNAME=admin
	export HSADMINNG_POSTGRES_ADMIN_PASSWORD=password
	export HSADMINNG_POSTGRES_RESTRICTED_USERNAME=restricted
	export HSADMINNG_SUPERUSER=superuser-alex@hostsharing.net
	
	if [ -f .environment ]; then
		source .environment
	fi

    echo "using environment (with ending ';' for use in IntelliJ IDEA):"
    set | grep ^HSADMINNG_ | sed 's/$/;/'

	./gradlew importOfficeData --rerun
}
alias gw-importOfficeData=importOfficeData

alias podman-start='systemctl --user enable --now podman.socket && systemctl --user status podman.socket && ls -la /run/user/$UID/podman/podman.sock'
alias podman-stop='systemctl --user disable --now podman.socket && systemctl --user status podman.socket && ls -la /run/user/$UID/podman/podman.sock'
alias podman-use='export DOCKER_HOST="unix:///run/user/$UID/podman/podman.sock"; export TESTCONTAINERS_RYUK_DISABLED=true'

alias gw=gradleWrapper
alias pg-sql-run='docker run --name hsadmin-ng-postgres -e POSTGRES_PASSWORD=password -p 5432:5432 -d postgres:15.5-bookworm'
alias pg-sql-stop='docker stop hsadmin-ng-postgres'
alias pg-sql-start='docker container start hsadmin-ng-postgres'
alias pg-sql-remove='docker rm hsadmin-ng-postgres'
alias pg-sql-reset='pg-sql-stop; pg-sql-remove; pg-sql-run'
alias pg-sql-backup='docker exec -i hsadmin-ng-postgres /usr/bin/pg_dump --clean --create -U postgres postgres | gzip -9'
alias pg-sql-restore='gunzip --stdout | docker exec -i hsadmin-ng-postgres psql -U postgres -d postgres'

alias fp='grep -r '@Accepts' src | sed -e 's/^.*@/@/g' | sort -u | wc -l'

alias gw-spotless='./gradlew spotlessApply -x pitest -x test -x :processResources'
alias gw-test='. .aliases; ./gradlew test importOfficeData'
alias gw-check='. .aliases; gw test importOfficeData check -x pitest -x :dependencyCheckAnalyze'