forked from 0k/0k-charms
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
187 lines
5.0 KiB
187 lines
5.0 KiB
#!/bin/bash
|
|
## compose: no-hooks
|
|
|
|
if [ -z "$SERVICE_DATASTORE" ]; then
|
|
echo "This script is meant to be run through 'compose' to work properly." >&2
|
|
exit 1
|
|
fi
|
|
|
|
|
|
version=0.1
|
|
usage="$exname [-h|--help] [DBNAME]"
|
|
help="
|
|
USAGE:
|
|
|
|
$usage
|
|
|
|
DESCRIPTION:
|
|
|
|
Drop odoo database DBNAME. If DBNAME is not provided, it'll take the
|
|
default odoo database from the ${DARKCYAN}postgres-database${NORMAL} relation of
|
|
current service.
|
|
|
|
EXAMPLES:
|
|
|
|
$exname
|
|
$exname odoo2
|
|
|
|
"
|
|
|
|
|
|
dbname=
|
|
while [ "$1" ]; do
|
|
case "$1" in
|
|
"--help"|"-h")
|
|
print_help >&2
|
|
exit 0
|
|
;;
|
|
--*|-*)
|
|
err "Unexpected optional argument '$1'"
|
|
print_usage >&2
|
|
exit 1
|
|
;;
|
|
*)
|
|
[ -z "$dbname" ] && { dbname=$1 ; shift ; continue ; }
|
|
err "Unexpected positional argument '$1'"
|
|
print_usage >&2
|
|
exit 1
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
|
|
db_drop() {
|
|
local dbname="$1"
|
|
(
|
|
switch_to_relation_service postgres-database
|
|
|
|
set +e
|
|
. lib/common
|
|
set -e
|
|
|
|
ensure_db_docker_running || exit 1
|
|
|
|
if db_has_database "$dbname"; then
|
|
info "Found a postgres database '$dbname' and deleting it."
|
|
PGM rm -f "$dbname" || exit 1
|
|
else
|
|
info "No postgres database '$dbname' found."
|
|
fi
|
|
|
|
) || exit 1
|
|
|
|
if [ -d "$SERVICE_DATASTORE"/var/lib/odoo/filestore/"$dbname" ]; then
|
|
rm -rf "$SERVICE_DATASTORE"/var/lib/odoo/filestore/"$dbname" >&2 || exit 1
|
|
info "Deleted filestore for database '$dbname'."
|
|
else
|
|
info "No filestore for database '$dbname' found."
|
|
fi
|
|
}
|
|
|
|
|
|
if [ -z "$dbname" ]; then
|
|
|
|
##
|
|
## Fetch default dbname in relation to postgres-database
|
|
##
|
|
|
|
## XXXvlab: can't get real config here
|
|
if ! read-0 ts _ _ < <(get_service_relation "$SERVICE_NAME" "postgres-database"); then
|
|
err "Couldn't find relation ${DARKCYAN}postgres-database${NORMAL}."
|
|
exit 1
|
|
fi
|
|
|
|
relation_file=$(get_relation_data_dir "$SERVICE_NAME" "$ts" "postgres-database") || {
|
|
err "Failed to find relation file"
|
|
exit 1
|
|
}
|
|
|
|
postgres_config=$(cat "$relation_file"/data) || exit 2
|
|
|
|
dbname="$(e "$postgres_config" | shyaml get-value dbname)" || {
|
|
err "Couldn't retrieve information of ${DARKCYAN}mysql-database${NORMAL}'s relation."
|
|
exit 1
|
|
}
|
|
fi
|
|
|
|
set -e
|
|
|
|
## Ensure odoo is launched
|
|
service_def=$(get_compose_service_def "$SERVICE_NAME")
|
|
|
|
## XXXvlab: should be moved to lib
|
|
CONFIG=$SERVICE_CONFIGSTORE/etc/odoo-server.conf
|
|
ADMIN_PASSWORD=$(echo "$service_def" | shyaml -q get-value options.admin-password) || {
|
|
if [ -e "$CONFIG" ]; then
|
|
ADMIN_PASSWORD=$(grep ^admin_passwd "$CONFIG" | sed -r 's/^admin_passwd\s+=\s+(.+)$/\1/g')
|
|
fi
|
|
if [ -z "$ADMIN_PASSWORD" ]; then
|
|
err "Could not find 'admin-password' in $SERVICE_NAME service definition nor in config file."
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
container_network_ip=$(get_healthy_container_ip_for_service "$SERVICE_NAME" 8069 4) || {
|
|
err "Please ensure that $DARKYELLOW$SERVICE_NAME$NORMAL is running before using '$exname'."
|
|
exit 1
|
|
}
|
|
|
|
container_ip=${container_network_ip##*:}
|
|
container_network=${container_network_ip%%:*}
|
|
|
|
|
|
DEFAULT_CURL_IMAGE=${DEFAULT_CURL_IMAGE:-docker.0k.io/curl}
|
|
|
|
|
|
cmd=(
|
|
docker run -i --rm --network "$container_network"
|
|
"$DEFAULT_CURL_IMAGE"
|
|
-sS
|
|
-X POST
|
|
-F "master_pwd=${ADMIN_PASSWORD}"
|
|
-F "name=${dbname}"
|
|
http://${container_ip}:8069/web/database/drop
|
|
)
|
|
## XXXvlab: contains password, left only for advanced debug
|
|
#echo "${cmd[@]}" >&2
|
|
|
|
|
|
out=$("${cmd[@]}") || {
|
|
errlvl="$?"
|
|
if [ "$errlvl" == "28" ]; then
|
|
## Curl timeout
|
|
warn "Standard method through curl timed out. Trying manual drop of database."
|
|
db_drop "$dbname" || exit 1
|
|
exit 0
|
|
else
|
|
die "Posting to odoo drop API through curl was unsuccessfull ($errlvl)."
|
|
fi
|
|
}
|
|
|
|
if [[ "$out" == *"<html>"* ]]; then
|
|
errmsg=$(echo "$out" | grep -m1 "alert-danger") ||
|
|
errmsg=$(echo "$out" | grep -m1 "errormsg") ||
|
|
errmsg=$(echo "$out" | grep -m1 "<title>")
|
|
errmsg="${errmsg#*>}"
|
|
errmsg="${errmsg%%<*}"
|
|
if [ -n "$errmsg" ]; then
|
|
errmsg=$(echo "$errmsg" | recode html..utf8)
|
|
if [[ "$errmsg" == "psycopg2.OperationalError: FATAL: database \"$dbname\" does not exist" ]]; then
|
|
warn "Received error we can probably ignore."
|
|
elif [[ "$errmsg" == "KeyError: 'ir.http'" ]] ||
|
|
[[ "$errmsg" == \
|
|
"psycopg2.ProgrammingError: relation \"base_registry_signaling\" already exists" ]]; then
|
|
## Hooks must have created an empty database, messing up things
|
|
warn "Standard method failed as if postgres db was empty but existing."
|
|
echo " Trying manual drop of database.." >&2
|
|
db_drop "$dbname" || exit 1 ## Let's do it the legacy way !
|
|
else
|
|
die "$errmsg"
|
|
fi
|
|
else
|
|
die "Unexpected output. Drop probably failed."
|
|
fi
|
|
else
|
|
info "Dropped odoo database '$dbname'."
|
|
fi >&2
|