Browse Source
new: [postgres-stub,postgres,*/postgres_database] new charm
new: [postgres-stub,postgres,*/postgres_database] new charm
Valentin Lab
4 months ago
17 changed files with 211 additions and 31 deletions
-
7cyclos/hooks/postgres_database-relation-joined
-
6docuseal/hooks/postgres_database-relation-joined
-
9etherpad/hooks/postgres_database-relation-joined
-
11gitea/hooks/postgres_database-relation-joined
-
6hedgedoc/hooks/postgres_database-relation-joined
-
4keycloak/hooks/postgres_database-relation-joined
-
9mattermost/hooks/postgres_database-relation-joined
-
7odoo-tecnativa/hooks/postgres_database-relation-joined
-
8onlyoffice/hooks/postgres_database-relation-joined
-
11peertube/hooks/postgres_database-relation-joined
-
46postgres-stub/README.org
-
62postgres-stub/hooks/postgres_database-relation-joined
-
29postgres-stub/lib/common
-
7postgres-stub/metadata.yml
-
4postgres/hooks/postgres_database-relation-joined
-
6rallly/hooks/postgres_database-relation-joined
-
10synapse/hooks/postgres_database-relation-joined
@ -0,0 +1,46 @@ |
|||
# -*- ispell-local-dictionary: "english" -*- |
|||
|
|||
* Description |
|||
|
|||
=postgres-stub= allows you to declare an external =postgres= so that |
|||
your local services can connect to it. It assumes you have the host, |
|||
port of the external postgres access, and a login, password, and a |
|||
database (already created) to connect to. |
|||
|
|||
For now, this stub can't manage an admin access to create database, and |
|||
more. This would be an easy addition thou. |
|||
|
|||
This can be useful for instance if you have an external provider giving |
|||
you access to their postgres (use SSL then!), or in your private cloud, |
|||
or on the same host but not managed by docker, either directly on the host |
|||
or by other virtual services (LXC, VMWare...). |
|||
|
|||
* Usage |
|||
|
|||
You can declare a stub service by specifying at least the host of your |
|||
external =postgres= database. |
|||
|
|||
#+begin_src yaml |
|||
my-postgres-stub: |
|||
charm: postgres-stub |
|||
options: |
|||
host: my-host.mydomain.fr:20432 |
|||
#+end_src |
|||
|
|||
If you don't specify a port, then it'll be defaulted to ~5432~ |
|||
|
|||
Any service that want to connect to this database could then: |
|||
|
|||
#+begin_src yaml |
|||
myservice: |
|||
# ... |
|||
relations: |
|||
postgres-database: |
|||
postgres-stub: |
|||
my-postgres-stub: |
|||
dbname: my-db-name |
|||
user: my-username |
|||
password: my-p4s5w0rd |
|||
#+end_src |
|||
|
|||
|
@ -0,0 +1,62 @@ |
|||
#!/bin/bash |
|||
|
|||
## When writing relation script, remember: |
|||
## - they should be idempotents |
|||
## - they can be launched while the dockers is already up |
|||
## - they are launched from the host |
|||
## - the target of the link is launched first, and get a chance to ``relation-set`` |
|||
## - both side of the scripts get to use ``relation-get``. |
|||
|
|||
|
|||
DBNAME=$(relation-get dbname) || { |
|||
DBNAME="$BASE_SERVICE_NAME" |
|||
relation-set dbname "$DBNAME" |
|||
} |
|||
|
|||
USER=$(relation-get user) || { |
|||
USER="$BASE_SERVICE_NAME" |
|||
relation-set user "$USER" |
|||
} |
|||
|
|||
HOST=$(options-get host) || true |
|||
if [ -z "$HOST" ]; then |
|||
err "No host specified. Please specify ${WHITE}host${NORMAL}" \ |
|||
"in ${DARKYELLOW}$SERVICE_NAME${NORMAL}'s option." |
|||
exit 1 |
|||
fi |
|||
|
|||
if [[ "$HOST" =~ :[0-9]+$ ]]; then |
|||
PORT="${HOST##*:}" |
|||
HOST="${HOST%:*}" |
|||
fi |
|||
if ! [[ "$HOST" =~ ^[0-9a-zA-Z.-]+$ ]]; then |
|||
err "Invalid host specified: '$HOST'. Please provide a valid" \ |
|||
"network target as ${WHITE}host${NORMAL} value" \ |
|||
"in ${DARKYELLOW}$SERVICE_NAME${NORMAL}'s option." |
|||
exit 1 |
|||
fi |
|||
|
|||
PORT=${PORT:-5432} |
|||
|
|||
relation-set host "$HOST" |
|||
relation-set port "$PORT" |
|||
|
|||
. lib/common |
|||
|
|||
set -e |
|||
|
|||
if ! PASSWORD="$(relation-get password 2>/dev/null)"; then |
|||
err "Please provide a password" |
|||
exit 1 |
|||
fi |
|||
|
|||
echo "SELECT 1;" | ddb "$DBNAME" || { |
|||
err "Connection failed to $DBNAME on $HOST:$PORT with user $USER and given password" |
|||
exit 1 |
|||
} |
|||
|
|||
array_read-0 extensions < <(relation-get extensions 2>/dev/null | shyaml get-values-0) |
|||
|
|||
if [ "${#extensions[@]}" -gt 0 ]; then |
|||
db_install_extensions "$DBNAME" "${extensions[@]}" || exit 1 |
|||
fi |
@ -0,0 +1,29 @@ |
|||
# -*- mode: shell-script -*- |
|||
|
|||
POSTGRES_IMAGE=docker.0k.io/postgres:12.15.0-myc |
|||
|
|||
|
|||
ddb () { |
|||
docker run --rm -i \ |
|||
-e PGPASSWORD="$PASSWORD" \ |
|||
-e PGHOST="$HOST" \ |
|||
-e PGUSER="$USER" \ |
|||
-e PGPORT="$PORT" \ |
|||
--entrypoint psql \ |
|||
"${POSTGRES_IMAGE}" \ |
|||
-qAt "$@" |
|||
} |
|||
|
|||
|
|||
## |
|||
## Entrypoints |
|||
## |
|||
|
|||
db_install_extensions() { |
|||
local dbname="$1" |
|||
shift |
|||
for ext in "$@"; do |
|||
ddb -d "$dbname" < <(echo "CREATE EXTENSION IF NOT EXISTS $ext;") || return 1 |
|||
info "Installed $ext extension on database '$dbname'." |
|||
done |
|||
} |
@ -0,0 +1,7 @@ |
|||
type: stub |
|||
|
|||
provides: |
|||
postgres-database: |
|||
|
|||
default-options: |
|||
host: ## Can contain a port specification (if not, port is 5432) |
Write
Preview
Loading…
Cancel
Save
Reference in new issue