#!/bin/bash
set -uo pipefail
#==============================================================#
# File      :   pgsql-user
# Desc      :   Create PostgreSQL Business USer
# Ctime     :   2021-07-15
# Mtime     :   2022-12-28
# Path      :   bin/pgsql-user
# Deps      :   ansible-playbook, pgsql-user.yml
# License   :   Apache-2.0 @ https://pigsty.io/docs/about/license/
# Copyright :   2018-2026  Ruohang Feng / Vonng (rh@vonng.com)
#==============================================================#
APP_NAME="$(basename $0)"
APP_DIR="$(cd $(dirname $0) && pwd)"
PIGSTY_HOME=$(cd $(dirname ${APP_DIR}) && pwd)


#--------------------------------------------------------------#
# Usage
#--------------------------------------------------------------#
# bin/pgsql-user <cls> <username>  # define user in inventory first
# `app.children.<cls>.vars.pg_users`, entry with name=<username>


#--------------------------------------------------------------#
# Utils
#--------------------------------------------------------------#
__CN='\033[0m';__CK='\033[0;30m';__CR='\033[0;31m';__CG='\033[0;32m';
__CY='\033[0;33m';__CB='\033[0;34m';__CM='\033[0;35m';__CC='\033[0;36m';__CW='\033[0;37m';
function log_info() {  printf "[${__CG} OK ${__CN}] ${__CG}$*${__CN}\n";   }
function log_warn() {  printf "[${__CY}WARN${__CN}] ${__CY}$*${__CN}\n";   }
function log_error() { printf "[${__CR}FAIL${__CN}] ${__CR}$*${__CN}\n";   }
function log_debug() { printf "[${__CB}HINT${__CN}] ${__CB}$*${__CN}\n"; }
function log_input() { printf "[${__CM} IN ${__CN}] ${__CM}$*\n=> ${__CN}"; }
function log_hint()  { printf "${__CB}$*${__CN}\n"; }
function log_line()  { printf "${__CM}[$*] ===========================================${__CN}\n"; }

#--------------------------------------------------------------#
# Param
#--------------------------------------------------------------#
PG_CLUSTER=${1-''}
USERNAME=${2-''}

if [[ -z "${PG_CLUSTER}" ]]; then
    log_error "pg_cluster is empty"
    log_hint "Usage:"
    log_hint "    bin/pgsql-user <cls> <username>"
    exit 1
fi
if [[ -z "${USERNAME}" ]]; then
    log_error "username is empty"
    log_warn "don't forget to define user in  all.children.${PG_CLUSTER}.vars.pg_users  first"
    log_hint "Usage:"
    log_hint "    bin/pgsql-user <cls> <username>"
    exit 2
fi


#--------------------------------------------------------------#
# Execute
#--------------------------------------------------------------#
log_line "EXECUTE"
log_warn "create pgsql user '${USERNAME}' on '${PG_CLUSTER}'"
log_hint "$ ./pgsql-user.yml -l ${PG_CLUSTER} -e username=${USERNAME}"

"${PIGSTY_HOME}/pgsql-user.yml" -l "${PG_CLUSTER}" -e username="${USERNAME}"

if [[ $? -ne 0 ]]; then
  log_line "FAILURE"
  log_error "fail to create pgsql user on '${PG_CLUSTER}'"
  exit 3
fi
log_line "SUMMARY"
log_info "create pgsql user ${USERNAME} on '${PG_CLUSTER}' complete"
log_hint "check pgurl: postgres://${USERNAME}:<PASSWORD>@${PG_CLUSTER}/postgres"
exit 0