#!/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 # define user in inventory first # `app.children..vars.pg_users`, entry with name= #--------------------------------------------------------------# # 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 " 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 " 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}:@${PG_CLUSTER}/postgres" exit 0