forked from 0k/0k-charms
Browse Source
chg: [odoo-tecnativa] rewrite ``load`` and ``save`` to use stdin and stdout, add ``drop`` action.
chg: [odoo-tecnativa] rewrite ``load`` and ``save`` to use stdin and stdout, add ``drop`` action.
The previous implementation had several shortcoming about file due to ``compose`` being run in a docker container. By shifting to ``stdin`` and ``stdout`` usage, we make a more elegant proposition. See ``--help`` to get full doc with examples of usage. Signed-off-by: Valentin Lab <valentin.lab@kalysto.org>
Valentin Lab
3 years ago
3 changed files with 312 additions and 103 deletions
@ -0,0 +1,142 @@ |
|||||
|
#!/bin/bash |
||||
|
|
||||
|
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] [--force|-f] [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= |
||||
|
output= |
||||
|
while [ "$1" ]; do |
||||
|
case "$1" in |
||||
|
"--help"|"-h") |
||||
|
print_help >&2 |
||||
|
exit 0 |
||||
|
;; |
||||
|
"--force"|"-f") |
||||
|
force=yes |
||||
|
;; |
||||
|
--*|-*) |
||||
|
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 |
||||
|
|
||||
|
|
||||
|
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 |
||||
|
} |
||||
|
|
||||
|
containers="$(get_running_containers_for_service "$SERVICE_NAME")" |
||||
|
|
||||
|
if [ -z "$containers" ]; then |
||||
|
err "No containers running for service $DARKYELLOW$SERVICE_NAME$NORMAL." |
||||
|
die "Please ensure that $DARKYELLOW$SERVICE_NAME$NORMAL is running before using '$exname'." |
||||
|
fi |
||||
|
|
||||
|
## XXXvlab: taking first container is probably not a good idea |
||||
|
container="$(echo "$containers" | head -n 1)" |
||||
|
|
||||
|
## XXXvlab: taking first ip is probably not a good idea |
||||
|
read-0 container_network container_ip < <(get_container_network_ip "$container") |
||||
|
|
||||
|
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 |
||||
|
#debug "${cmd[@]}" |
||||
|
|
||||
|
out=$("${cmd[@]}") || { |
||||
|
die "Posting to odoo drop API through curl was unsuccessfull." |
||||
|
} |
||||
|
|
||||
|
if [[ "$out" == *"<html>"* ]]; then |
||||
|
errmsg=$(echo "$out" | grep "alert-danger") |
||||
|
errmsg=${errmsg#*>} |
||||
|
errmsg=${errmsg%%<*} |
||||
|
if [ "$errmsg" ]; then |
||||
|
errmsg=$(echo "$errmsg" | recode html..utf8) |
||||
|
die "$errmsg" |
||||
|
fi |
||||
|
die "Unexpected output. Drop probably failed." |
||||
|
fi >&2 |
||||
|
|
||||
|
info "Dropped odoo database '$dbname'." |
Write
Preview
Loading…
Cancel
Save
Reference in new issue