mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-15 11:59:11 +02:00
update
This commit is contained in:
@@ -105,7 +105,6 @@
|
|||||||
"cifspassword": "str?",
|
"cifspassword": "str?",
|
||||||
"cifsusername": "str?",
|
"cifsusername": "str?",
|
||||||
"data_location": "str",
|
"data_location": "str",
|
||||||
"database": "list(internal|external_postgresql)?",
|
|
||||||
"localdisks": "str?",
|
"localdisks": "str?",
|
||||||
"networkdisks": "str?"
|
"networkdisks": "str?"
|
||||||
},
|
},
|
||||||
@@ -116,4 +115,4 @@
|
|||||||
"url": "https://github.com/alexbelgium/hassio-addons",
|
"url": "https://github.com/alexbelgium/hassio-addons",
|
||||||
"version": "1.75.2",
|
"version": "1.75.2",
|
||||||
"webui": "http://[HOST]:[PORT:8080]"
|
"webui": "http://[HOST]:[PORT:8080]"
|
||||||
}
|
}
|
||||||
@@ -2,6 +2,20 @@
|
|||||||
# shellcheck shell=bash
|
# shellcheck shell=bash
|
||||||
# shellcheck disable=SC2155,SC2016
|
# shellcheck disable=SC2155,SC2016
|
||||||
|
|
||||||
|
######################
|
||||||
|
# Switch of database #
|
||||||
|
######################
|
||||||
|
|
||||||
|
if [ -f /share/postgresql_immich.tar.gz ]; then
|
||||||
|
bashio::log.warning "Your previous database was exported to /share/postgresql_immich.tar.gz"
|
||||||
|
elif [ -d /data/postgresql ]; then
|
||||||
|
bashio::log.warning "------------------------------------"
|
||||||
|
bashio::log.warning "Internal postgres database detected, copying to /share/postgresql_immich.tar.gz"
|
||||||
|
bashio::log.warning "------------------------------------"
|
||||||
|
tar -zcvf /share/postgresql_immich.tar.gz /data/postgresql
|
||||||
|
rm -r /data/postgresql
|
||||||
|
fi
|
||||||
|
|
||||||
###################
|
###################
|
||||||
# Define database #
|
# Define database #
|
||||||
###################
|
###################
|
||||||
@@ -9,69 +23,36 @@
|
|||||||
bashio::log.info "Defining database"
|
bashio::log.info "Defining database"
|
||||||
bashio::log.info "-----------------"
|
bashio::log.info "-----------------"
|
||||||
|
|
||||||
case $(bashio::config 'database') in
|
bashio::log.info "Connecting to external postgresql"
|
||||||
|
bashio::log.info ""
|
||||||
|
|
||||||
"external_postgresql")
|
# Check if values exist
|
||||||
|
if ! bashio::config.has_value 'DB_USERNAME' && \
|
||||||
|
! bashio::config.has_value 'DB_HOSTNAME' && \
|
||||||
|
! bashio::config.has_value 'DB_PASSWORD' && \
|
||||||
|
! bashio::config.has_value 'DB_DATABASE_NAME' && \
|
||||||
|
! bashio::config.has_value 'JWT_SECRET' && \
|
||||||
|
! bashio::config.has_value 'DB_PORT'; then
|
||||||
|
! bashio::exit.nok "Please make sure that the following options are set : DB_USERNAME, DB_HOSTNAME, DB_PASSWORD, DB_DATABASE_NAME, DB_PORT"
|
||||||
|
fi
|
||||||
|
|
||||||
bashio::log.info "Using external postgresql"
|
# Settings parameters
|
||||||
bashio::log.info ""
|
export DB_USERNAME=$(bashio::config 'DB_USERNAME')
|
||||||
|
export DB_HOSTNAME=$(bashio::config 'DB_HOSTNAME')
|
||||||
|
export DB_PASSWORD=$(bashio::config 'DB_PASSWORD')
|
||||||
|
export DB_DATABASE_NAME=$(bashio::config 'DB_DATABASE_NAME')
|
||||||
|
export DB_PORT=$(bashio::config 'DB_PORT')
|
||||||
|
export JWT_SECRET=$(bashio::config 'JWT_SECRET')
|
||||||
|
|
||||||
# Check if values exist
|
# Create database
|
||||||
if ! bashio::config.has_value 'DB_USERNAME' && \
|
echo "CREATE ROLE root WITH LOGIN SUPERUSER CREATEDB CREATEROLE PASSWORD 'securepassword';
|
||||||
! bashio::config.has_value 'DB_HOSTNAME' && \
|
CREATE DATABASE immich; CREATE USER immich WITH ENCRYPTED PASSWORD 'immich';
|
||||||
! bashio::config.has_value 'DB_PASSWORD' && \
|
GRANT ALL PRIVILEGES ON DATABASE immich to immich;
|
||||||
! bashio::config.has_value 'DB_DATABASE_NAME' && \
|
\q"> setup_postgres.sql
|
||||||
! bashio::config.has_value 'JWT_SECRET' && \
|
chown postgres setup_postgres.sql
|
||||||
! bashio::config.has_value 'DB_PORT'
|
# shellcheck disable=SC2024
|
||||||
then
|
sudo -iu postgres psql < setup_postgres.sql
|
||||||
! bashio::exit.nok "Please make sure that the following options are set : DB_USERNAME, DB_HOSTNAME, DB_PASSWORD, DB_DATABASE_NAME, DB_PORT"
|
rm setup_postgres.sql
|
||||||
fi
|
|
||||||
|
|
||||||
# Settings parameters
|
|
||||||
export DB_USERNAME=$(bashio::config 'DB_USERNAME')
|
|
||||||
export DB_HOSTNAME=$(bashio::config 'DB_HOSTNAME')
|
|
||||||
export DB_PASSWORD=$(bashio::config 'DB_PASSWORD')
|
|
||||||
export DB_DATABASE_NAME=$(bashio::config 'DB_DATABASE_NAME')
|
|
||||||
export DB_PORT=$(bashio::config 'DB_PORT')
|
|
||||||
export JWT_SECRET=$(bashio::config 'JWT_SECRET')
|
|
||||||
;;
|
|
||||||
|
|
||||||
**)
|
|
||||||
|
|
||||||
bashio::log.info "Using internal postgresql"
|
|
||||||
bashio::log.info ""
|
|
||||||
|
|
||||||
# Settings files & permissions
|
|
||||||
ln -s /usr/lib/postgresql/14/bin/postgres /usr/bin || true
|
|
||||||
ln -s /usr/lib/postgresql/14/bin/psql /usr/psql || true
|
|
||||||
mkdir -p /data/postgresql
|
|
||||||
cp -rnf /var/lib/postgresql/14/main/* /data/postgresql/
|
|
||||||
chown -R postgres /data/postgresql
|
|
||||||
chmod -R 700 /data/postgresql
|
|
||||||
|
|
||||||
# Start postgresql
|
|
||||||
/etc/init.d/postgresql start
|
|
||||||
|
|
||||||
# Create database
|
|
||||||
echo "CREATE ROLE root WITH LOGIN SUPERUSER CREATEDB CREATEROLE PASSWORD 'securepassword';
|
|
||||||
CREATE DATABASE immich; CREATE USER immich WITH ENCRYPTED PASSWORD 'immich';
|
|
||||||
GRANT ALL PRIVILEGES ON DATABASE immich to immich;
|
|
||||||
\q"> setup_postgres.sql
|
|
||||||
chown postgres setup_postgres.sql
|
|
||||||
# shellcheck disable=SC2024
|
|
||||||
sudo -iu postgres psql < setup_postgres.sql
|
|
||||||
rm setup_postgres.sql
|
|
||||||
|
|
||||||
# Settings parameters
|
|
||||||
export DB_USERNAME=immich
|
|
||||||
export DB_HOSTNAME=localhost
|
|
||||||
export DB_PASSWORD=immich
|
|
||||||
export DB_DATABASE_NAME=immich
|
|
||||||
export DB_PORT=5432
|
|
||||||
export JWT_SECRET=$(bashio::config 'JWT_SECRET')
|
|
||||||
;;
|
|
||||||
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Export variables
|
# Export variables
|
||||||
if [ -d /var/run/s6/container_environment ]; then
|
if [ -d /var/run/s6/container_environment ]; then
|
||||||
|
|||||||
Reference in New Issue
Block a user