2021-07-10 19:40:17 +02:00
#!/bin/bash
#=================================================
# COMMON VARIABLES
#=================================================
2022-01-30 00:02:31 +01:00
nodejs_version = 14
2021-07-10 19:40:17 +02:00
2023-09-01 11:11:38 +02:00
mongo_version = 5.0
2022-07-26 21:05:19 +02:00
2021-07-10 19:40:17 +02:00
#=================================================
# PERSONAL HELPERS
#=================================================
#=================================================
# EXPERIMENTAL HELPERS
#=================================================
2022-07-12 09:33:07 +02:00
readonly YNH_DEFAULT_MONGO_VERSION = 4.4
2023-01-25 09:54:43 +01:00
# Declare the actual MongoDB version to use: 4.4 ; 5.0 ; 6.0
2022-07-12 09:33:07 +02:00
# A packager willing to use another version of MongoDB can override the variable into its _common.sh.
YNH_MONGO_VERSION = ${ YNH_MONGO_VERSION :- $YNH_DEFAULT_MONGO_VERSION }
2021-07-10 19:40:17 +02:00
# Execute a mongo command
#
# example: ynh_mongo_exec --command='db.getMongo().getDBNames().indexOf("wekan")'
# example: ynh_mongo_exec --command="db.getMongo().getDBNames().indexOf(\"wekan\")"
#
# usage: ynh_mongo_exec [--user=user] [--password=password] [--authenticationdatabase=authenticationdatabase] [--database=database] [--host=host] [--port=port] --command="command" [--eval]
2022-07-02 22:18:59 +02:00
# | arg: -u, --user= - The user name to connect as
# | arg: -p, --password= - The user password
# | arg: -d, --authenticationdatabase= - The authenticationdatabase to connect to
# | arg: -d, --database= - The database to connect to
# | arg: -h, --host= - The host to connect to
# | arg: -P, --port= - The port to connect to
# | arg: -c, --command= - The command to evaluate
# | arg: -e, --eval - Evaluate instead of execute the command.
2021-07-10 19:40:17 +02:00
#
#
ynh_mongo_exec( ) {
# Declare an array to define the options of this helper.
local legacy_args = upadhPce
local -A args_array = ( [ u] = user = [ p] = password = [ a] = authenticationdatabase = [ d] = database = [ h] = host = [ P] = port = [ c] = command = [ e] = eval )
local user
local password
local authenticationdatabase
local database
local host
local port
local command
local eval
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
user = " ${ user :- } "
password = " ${ password :- } "
authenticationdatabase = " ${ authenticationdatabase :- } "
database = " ${ database :- } "
host = " ${ host :- } "
port = " ${ port :- } "
eval = ${ eval :- 0 }
# If user is provided
if [ -n " $user " ]
then
user = " --username= $user "
2023-01-25 09:54:43 +01:00
2021-07-10 19:40:17 +02:00
# If password is provided
if [ -n " $password " ]
then
password = " --password= $password "
fi
# If authenticationdatabase is provided
if [ -n " $authenticationdatabase " ]
then
authenticationdatabase = " --authenticationDatabase= $authenticationdatabase "
else
authenticationdatabase = "--authenticationDatabase=admin"
fi
else
password = ""
authenticationdatabase = ""
fi
# If host is provided
if [ -n " $host " ]
then
host = " --host= $host "
fi
# If port is provided
if [ -n " $port " ]
then
port = " --port= $port "
fi
# If eval is not provided
if [ $eval -eq 0 ]
then
# If database is provided
if [ -n " $database " ]
then
database = " use $database "
else
database = ""
fi
2023-07-28 19:42:11 +02:00
mongo --quiet $user $password $authenticationdatabase $host $port <<EOF
2021-07-10 19:40:17 +02:00
$database
${ command }
quit( )
EOF
else
# If database is provided
if [ -n " $database " ]
then
database = " $database "
else
database = ""
fi
2023-01-25 09:54:43 +01:00
2023-07-28 19:42:11 +02:00
mongo --quiet $database $user $password $authenticationdatabase $host $port --eval= " $command "
2021-07-10 19:40:17 +02:00
fi
2017-11-27 21:45:46 +01:00
}
2021-07-10 19:40:17 +02:00
# Drop a database
#
# [internal]
#
# If you intend to drop the database *and* the associated user,
# consider using ynh_mongo_remove_db instead.
#
# usage: ynh_mongo_drop_db --database=database
# | arg: -d, --database= - The database name to drop
#
#
ynh_mongo_drop_db( ) {
# Declare an array to define the options of this helper.
local legacy_args = d
local -A args_array = ( [ d] = database = )
local database
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
ynh_mongo_exec --database= " $database " --command= 'db.runCommand({dropDatabase: 1})'
2017-09-04 22:24:56 +02:00
}
2021-07-10 19:40:17 +02:00
# Dump a database
#
# example: ynh_mongo_dump_db --database=wekan > ./dump.bson
#
# usage: ynh_mongo_dump_db --database=database
# | arg: -d, --database= - The database name to dump
# | ret: the mongodump output
#
#
ynh_mongo_dump_db( ) {
# Declare an array to define the options of this helper.
local legacy_args = d
local -A args_array = ( [ d] = database = )
local database
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
mongodump --quiet --db= " $database " --archive
2018-01-10 17:21:46 +01:00
}
2021-07-10 19:40:17 +02:00
# Create a user
#
# [internal]
#
# usage: ynh_mongo_create_user --db_user=user --db_pwd=pwd --db_name=name
2022-07-02 22:18:59 +02:00
# | arg: -u, --db_user= - The user name to create
# | arg: -p, --db_pwd= - The password to identify user by
# | arg: -n, --db_name= - Name of the database to grant privilegies
2021-07-10 19:40:17 +02:00
#
#
ynh_mongo_create_user( ) {
# Declare an array to define the options of this helper.
local legacy_args = unp
local -A args_array = ( [ u] = db_user = [ n] = db_name = [ p] = db_pwd = )
local db_user
local db_name
local db_pwd
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
2017-09-28 20:40:20 +02:00
2021-07-10 19:40:17 +02:00
# Create the user and set the user as admin of the db
ynh_mongo_exec --database= " $db_name " --command= 'db.createUser( { user: "' ${ db_user } '", pwd: "' ${ db_pwd } '", roles: [ { role: "readWrite", db: "' ${ db_name } '" } ] } );'
2023-01-25 09:54:43 +01:00
2021-07-10 19:40:17 +02:00
# Add clustermonitoring rights
ynh_mongo_exec --database= " $db_name " --command= 'db.grantRolesToUser("' ${ db_user } '",[{ role: "clusterMonitor", db: "admin" }]);'
}
2019-01-25 23:34:56 +01:00
2021-07-10 19:40:17 +02:00
# Check if a mongo database exists
#
# usage: ynh_mongo_database_exists --database=database
2022-07-02 22:18:59 +02:00
# | arg: -d, --database= - The database for which to check existence
2021-07-10 19:40:17 +02:00
# | exit: Return 1 if the database doesn't exist, 0 otherwise
#
#
ynh_mongo_database_exists( ) {
# Declare an array to define the options of this helper.
local legacy_args = d
local -A args_array = ( [ d] = database = )
local database
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
2019-01-25 23:34:56 +01:00
2021-07-10 19:40:17 +02:00
if [ $( ynh_mongo_exec --command= 'db.getMongo().getDBNames().indexOf("' ${ database } '")' --eval) -lt 0 ]
then
return 1
else
return 0
fi
}
# Restore a database
#
# example: ynh_mongo_restore_db --database=wekan < ./dump.bson
#
# usage: ynh_mongo_restore_db --database=database
# | arg: -d, --database= - The database name to restore
#
#
ynh_mongo_restore_db( ) {
# Declare an array to define the options of this helper.
local legacy_args = d
local -A args_array = ( [ d] = database = )
local database
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
mongorestore --quiet --db= " $database " --archive
}
2017-09-04 22:24:56 +02:00
2021-07-10 19:40:17 +02:00
# Drop a user
#
# [internal]
#
# usage: ynh_mongo_drop_user --db_user=user --db_name=name
2022-07-02 22:18:59 +02:00
# | arg: -u, --db_user= - The user to drop
# | arg: -n, --db_name= - Name of the database
2021-07-10 19:40:17 +02:00
#
#
ynh_mongo_drop_user( ) {
# Declare an array to define the options of this helper.
local legacy_args = un
local -A args_array = ( [ u] = db_user = [ n] = db_name = )
local db_user
local db_name
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
2017-09-04 22:24:56 +02:00
2021-07-10 19:40:17 +02:00
ynh_mongo_exec --database= " $db_name " --command= 'db.dropUser("' $db_user '", {w: "majority", wtimeout: 5000})'
}
# Create a database, an user and its password. Then store the password in the app's config
#
# usage: ynh_mongo_setup_db --db_user=user --db_name=name [--db_pwd=pwd]
2022-07-02 22:18:59 +02:00
# | arg: -u, --db_user= - Owner of the database
# | arg: -n, --db_name= - Name of the database
# | arg: -p, --db_pwd= - Password of the database. If not provided, a password will be generated
2021-07-10 19:40:17 +02:00
#
# After executing this helper, the password of the created database will be available in $db_pwd
# It will also be stored as "mongopwd" into the app settings.
#
#
ynh_mongo_setup_db( ) {
# Declare an array to define the options of this helper.
local legacy_args = unp
local -A args_array = ( [ u] = db_user = [ n] = db_name = [ p] = db_pwd = )
local db_user
local db_name
db_pwd = ""
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
2017-09-04 22:24:56 +02:00
2021-07-10 19:40:17 +02:00
local new_db_pwd = $( ynh_string_random) # Generate a random password
# If $db_pwd is not provided, use new_db_pwd instead for db_pwd
db_pwd = " ${ db_pwd :- $new_db_pwd } "
2023-01-25 09:54:43 +01:00
2021-07-10 19:40:17 +02:00
# Create the user and grant access to the database
ynh_mongo_create_user --db_user= " $db_user " --db_pwd= " $db_pwd " --db_name= " $db_name "
# Store the password in the app's config
2023-04-13 08:55:12 +02:00
ynh_app_setting_set --app= $app --key= db_pwd --value= $db_pwd
2021-07-10 19:40:17 +02:00
}
# Remove a database if it exists, and the associated user
#
# usage: ynh_mongo_remove_db --db_user=user --db_name=name
2022-07-02 22:18:59 +02:00
# | arg: -u, --db_user= - Owner of the database
# | arg: -n, --db_name= - Name of the database
2021-07-10 19:40:17 +02:00
#
#
ynh_mongo_remove_db( ) {
# Declare an array to define the options of this helper.
local legacy_args = un
local -A args_array = ( [ u] = db_user = [ n] = db_name = )
local db_user
local db_name
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
if ynh_mongo_database_exists --database= $db_name ; then # Check if the database exists
ynh_mongo_drop_db --database= $db_name # Remove the database
else
ynh_print_warn --message= " Database $db_name not found "
fi
# Remove mongo user if it exists
ynh_mongo_drop_user --db_user= $db_user --db_name= $db_name
}
# Install MongoDB and integrate MongoDB service in YunoHost
#
2022-07-12 09:33:07 +02:00
# usage: ynh_install_mongo [--mongo_version=mongo_version]
# | arg: -m, --mongo_version= - Version of MongoDB to install
2021-07-10 19:40:17 +02:00
#
#
ynh_install_mongo( ) {
2022-07-12 09:33:07 +02:00
# Declare an array to define the options of this helper.
local legacy_args = m
local -A args_array = ( [ m] = mongo_version = )
local mongo_version
# Manage arguments with getopts
ynh_handle_getopts_args " $@ "
mongo_version = " ${ mongo_version :- $YNH_MONGO_VERSION } "
2023-08-15 11:03:51 +02:00
ynh_print_info --message= "Installing MongoDB Community Edition..."
local mongo_debian_release = bullseye #$(ynh_get_debian_release)
2023-01-25 09:54:43 +01:00
2023-08-04 14:14:49 +02:00
if [ [ $( cat /proc/cpuinfo) != *"avx" * && " $mongo_version " != "4.4" ] ] ; then
ynh_print_warn --message= " Installing Mongo 4.4 as $mongo_version is not compatible with your CPU (see https://docs.mongodb.com/manual/administration/production-notes/#x86_64). "
2023-01-26 17:34:40 +01:00
mongo_version = "4.4"
fi
if [ [ " $mongo_version " = = "4.4" && " $mongo_debian_release " != "buster" ] ] ; then
2023-08-04 14:14:49 +02:00
ynh_print_warn --message= " Switched to Buster install as Mongo 4.4 is not compatible with $mongo_debian_release . "
2023-01-25 09:54:43 +01:00
mongo_debian_release = buster
2023-01-26 17:34:40 +01:00
fi
2023-01-25 09:54:43 +01:00
2023-07-29 00:31:53 +02:00
ynh_install_extra_app_dependencies --repo= " deb http://repo.mongodb.org/apt/debian $mongo_debian_release /mongodb-org/ $mongo_version main " --package= "mongodb-org-server mongodb-org-shell mongodb-database-tools" --key= " https://www.mongodb.org/static/pgp/server- $mongo_version .asc "
2022-07-12 09:33:07 +02:00
mongodb_servicename = mongod
2021-07-10 19:40:17 +02:00
# Make sure MongoDB is started and enabled
2022-07-12 09:33:07 +02:00
systemctl enable $mongodb_servicename --quiet
systemctl daemon-reload --quiet
2023-01-25 09:54:43 +01:00
2023-01-26 17:34:40 +01:00
ynh_systemd_action --service_name= $mongodb_servicename --action= restart --line_match= "aiting for connections" --log_path= " /var/log/mongodb/ $mongodb_servicename .log "
2022-07-12 09:33:07 +02:00
2021-07-10 19:40:17 +02:00
# Integrate MongoDB service in YunoHost
2022-06-26 20:53:36 +02:00
yunohost service add $mongodb_servicename --description= "MongoDB daemon" --log= " /var/log/mongodb/ $mongodb_servicename .log "
2022-07-12 09:33:07 +02:00
# Store mongo_version into the config of this app
ynh_app_setting_set --app= $app --key= mongo_version --value= $mongo_version
2021-07-10 19:40:17 +02:00
}
2017-09-28 20:40:20 +02:00
2021-07-10 19:40:17 +02:00
# Remove MongoDB
# Only remove the MongoDB service integration in YunoHost for now
# if MongoDB package as been removed
#
# usage: ynh_remove_mongo
#
#
ynh_remove_mongo( ) {
# Only remove the mongodb service if it is not installed.
if ! ynh_package_is_installed --package= "mongodb*"
then
2022-06-26 20:53:36 +02:00
ynh_print_info --message= "Removing MongoDB service..."
2022-07-12 09:33:07 +02:00
mongodb_servicename = mongod
2021-07-10 19:40:17 +02:00
# Remove the mongodb service
2022-06-26 20:53:36 +02:00
yunohost service remove $mongodb_servicename
2022-06-27 02:49:41 +02:00
ynh_secure_remove --file= "/var/lib/mongodb"
ynh_secure_remove --file= "/var/log/mongodb"
2021-07-10 19:40:17 +02:00
fi
2017-07-21 14:35:08 +02:00
}