#!/bin/sh
#
# Copyright (C) 2000-2023 Kern Sibbald
# License: BSD 2-Clause; see file LICENSE-FOSS
#
# This routine creates the Bacula database
# using PostgreSQL, Ingres, MySQL, or SQLite.
#

# can be used to change the current user with su
pre_command="sh -c"

default_db_type=sqlite3

#
# See if the first argument is a valid backend name.
# If so the user overrides the default database backend.
#
if [ $# -gt 0 ]; then
   case $1 in
     sqlite3)
       db_type=$1
       shift
       ;;
     mysql)
       db_type=$1
       shift
       ;;
     postgresql)
       db_type=$1
       shift
       ;;
     *)
       ;;
   esac
fi

#
# If no new db_type is gives use the default db_type.
#
if [ -z "${db_type}" ]; then
   db_type="${default_db_type}"
fi

if [ $db_type = postgresql -a "$UID" = 0 ]; then
    pre_command="su - postgres -c"
fi

echo "Creating ${db_type} database"
$pre_command "/usr/pkg/libexec/bacula/create_${db_type}_database $*"
