IDEMPIERE-1900 iDempiere Debian Installer
|
@ -4,11 +4,11 @@ root.folder.data=data
|
|||
root.folder.setup=setup
|
||||
|
||||
#linux 64 bits
|
||||
root.linux.gtk.x86_64=file:setup.sh,file:console-setup.sh,file:idempiere-server.sh,file:setup-alt.sh,file:console-setup-alt.sh,file:sign-database-build.sh
|
||||
root.linux.gtk.x86_64=file:setup.sh,file:console-setup.sh,file:idempiere-server.sh,file:setup-alt.sh,file:console-setup-alt.sh,file:sign-database-build.sh,file:idempiereEnvTemplate.properties
|
||||
root.linux.gtk.x86_64.folder.utils=utils.unix
|
||||
root.linux.gtk.x86_64.permissions.755=*.sh,**/*.sh
|
||||
#linux
|
||||
root.linux.gtk.x86=file:setup.sh,file:console-setup.sh,file:idempiere-server.sh,file:setup-alt.sh,file:console-setup-alt.sh,file:sign-database-build.sh
|
||||
root.linux.gtk.x86=file:setup.sh,file:console-setup.sh,file:idempiere-server.sh,file:setup-alt.sh,file:console-setup-alt.sh,file:sign-database-build.sh,file:idempiereEnvTemplate.properties
|
||||
root.linux.gtk.x86.folder.utils=utils.unix
|
||||
root.linux.gtk.x86.permissions.755=*.sh,**/*.sh
|
||||
#mac
|
||||
|
|
|
@ -0,0 +1,66 @@
|
|||
#idempiereEnv.properties Template
|
||||
|
||||
#idempiere home
|
||||
IDEMPIERE_HOME=/opt/idempiere-server
|
||||
#Java home
|
||||
JAVA_HOME=
|
||||
|
||||
#Java runtime options
|
||||
IDEMPIERE_JAVA_OPTIONS=-Xms64M -Xmx512M
|
||||
|
||||
#Type of database, postgresql|oracle|oracleXE
|
||||
ADEMPIERE_DB_TYPE=PostgreSQL
|
||||
ADEMPIERE_DB_EXISTS=N
|
||||
#Path to database specific sql scripts: postgresql|oracle|oracleXE
|
||||
ADEMPIERE_DB_PATH=postgresql
|
||||
#Database server host name
|
||||
ADEMPIERE_DB_SERVER=localhost
|
||||
#Database port, oracle[1512], postgresql[5432]
|
||||
ADEMPIERE_DB_PORT=5432
|
||||
#Database name
|
||||
ADEMPIERE_DB_NAME=idempiere
|
||||
#Database system user password
|
||||
ADEMPIERE_DB_SYSTEM=
|
||||
#Database user name
|
||||
ADEMPIERE_DB_USER=adempiere
|
||||
#Database user password
|
||||
ADEMPIERE_DB_PASSWORD=adempiere
|
||||
|
||||
#Application server host name
|
||||
ADEMPIERE_APPS_SERVER=localhost
|
||||
ADEMPIERE_WEB_ALIAS=localhost
|
||||
#Application server port
|
||||
ADEMPIERE_WEB_PORT=8080
|
||||
ADEMPIERE_SSL_PORT=8443
|
||||
|
||||
#Keystore setting
|
||||
ADEMPIERE_KEYSTORE=/opt/idempiere-server/keystore/myKeystore
|
||||
ADEMPIERE_KEYSTOREWEBALIAS=adempiere
|
||||
ADEMPIERE_KEYSTORECODEALIAS=adempiere
|
||||
ADEMPIERE_KEYSTOREPASS=myPassword
|
||||
|
||||
#Certificate details
|
||||
#Common name, default to host name
|
||||
ADEMPIERE_CERT_CN=localhost
|
||||
#Organization, default to the user name
|
||||
ADEMPIERE_CERT_ORG=iDempiere Bazaar
|
||||
#Organization Unit, default to 'AdempiereUser'
|
||||
ADEMPIERE_CERT_ORG_UNIT=iDempiereUser
|
||||
#town
|
||||
ADEMPIERE_CERT_LOCATION=myTown
|
||||
#state
|
||||
ADEMPIERE_CERT_STATE=CA
|
||||
#2 character country code
|
||||
ADEMPIERE_CERT_COUNTRY=US
|
||||
|
||||
#Mail server setting
|
||||
ADEMPIERE_MAIL_SERVER=localhost
|
||||
ADEMPIERE_ADMIN_EMAIL=
|
||||
ADEMPIERE_MAIL_USER=
|
||||
ADEMPIERE_MAIL_PASSWORD=
|
||||
|
||||
#ftp server setting
|
||||
ADEMPIERE_FTP_SERVER=localhost
|
||||
ADEMPIERE_FTP_PREFIX=my
|
||||
ADEMPIERE_FTP_USER=anonymous
|
||||
ADEMPIERE_FTP_PASSWORD=user@host.com
|
|
@ -23,20 +23,33 @@ fi
|
|||
|
||||
PGPASSWORD=$4
|
||||
export PGPASSWORD
|
||||
if [ "x$4" = "x^TryLocalConnection^" ]
|
||||
then
|
||||
LOCALPG=true # Allow to run this command with user postgres (just useful running configure as root)
|
||||
else
|
||||
LOCALPG=false
|
||||
fi
|
||||
|
||||
echo -------------------------------------
|
||||
echo Recreate user and database
|
||||
echo -------------------------------------
|
||||
dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $ADEMPIERE_DB_NAME
|
||||
|
||||
dropuser -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $2
|
||||
|
||||
ADEMPIERE_CREATE_ROLE_SQL="CREATE ROLE $2 SUPERUSER LOGIN PASSWORD '$3'"
|
||||
psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres -c "$ADEMPIERE_CREATE_ROLE_SQL"
|
||||
if [ $LOCALPG = "true" ]
|
||||
then
|
||||
# Assuming that adempiere role already exists (it was created out there)
|
||||
PGPASSWORD=$3
|
||||
export PGPASSWORD
|
||||
dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U $2 $ADEMPIERE_DB_NAME
|
||||
else
|
||||
dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $ADEMPIERE_DB_NAME
|
||||
dropuser -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $2
|
||||
psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres -c "$ADEMPIERE_CREATE_ROLE_SQL"
|
||||
fi
|
||||
ADEMPIERE_CREATE_ROLE_SQL=
|
||||
|
||||
PGPASSWORD=$3
|
||||
export PGPASSWORD
|
||||
createdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -E UNICODE -O $2 -U $2 $ADEMPIERE_DB_NAME
|
||||
createdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -E UNICODE -T template0 -O $2 -U $2 $ADEMPIERE_DB_NAME
|
||||
|
||||
echo -------------------------------------
|
||||
echo Import Adempiere_pg.dmp
|
||||
|
|
|
@ -23,20 +23,32 @@ fi
|
|||
|
||||
PGPASSWORD=$4
|
||||
export PGPASSWORD
|
||||
if [ "x$4" = "x^TryLocalConnection^" ]
|
||||
then
|
||||
LOCALPG=true # Allow to run this command with user postgres (just useful running configure as root)
|
||||
else
|
||||
LOCALPG=false
|
||||
fi
|
||||
echo -------------------------------------
|
||||
echo Recreate user and database
|
||||
echo -------------------------------------
|
||||
dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $ADEMPIERE_DB_NAME
|
||||
|
||||
dropuser -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $2
|
||||
|
||||
ADEMPIERE_CREATE_ROLE_SQL="CREATE ROLE $2 SUPERUSER LOGIN PASSWORD '$3'"
|
||||
psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres -c "$ADEMPIERE_CREATE_ROLE_SQL"
|
||||
if [ $LOCALPG = "true" ]
|
||||
then
|
||||
# Assuming that adempiere role already exists (it was created out there)
|
||||
PGPASSWORD=$3
|
||||
export PGPASSWORD
|
||||
dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U $2 $ADEMPIERE_DB_NAME
|
||||
else
|
||||
dropdb -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $ADEMPIERE_DB_NAME
|
||||
dropuser -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres $2
|
||||
psql -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -U postgres -c "$ADEMPIERE_CREATE_ROLE_SQL"
|
||||
fi
|
||||
ADEMPIERE_CREATE_ROLE_SQL=
|
||||
|
||||
PGPASSWORD=$3
|
||||
export PGPASSWORD
|
||||
createdb --template=template0 -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -E UNICODE -O $2 -U $2 $ADEMPIERE_DB_NAME
|
||||
createdb -T template0 -h $ADEMPIERE_DB_SERVER -p $ADEMPIERE_DB_PORT -E UNICODE -O $2 -U $2 $ADEMPIERE_DB_NAME
|
||||
|
||||
echo -------------------------------------
|
||||
echo Import Adempiere$5.dmp
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
/etc/default/idempiere
|
|
@ -0,0 +1,12 @@
|
|||
Package: idempiere
|
||||
Version: 2.0
|
||||
Section: web
|
||||
Priority: extra
|
||||
Architecture: all
|
||||
Pre-Depends: openjdk-7-jdk|openjdk-6-jdk, postgresql-9.3|postgresql-9.2|postgresql-9.1, postgresql-contrib, adduser
|
||||
Suggests: firefox
|
||||
Installed-Size: 968668
|
||||
Maintainer: Carlos Ruiz <carg67@gmail.com>
|
||||
Description: iDempiere ERP
|
||||
iDempiere Business Suite ERP/CRM/SCM
|
||||
Homepage: http://www.idempiere.org/
|
|
@ -0,0 +1,116 @@
|
|||
#!/bin/sh
|
||||
|
||||
if [ "$1" != "configure" ]
|
||||
then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [ -z "$2" ]
|
||||
then
|
||||
MODE=install
|
||||
else
|
||||
MODE=upgrade
|
||||
fi
|
||||
|
||||
if [ -x "/etc/init.d/idempiere" ]; then
|
||||
update-rc.d idempiere defaults >/dev/null
|
||||
if [ -x "`which invoke-rc.d 2>/dev/null`" ]; then
|
||||
invoke-rc.d idempiere start || exit 0
|
||||
else
|
||||
/etc/init.d/idempiere start || exit 0
|
||||
fi
|
||||
fi
|
||||
|
||||
echo "Executing Post-install steps..."
|
||||
|
||||
if [ "$MODE" = "install" ]
|
||||
then
|
||||
if `grep -q ^idempiere: /etc/group`
|
||||
then
|
||||
echo ""
|
||||
else
|
||||
/usr/sbin/groupadd idempiere
|
||||
fi
|
||||
id idempiere > /dev/null 2>&1
|
||||
status=$?
|
||||
if test $status -eq 0
|
||||
then
|
||||
groups idempiere | grep idempiere > /dev/null
|
||||
status=$?
|
||||
if test $status != 0
|
||||
then
|
||||
/usr/sbin/usermod -G idempiere idempiere
|
||||
fi
|
||||
else
|
||||
/usr/sbin/useradd -g idempiere -d /opt/idempiere-server -s /bin/bash idempiere
|
||||
fi
|
||||
|
||||
# End MODE=install
|
||||
fi
|
||||
|
||||
if [ "$MODE" = "install" ]
|
||||
then
|
||||
# Start Menu icons
|
||||
|
||||
mergefile()
|
||||
{
|
||||
MENUFILE="$1"
|
||||
|
||||
if [ -z "$MENUFILE" ]
|
||||
then
|
||||
return
|
||||
fi
|
||||
|
||||
TFILE="$(mktemp)" || TFILE="/tmp/idempiereapplications.tmp"
|
||||
(sed -n '1,/<\/Menu>/p' "$MENUFILE" ; cat /opt/idempiere-server/utils/unix/idempiere-merge-debian.menu ; sed -n '1,/<\/Menu>/!p' "$MENUFILE" ) > "$TFILE"
|
||||
cp -f "$TFILE" "$MENUFILE"
|
||||
rm -f "$TFILE"
|
||||
}
|
||||
|
||||
if [ -f /etc/xdg/menus/gnome-applications.menu ]
|
||||
then
|
||||
mergefile /etc/xdg/menus/gnome-applications.menu
|
||||
fi
|
||||
if [ -f /etc/xdg/menus/kde-applications.menu ]
|
||||
then
|
||||
mergefile /etc/xdg/menus/kde-applications.menu
|
||||
fi
|
||||
if [ -f /etc/xdg/menus/applications.menu ]
|
||||
then
|
||||
mergefile /etc/xdg/menus/applications.menu
|
||||
fi
|
||||
|
||||
# End MODE=install
|
||||
fi
|
||||
|
||||
/bin/chown -R idempiere:idempiere /opt/idempiere-server
|
||||
/bin/chown idempiere:idempiere /etc/default/idempiere
|
||||
/bin/chown idempiere:idempiere /etc/init.d/idempiere
|
||||
/bin/chown idempiere:idempiere /etc/xdg/menus/idempiere.menu
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-backup.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-gotoonlineforum.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-homepage.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-readdocumentation.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-restore.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-startserver.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/applications/idempiere-webclient.desktop
|
||||
/bin/chown idempiere:idempiere /usr/share/desktop-directories/idempiere.directory
|
||||
/bin/chown idempiere:idempiere /usr/share/desktop-directories/idempiere-gethelp.directory
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere-backup.png
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere-gethelp.png
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere-gotoonlineforum.png
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere.png
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere-readdocumentation.png
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere-restore.png
|
||||
/bin/chown idempiere:idempiere /usr/share/pixmaps/idempiere-start.png
|
||||
|
||||
CONFIGURATION=/etc/default/idempiere
|
||||
[ -f "$CONFIGURATION" ] && . "$CONFIGURATION"
|
||||
|
||||
if [ "$CONFIGURE_RUN" != "true" ]
|
||||
then
|
||||
echo "You must run '/etc/init.d/idempiere configure' as the root user to configure the application."
|
||||
echo
|
||||
fi
|
||||
|
||||
exit 0
|
|
@ -0,0 +1,70 @@
|
|||
#!/bin/sh
|
||||
|
||||
case "$1" in
|
||||
remove|purge)
|
||||
;;
|
||||
*)
|
||||
exit 0
|
||||
;;
|
||||
esac
|
||||
|
||||
if [ "$1" = "purge" ] ; then
|
||||
update-rc.d idempiere remove >/dev/null || exit 0
|
||||
fi
|
||||
|
||||
|
||||
case "$1" in
|
||||
purge)
|
||||
rm -fr /opt/idempiere-server
|
||||
# rm -fr /etc/default/idempiere
|
||||
# rm -fr /etc/init.d/idempiere
|
||||
# rm -fr /etc/xdg/menus/idempiere.menu
|
||||
rm -fr /usr/share/desktop-directories/idempiere-gethelp.directory
|
||||
rm -fr /usr/share/desktop-directories/idempiere.directory
|
||||
rm -fr /usr/share/pixmaps/idempiere-restore.png
|
||||
rm -fr /usr/share/pixmaps/idempiere.png
|
||||
rm -fr /usr/share/pixmaps/idempiere-gethelp.png
|
||||
rm -fr /usr/share/pixmaps/idempiere-gotoonlineforum.png
|
||||
rm -fr /usr/share/pixmaps/idempiere-backup.png
|
||||
rm -fr /usr/share/pixmaps/idempiere-start.png
|
||||
rm -fr /usr/share/pixmaps/idempiere-readdocumentation.png
|
||||
rm -fr /usr/share/applications/idempiere-gotoonlineforum.desktop
|
||||
rm -fr /usr/share/applications/idempiere-homepage.desktop
|
||||
rm -fr /usr/share/applications/idempiere-webclient.desktop
|
||||
rm -fr /usr/share/applications/idempiere-readdocumentation.desktop
|
||||
rm -fr /usr/share/applications/idempiere-restore.desktop
|
||||
rm -fr /usr/share/applications/idempiere-startserver.desktop
|
||||
rm -fr /usr/share/applications/idempiere-backup.desktop
|
||||
;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
|
||||
mergefile()
|
||||
{
|
||||
MENUFILE="$1"
|
||||
if [ -z "$MENUFILE" ]
|
||||
then
|
||||
return
|
||||
fi
|
||||
|
||||
TFILE="$(mktemp)" || TFILE="/tmp/idempiereapplications.tmp"
|
||||
sed -n '/<\!\-- iDempiere \-->/,/<\!\-- End of iDempiere \-->/!p' "$MENUFILE" > "$TFILE"
|
||||
cp -f "$TFILE" "$MENUFILE"
|
||||
rm -f "$TFILE"
|
||||
}
|
||||
|
||||
if [ -f /etc/xdg/menus/gnome-applications.menu ]
|
||||
then
|
||||
mergefile /etc/xdg/menus/gnome-applications.menu
|
||||
fi
|
||||
if [ -f /etc/xdg/menus/kde-applications.menu ]
|
||||
then
|
||||
mergefile /etc/xdg/menus/kde-applications.menu
|
||||
fi
|
||||
if [ -f /etc/xdg/menus/applications.menu ]
|
||||
then
|
||||
mergefile /etc/xdg/menus/applications.menu
|
||||
fi
|
||||
|
||||
exit 0
|
|
@ -0,0 +1,48 @@
|
|||
#!/bin/sh
|
||||
|
||||
if [ "$1" != "install" -o -n "$2" ]
|
||||
then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# User must be root
|
||||
|
||||
if [ $(id -u) != "0" ]
|
||||
then
|
||||
echo "You must be the root to install the software" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# IDEMPIERE_HOME must be unset
|
||||
if `env | grep -q IDEMPIERE_HOME`
|
||||
then
|
||||
unset IDEMPIERE_HOME
|
||||
fi
|
||||
|
||||
# Check for sufficient diskspace
|
||||
if [ -d /opt/idempiere-server ]
|
||||
then
|
||||
diskspace=`df -k /opt/idempiere-server | grep % | tr -s " " | cut -d" " -f4 | tail -1`
|
||||
diskspace=`expr $diskspace / 1024`
|
||||
if [ $diskspace -lt 1024 ]
|
||||
then
|
||||
echo "You have insufficient diskspace in the destination directory (/opt/idempiere-server)
|
||||
to install idempiere The installation requires at
|
||||
least 1 GB free on this disk."
|
||||
exit 1
|
||||
fi
|
||||
else
|
||||
diskspace=`df -k /usr/lib | grep % | tr -s " " | cut -d" " -f4 | tail -1`
|
||||
diskspace=`expr $diskspace / 1024`
|
||||
if [ $diskspace -lt 1024 ]
|
||||
then
|
||||
echo "You have insufficient diskspace in the destination directory (/usr/lib) to
|
||||
install idempiere. The installation requires at
|
||||
least 1 GB free on this disk."
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Don't fail, even on sysctl errors
|
||||
exit 0
|
||||
|
|
@ -0,0 +1,17 @@
|
|||
#!/bin/sh
|
||||
|
||||
|
||||
if [ "$1" != "remove" ]
|
||||
then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [ -x "/etc/init.d/idempiere" ]; then
|
||||
if [ -x "`which invoke-rc.d 2>/dev/null`" ]; then
|
||||
invoke-rc.d idempiere stop || exit 0
|
||||
else
|
||||
/etc/init.d/idempiere stop || exit 0
|
||||
fi
|
||||
fi
|
||||
|
||||
exit 0
|
|
@ -0,0 +1,3 @@
|
|||
#
|
||||
# Please run "/etc/init.d/idempiere configure" to configure iDempiere.
|
||||
#
|
|
@ -0,0 +1,736 @@
|
|||
#!/bin/bash
|
||||
#
|
||||
|
||||
### BEGIN INIT INFO
|
||||
# Provides: idempiere
|
||||
# Required-Start: postgresql
|
||||
# Required-Stop: postgresql
|
||||
# Default-Start: 2 3 4 5
|
||||
# Default-Stop: 1
|
||||
# Short-Description: iDempiere server
|
||||
# Description: Provides iDempiere ERP-CRM Server startup and shutdown script. Requires PostgreSQL server.
|
||||
# FileTarget: /etc/init.d/idempiere
|
||||
# FileOwner: root.root
|
||||
# FilePerms: 0755
|
||||
#
|
||||
# chkconfig: 2345 97 06
|
||||
### END INIT INFO
|
||||
|
||||
# processname: idempiere
|
||||
# Red Hat or SuSE config: /etc/sysconfig/idempiere
|
||||
# Debian or Ubuntu config: /etc/default/idempiere
|
||||
|
||||
# Source function library
|
||||
if [ -f /lib/lsb/init-functions ]
|
||||
then
|
||||
. /lib/lsb/init-functions
|
||||
elif [ -f /etc/init.d/functions ]
|
||||
then
|
||||
. /etc/init.d/functions
|
||||
fi
|
||||
|
||||
# Set path if path not set (if called from /etc/rc)
|
||||
case $PATH in
|
||||
"") PATH=/bin:/usr/bin:/sbin:/etc
|
||||
export PATH ;;
|
||||
esac
|
||||
|
||||
# initialization
|
||||
# adjust these variables to your environment
|
||||
IDEMPIERE_USER=idempiere
|
||||
IDEMPIERE_HOME=/opt/idempiere-server
|
||||
JAVA_HOME=`ls -r /usr/lib/jvm/java-[67]-openjdk*/bin/javac | head -1`
|
||||
JAVA_HOME=`dirname $JAVA_HOME`
|
||||
JAVA_HOME=`dirname $JAVA_HOME`
|
||||
SU=su
|
||||
export IDEMPIERE_HOME
|
||||
|
||||
if [ $(id -u) != "0" ]
|
||||
then
|
||||
echo "You must be root to run the configure script. Login as root and then run the configure script."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
RETVAL=0
|
||||
IDEMPIERESTATUS=
|
||||
MAXSECONDS=120 # max wait 2 minutes
|
||||
SLEEPSECONDS=2
|
||||
MAXITERATIONS=`expr $MAXSECONDS / $SLEEPSECONDS`
|
||||
|
||||
CONFIG_NAME=idempiere
|
||||
CONFIGURATION="/etc/sysconfig/$CONFIG_NAME"
|
||||
if [ -f /etc/redhat-release ]
|
||||
then
|
||||
. /etc/init.d/functions
|
||||
|
||||
init_status()
|
||||
{
|
||||
return 0
|
||||
}
|
||||
exit_status()
|
||||
{
|
||||
exit $?
|
||||
}
|
||||
success_status()
|
||||
{
|
||||
success
|
||||
echo
|
||||
}
|
||||
failure_status()
|
||||
{
|
||||
failure $?
|
||||
echo
|
||||
}
|
||||
|
||||
elif [ -f /etc/SuSE-release ]
|
||||
then
|
||||
. /etc/rc.status
|
||||
|
||||
init_status()
|
||||
{
|
||||
rc_reset
|
||||
}
|
||||
success_status()
|
||||
{
|
||||
echo "OK"
|
||||
return 0
|
||||
}
|
||||
failure_status()
|
||||
{
|
||||
echo "Failed"
|
||||
return 1
|
||||
}
|
||||
exit_status()
|
||||
{
|
||||
exit $?
|
||||
}
|
||||
|
||||
else
|
||||
if [ -d /etc/default ]
|
||||
then
|
||||
CONFIGURATION="/etc/default/$CONFIG_NAME"
|
||||
fi
|
||||
|
||||
init_status()
|
||||
{
|
||||
return 0
|
||||
}
|
||||
|
||||
success_status()
|
||||
{
|
||||
echo "OK"
|
||||
return 0
|
||||
}
|
||||
|
||||
failure_status()
|
||||
{
|
||||
echo "Failed"
|
||||
return 0
|
||||
}
|
||||
|
||||
exit_status()
|
||||
{
|
||||
exit $?
|
||||
}
|
||||
fi
|
||||
|
||||
# Source configuration
|
||||
|
||||
[ -f "$CONFIGURATION" ] && . "$CONFIGURATION"
|
||||
|
||||
init_status
|
||||
|
||||
#
|
||||
# if_fail()
|
||||
#
|
||||
# Evaluates return codes. If 0, prints "OK", if 1, prints "Failed"
|
||||
# and exits. If 2, status is "already done" and nothing is printed.
|
||||
# The rest of the functions in here all honor this convention.
|
||||
#
|
||||
if_fail()
|
||||
{
|
||||
RC="$1"
|
||||
REASON="$2"
|
||||
if [ "$RC" = "0" ]
|
||||
then
|
||||
return
|
||||
elif [ "$RC" = "2" ]
|
||||
then
|
||||
return
|
||||
fi
|
||||
failure_status "${REASON}"
|
||||
exit 1
|
||||
}
|
||||
|
||||
#
|
||||
# write_sysconfig()
|
||||
#
|
||||
# Writes the system configuration
|
||||
#
|
||||
write_sysconfig()
|
||||
{
|
||||
cat >"$CONFIGURATION" <<EOF
|
||||
|
||||
#This is a configuration file for automatic starting of the iDempiere
|
||||
#Server at system startup. It is generated by running
|
||||
#'/etc/init.d/idempiere configure'.Please use that method to modify this
|
||||
#file
|
||||
|
||||
# RUN_AT_STARTUP:'true' means to load the Server at system boot.
|
||||
RUN_AT_STARTUP=${RUN_AT_STARTUP:-false}
|
||||
|
||||
# Configuration : Check whether configure has been done or not
|
||||
CONFIGURE_RUN=${CONFIGURE_RUN}
|
||||
|
||||
EOF
|
||||
|
||||
if [ $? != 0 ]
|
||||
then
|
||||
return 1
|
||||
fi
|
||||
return 0
|
||||
}
|
||||
|
||||
# configure_perform()
|
||||
# Create idempiereEnv.properties
|
||||
# RUN_silentsetup.sh
|
||||
# Import database
|
||||
configure_perform()
|
||||
{
|
||||
cp ${IDEMPIERE_HOME}/idempiereEnvTemplate.properties ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^IDEMPIERE_HOME=.*:IDEMPIERE_HOME=${IDEMPIERE_HOME}:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^JAVA_HOME=.*:JAVA_HOME=${JAVA_HOME}:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^ADEMPIERE_DB_PASSWORD=.*:ADEMPIERE_DB_PASSWORD=${ADEMPIERE_DB_PASSWORD}:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^ADEMPIERE_DB_SYSTEM=.*:ADEMPIERE_DB_SYSTEM=${ADEMPIERE_DB_SYSTEM}:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^ADEMPIERE_WEB_PORT=.*:ADEMPIERE_WEB_PORT=${ADEMPIERE_WEB_PORT}:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^ADEMPIERE_SSL_PORT=.*:ADEMPIERE_SSL_PORT=${ADEMPIERE_SSL_PORT}:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^ADEMPIERE_APPS_SERVER=.*:ADEMPIERE_APPS_SERVER=0.0.0.0:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
sed -i "s:^ADEMPIERE_KEYSTORE=.*:ADEMPIERE_KEYSTORE=${IDEMPIERE_HOME}/keystore/myKeystore:" ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
chown idempiere:idempiere ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
chmod 600 ${IDEMPIERE_HOME}/idempiereEnv.properties
|
||||
|
||||
sed -i "s/:8080/:${ADEMPIERE_WEB_PORT}/g" /usr/share/applications/idempiere-homepage.desktop
|
||||
sed -i "s/:8443/:${ADEMPIERE_SSL_PORT}/g" /usr/share/applications/idempiere-webclient.desktop
|
||||
|
||||
if [ -f ${IDEMPIERE_HOME}/console-setup.sh ]
|
||||
then
|
||||
echo -n "Deploying iDempiere ERP server..."
|
||||
$SU ${IDEMPIERE_USER} -c "cd ${IDEMPIERE_HOME}; ./console-setup.sh" <<!
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
!
|
||||
echo "Done"
|
||||
fi
|
||||
grep ${ADEMPIERE_WEB_PORT} ${IDEMPIERE_HOME}/plugins/org.adempiere.tomcat.config_2.0.0/META-INF/tomcat/server.xml > /dev/null 2>&1
|
||||
if [ $? -ne 0 ]
|
||||
then
|
||||
echo "Error deploying iDempiere, please verify and try again"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ "x${ADEMPIERE_DB_SYSTEM}" = "x^TryLocalConnection^" ]
|
||||
then
|
||||
# recreate idempiere user from here as the RUN_ImportIdempiere requires it
|
||||
$SU postgres -c "dropdb -U postgres idempiere" # > /dev/null 2>&1
|
||||
$SU postgres -c "dropuser -U postgres idempiere" # > /dev/null 2>&1
|
||||
$SU postgres -c "psql -U postgres -c \"CREATE ROLE adempiere SUPERUSER LOGIN PASSWORD '${ADEMPIERE_DB_PASSWORD}'\"" # > /dev/null 2>&1
|
||||
fi
|
||||
|
||||
if [ -f ${IDEMPIERE_HOME}/utils/RUN_ImportIdempiere.sh ]
|
||||
then
|
||||
echo -n "Importing seed database..."
|
||||
$SU ${IDEMPIERE_USER} -c "cd ${IDEMPIERE_HOME}/utils; ( echo "" | ./RUN_ImportIdempiere.sh )" # > /dev/null 2>&1
|
||||
echo "Done"
|
||||
fi
|
||||
$SU ${IDEMPIERE_USER} -c "export PGPASSWORD=${ADEMPIERE_DB_PASSWORD}; psql -d idempiere -U adempiere -h localhost -p 5432 -c ''" > /dev/null 2>&1
|
||||
if [ $? -ne 0 ]
|
||||
then
|
||||
echo "Cannot connect to idempiere database, please verify and try again"
|
||||
exit 1
|
||||
fi
|
||||
$SU ${IDEMPIERE_USER} -c "export PGPASSWORD=${ADEMPIERE_DB_PASSWORD}; psql -d idempiere -U adempiere -h localhost -p 5432 -c 'select count(*) from ad_system' 2>&1 | grep '1$'" > /dev/null 2>&1
|
||||
if [ $? -ne 0 ]
|
||||
then
|
||||
echo "Database not imported correctly, please verify and try again"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
chmod 700 ${IDEMPIERE_HOME}/utils/myEnvironment.*
|
||||
|
||||
echo "Installation Completed Successfully."
|
||||
|
||||
return 0
|
||||
}
|
||||
|
||||
checkportused()
|
||||
{
|
||||
port=`netstat -n --tcp --listen | grep :$1 | awk '{print $4}' | cut -d':' -f2`
|
||||
if [ "$port" = "$1" ]
|
||||
then
|
||||
return 0 # Used
|
||||
else
|
||||
return 1 # Not Used
|
||||
fi
|
||||
}
|
||||
|
||||
#
|
||||
#configure_ask()
|
||||
#
|
||||
# Ask configuration questions,setting the variables.
|
||||
#
|
||||
configure_ask()
|
||||
{
|
||||
cat <<EOF
|
||||
|
||||
iDempiere ERP Server Configuration
|
||||
-------------------------------------------------
|
||||
This will configure on-boot properties of iDempiere ERP Server.
|
||||
The following questions will determine whether the database should
|
||||
be starting upon system boot, the ports it will use, and the passwords that
|
||||
will be used for database accounts. Press <Enter> to accept the defaults.
|
||||
Ctrl-C will abort.
|
||||
|
||||
EOF
|
||||
# TODO: ask for certificate data (or integrate with openssl certificate)
|
||||
# TODO: ask for mail server settings
|
||||
# TODO: ask for postgres port (and perhaps machine if it's remote)
|
||||
|
||||
# Check not configurable tomcat ports (i.e. 8005, 8009)
|
||||
for TOMCATPORT in 8005 8009
|
||||
do
|
||||
if checkportused "$TOMCATPORT"
|
||||
then
|
||||
echo Port $TOMCATPORT is required by iDempiere ERP server and it appears to be in use by another application.\
|
||||
Please fix the problem and try again.
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
|
||||
#get the http port value
|
||||
while :
|
||||
do
|
||||
while [ 1 ]
|
||||
do
|
||||
echo -n Specify the HTTP port that will be used for iDempiere server [8080]:
|
||||
read LINE
|
||||
if [ -z $LINE ]
|
||||
then
|
||||
LINE=8080
|
||||
fi
|
||||
if checkportused "$LINE"
|
||||
then
|
||||
echo Port $port appears to be in use by another application.\
|
||||
Please specify a different port.
|
||||
else
|
||||
break;
|
||||
fi
|
||||
done
|
||||
|
||||
case "$LINE" in
|
||||
"")
|
||||
break
|
||||
;;
|
||||
*[^0-9]*)
|
||||
echo "Invalid http port: $LINE"
|
||||
;;
|
||||
*)
|
||||
ADEMPIERE_WEB_PORT=$LINE
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
#get the https port value
|
||||
while :
|
||||
do
|
||||
while [ 1 ]
|
||||
do
|
||||
echo -n Specify the HTTPS port that will be used for iDempiere server [8443]:
|
||||
read LINE
|
||||
if [ -z $LINE ]
|
||||
then
|
||||
LINE=8443
|
||||
fi
|
||||
if checkportused "$LINE"
|
||||
then
|
||||
echo Port $port appears to be in use by another application.\
|
||||
Please specify a different port.
|
||||
else
|
||||
break;
|
||||
fi
|
||||
done
|
||||
|
||||
case "$LINE" in
|
||||
"")
|
||||
break
|
||||
;;
|
||||
*[^0-9]*)
|
||||
echo "Invalid https port: $LINE"
|
||||
;;
|
||||
*)
|
||||
ADEMPIERE_SSL_PORT=$LINE
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
#get the idempiere database password
|
||||
while :
|
||||
do
|
||||
echo -n "Specify a password to be used for adempiere database account:"
|
||||
while [ 1 ]
|
||||
do
|
||||
stty -echo > /dev/null 2>&1
|
||||
temp=`echo $IFS`
|
||||
export IFS="\n"
|
||||
while [ 1 ]
|
||||
do
|
||||
read LINE
|
||||
while [ -z "$LINE" ]
|
||||
do
|
||||
echo
|
||||
echo -n "Password can't be null. Enter password:"
|
||||
read LINE
|
||||
done
|
||||
|
||||
result=`expr index "$LINE" [\'\"]`
|
||||
if [ $result != 0 ];
|
||||
then
|
||||
echo
|
||||
echo -n "The password you entered contains invalid characters. Enter password:"
|
||||
else
|
||||
break
|
||||
fi
|
||||
done
|
||||
echo
|
||||
echo -n "Confirm the password:"
|
||||
read LINE1
|
||||
echo
|
||||
if [ "$LINE" != "$LINE1" ];
|
||||
then
|
||||
echo
|
||||
echo -n "Passwords do not match. Enter the password:"
|
||||
else
|
||||
break
|
||||
fi
|
||||
done
|
||||
stty echo > /dev/null 2>&1
|
||||
ADEMPIERE_DB_PASSWORD=$LINE
|
||||
export IFS=$temp
|
||||
break;
|
||||
done
|
||||
|
||||
#get the postgres database password
|
||||
while :
|
||||
do
|
||||
echo -n "Specify the password of the user postgres on postgres database
|
||||
(if empty then local connection will be tried):"
|
||||
while [ 1 ]
|
||||
do
|
||||
stty -echo > /dev/null 2>&1
|
||||
temp=`echo $IFS`
|
||||
export IFS="\n"
|
||||
while [ 1 ]
|
||||
do
|
||||
read LINE
|
||||
if [ -z "$LINE" ]
|
||||
then
|
||||
break
|
||||
fi
|
||||
|
||||
result=`expr index "$LINE" [\'\"]`
|
||||
if [ $result != 0 ];
|
||||
then
|
||||
echo
|
||||
echo -n "The password you entered contains invalid characters. Enter password:"
|
||||
else
|
||||
break
|
||||
fi
|
||||
done
|
||||
echo
|
||||
if [ -z "$LINE" ]
|
||||
then
|
||||
# Empty postgres password verify connection with local postgres user
|
||||
$SU postgres -c "psql -U postgres -c ''"
|
||||
if [ $? -eq 0 ]
|
||||
then
|
||||
break
|
||||
fi
|
||||
echo -n "Could not connect locally with user postgres.
|
||||
NOTE: You can verify pg_hba.conf to check if this line is enabled
|
||||
local all postgres ident
|
||||
Enter postgres password:"
|
||||
else
|
||||
PGPASSWORD=$LINE
|
||||
export PGPASSWORD
|
||||
psql -U postgres -d template1 -h localhost -p 5432 -c ''
|
||||
if [ $? -eq 0 ]
|
||||
then
|
||||
break
|
||||
fi
|
||||
echo -n "Could not connect with user postgres to database template with such password.
|
||||
NOTE: You can check the file pg_hba.conf to validate that connection is allowed,
|
||||
or check that postgresql server allows tcp/ip connections on port 5432
|
||||
or check that user postgres database password is correctly set.
|
||||
Enter postgres password:"
|
||||
fi
|
||||
done
|
||||
stty echo > /dev/null 2>&1
|
||||
if [ -z "$LINE" ]
|
||||
then
|
||||
LINE="^TryLocalConnection^"
|
||||
fi
|
||||
ADEMPIERE_DB_SYSTEM=$LINE
|
||||
export IFS=$temp
|
||||
break;
|
||||
done
|
||||
|
||||
while :
|
||||
do
|
||||
if [ "${RUN_AT_STARTUP}" = "true" ]
|
||||
then
|
||||
CUR=y
|
||||
else
|
||||
CUR=n
|
||||
fi
|
||||
echo
|
||||
echo -n "Do you want iDempiere ERP Server to be started on boot (y/n) [y]:"
|
||||
read LINE
|
||||
if [ -z $LINE ]
|
||||
then
|
||||
RUN_AT_STARTUP=true
|
||||
fi
|
||||
echo
|
||||
case "$LINE" in
|
||||
"")
|
||||
break
|
||||
;;
|
||||
y|Y)
|
||||
RUN_AT_STARTUP=true
|
||||
break
|
||||
;;
|
||||
n|N)
|
||||
RUN_AT_STARTUP=false
|
||||
break
|
||||
;;
|
||||
*)
|
||||
echo "Invalid response: $LINE " >&2
|
||||
break
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
getidempierestatus() {
|
||||
IDEMPIERESTATUSSTRING=$(ps ax | grep -v grep | grep ${IDEMPIERE_HOME})
|
||||
echo $IDEMPIERESTATUSSTRING | grep -q ${IDEMPIERE_HOME}
|
||||
IDEMPIERESTATUS=$?
|
||||
}
|
||||
|
||||
configure()
|
||||
{
|
||||
if [ "${CONFIGURE_RUN}" = "true" ]
|
||||
then
|
||||
echo "iDempiere is already configured"
|
||||
exit 1
|
||||
fi
|
||||
configure_ask
|
||||
configure_perform
|
||||
CONFIGURE_RUN=true
|
||||
write_sysconfig
|
||||
echo To access the iDempiere Server Home Page, start the server with '/etc/init.d/idempiere start'
|
||||
echo and then go to \"http://127.0.0.1:${ADEMPIERE_WEB_PORT}\"
|
||||
|
||||
}
|
||||
|
||||
start () {
|
||||
|
||||
if [ "${CONFIGURE_RUN}" != "true" ]
|
||||
then
|
||||
echo "iDempiere is not configured. You must run
|
||||
'/etc/init.d/idempiere configure' as the root user to configure the server."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
getidempierestatus
|
||||
if [ $IDEMPIERESTATUS -eq 0 ] ; then
|
||||
echo "iDempiere is already running"
|
||||
return 1
|
||||
fi
|
||||
echo -n "Starting iDempiere ERP: "
|
||||
export LOGFILE=$IDEMPIERE_HOME/log/idempiere_`date +%Y%m%d%H%M%S`.log
|
||||
$SU ${IDEMPIERE_USER} -c "mkdir -p $IDEMPIERE_HOME/log"
|
||||
$SU ${IDEMPIERE_USER} -c "cd $IDEMPIERE_HOME;$IDEMPIERE_HOME/idempiere-server.sh &> $LOGFILE &"
|
||||
RETVAL=$?
|
||||
if [ $RETVAL -eq 0 ] ; then
|
||||
# wait for server to be confirmed as started in logfile
|
||||
STATUSTEST=0
|
||||
ITERATIONS=0
|
||||
while [ $STATUSTEST -eq 0 ] ; do
|
||||
sleep $SLEEPSECONDS
|
||||
tail -n 9 $LOGFILE | grep -q '.*WebUIServlet.*started successfully.*' && STATUSTEST=1
|
||||
echo -n "."
|
||||
ITERATIONS=`expr $ITERATIONS + 1`
|
||||
if [ $ITERATIONS -gt $MAXITERATIONS ]
|
||||
then
|
||||
break
|
||||
fi
|
||||
done
|
||||
if [ $STATUSTEST -eq 0 ]
|
||||
then
|
||||
log_warning_msg "Service hasn't started within the timeout allowed, please review file $LOGFILE to see the status of the service"
|
||||
else
|
||||
log_success_msg "Service started"
|
||||
fi
|
||||
echo
|
||||
else
|
||||
log_failure_msg "Service not started"
|
||||
echo
|
||||
fi
|
||||
RETVAL=$?
|
||||
return $RETVAL
|
||||
}
|
||||
|
||||
stop () {
|
||||
|
||||
if [ "${CONFIGURE_RUN}" != "true" ]
|
||||
then
|
||||
echo "iDempiere is not configured. You must run
|
||||
'/etc/init.d/idempiere configure' as the root user to configure the server."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
getidempierestatus
|
||||
if [ $IDEMPIERESTATUS -ne 0 ] ; then
|
||||
echo "iDempiere is already stopped"
|
||||
return 1
|
||||
fi
|
||||
echo -n "Stopping iDempiere ERP: "
|
||||
cd $IDEMPIERE_HOME/utils
|
||||
log_warning_msg "Trying direct kill with signal -15"
|
||||
# try direct kill with signal 15, then signal 9
|
||||
kill -15 -`ps ax o pgid,command | grep -v grep | grep $IDEMPIERE_HOME | sed -e 's/^ *//g' | cut -f 1 -d " " | sort -u`
|
||||
sleep 5
|
||||
getidempierestatus
|
||||
if [ $IDEMPIERESTATUS -ne 0 ] ; then
|
||||
log_success_msg "Service stopped with kill -15"
|
||||
else
|
||||
echo "Trying direct kill with signal -9"
|
||||
kill -9 -`ps ax o pgid,command | grep -v grep | grep $IDEMPIERE_HOME | sed -e 's/^ *//g' | cut -f 1 -d " " | sort -u`
|
||||
sleep 5
|
||||
getidempierestatus
|
||||
if [ $IDEMPIERESTATUS -ne 0 ] ; then
|
||||
log_success_msg "Service stopped with kill -9"
|
||||
else
|
||||
log_warning_msg "Service hasn't stopped"
|
||||
fi
|
||||
fi
|
||||
return $RETVAL
|
||||
}
|
||||
|
||||
restart () {
|
||||
stop
|
||||
sleep $SLEEPSECONDS
|
||||
start
|
||||
}
|
||||
|
||||
condrestart () {
|
||||
getidempierestatus
|
||||
if [ $IDEMPIERESTATUS -eq 0 ] ; then
|
||||
restart
|
||||
fi
|
||||
}
|
||||
|
||||
dostatus () {
|
||||
getidempierestatus
|
||||
if [ $IDEMPIERESTATUS -eq 0 ] ; then
|
||||
echo
|
||||
echo "iDempiere is running:"
|
||||
ps ax | grep -v grep | grep ${IDEMPIERE_HOME} | sed 's/^[[:space:]]*\([[:digit:]]*\).*:[[:digit:]][[:digit:]][[:space:]]\(.*\)/\1 \2/'
|
||||
echo
|
||||
else
|
||||
echo "iDempiere is stopped"
|
||||
fi
|
||||
}
|
||||
|
||||
case "$1" in
|
||||
start)
|
||||
if test -f "$CONFIGURATION"
|
||||
then
|
||||
if test "${RUN_AT_STARTUP}" != "true"
|
||||
then
|
||||
exit 0
|
||||
fi
|
||||
else
|
||||
echo "iDempiere is not configured. You must run
|
||||
'/etc/init.d/idempiere configure' as the root user to configure the server."
|
||||
exit 0
|
||||
fi
|
||||
start
|
||||
;;
|
||||
configure)
|
||||
configure
|
||||
;;
|
||||
stop)
|
||||
stop
|
||||
;;
|
||||
restart|reload|force-reload)
|
||||
restart
|
||||
;;
|
||||
condrestart)
|
||||
condrestart
|
||||
;;
|
||||
status)
|
||||
dostatus
|
||||
;;
|
||||
enable)
|
||||
if test -f "$CONFIGURATION"
|
||||
then
|
||||
RUN_AT_STARTUP=true
|
||||
write_sysconfig
|
||||
else
|
||||
echo "iDempiere is not configured. You must run
|
||||
'/etc/init.d/idempiere configure' as the root user to configure the server."
|
||||
exit 0
|
||||
fi
|
||||
;;
|
||||
disable)
|
||||
if test -f "$CONFIGURATION"
|
||||
then
|
||||
RUN_AT_STARTUP=false
|
||||
write_sysconfig
|
||||
else
|
||||
echo "iDempiere is not configured. You must run
|
||||
'/etc/init.d/idempiere configure' as the root user to configure the server."
|
||||
exit 0
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
echo $"Usage: $0 {start|stop|restart|force-reload|configure|status|enable|disable}"
|
||||
exit 1
|
||||
|
||||
esac
|
||||
|
||||
exit 0
|
|
@ -0,0 +1,23 @@
|
|||
<!-- iDempiere ERP -->
|
||||
<Menu>
|
||||
<Name>iDempiere ERP</Name>
|
||||
<Directory>idempiere.directory</Directory>
|
||||
<NotDeleted/>
|
||||
<Include>
|
||||
<Filename>idempiere-startserver.desktop</Filename>
|
||||
<Filename>idempiere-homepage.desktop</Filename>
|
||||
<Filename>idempiere-webclient.desktop</Filename>
|
||||
<Filename>idempiere-backup.desktop</Filename>
|
||||
<Filename>idempiere-restore.desktop</Filename>
|
||||
</Include>
|
||||
<Menu>
|
||||
<Name>Get Help</Name>
|
||||
<Directory>idempiere-gethelp.directory</Directory>
|
||||
<NotDeleted/>
|
||||
<Include>
|
||||
<Filename>idempiere-gotoonlineforum.desktop</Filename>
|
||||
<Filename>idempiere-readdocumentation.desktop</Filename>
|
||||
</Include>
|
||||
</Menu>
|
||||
</Menu>
|
||||
<!-- End of iDempiere -->
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Exec=gksudo "su -c idempiere '/opt/idempiere-server/utils/RUN_DBExport.sh'"
|
||||
Terminal=true
|
||||
MultipleArgs=true
|
||||
Type=Application
|
||||
Categories=Applications;
|
||||
Icon=idempiere-backup.png
|
||||
Encoding=UTF-8
|
||||
Name=Backup Database
|
||||
Name[es]=Copia de Seguridad de Base de Datos
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Terminal=false
|
||||
MultipleArgs=true
|
||||
Type=Link
|
||||
URL=https://groups.google.com/forum/?fromgroups#!forum/idempiere
|
||||
Categories=Applications;
|
||||
Icon=idempiere-gotoonlineforum.png
|
||||
Encoding=UTF-8
|
||||
Name=Go To Online Forum
|
||||
Name[es]=Ir a Foro en Línea
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Terminal=false
|
||||
MultipleArgs=true
|
||||
Type=Link
|
||||
URL=http://localhost:8080
|
||||
Categories=Applications;
|
||||
Icon=idempiere.png
|
||||
Encoding=UTF-8
|
||||
Name=iDempiere Homepage
|
||||
Name[es]=Página Principal iDempiere
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Terminal=false
|
||||
MultipleArgs=true
|
||||
Type=Link
|
||||
URL=http://wiki.idempiere.org
|
||||
Categories=Applications;
|
||||
Icon=idempiere-readdocumentation.png
|
||||
Encoding=UTF-8
|
||||
Name=Read Documentation
|
||||
Name[es]=Leer Documentación
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Exec=gksudo "su -c idempiere '/opt/idempiere-server/utils/RUN_DBRestore.sh'"
|
||||
Terminal=true
|
||||
MultipleArgs=true
|
||||
Type=Application
|
||||
Categories=Applications;
|
||||
Icon=idempiere-restore.png
|
||||
Encoding=UTF-8
|
||||
Name=Restore Database
|
||||
Name[es]=Restaurar Base de Datos
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Exec=gksudo "su -c idempiere '/opt/idempiere-server/idempiere-server.sh'"
|
||||
Terminal=true
|
||||
MultipleArgs=true
|
||||
Type=Application
|
||||
Categories=Applications;
|
||||
Icon=idempiere-start.png
|
||||
Encoding=UTF-8
|
||||
Name=Start Server
|
||||
Name[es]=Iniciar Servidor
|
|
@ -0,0 +1,10 @@
|
|||
[Desktop Entry]
|
||||
Terminal=false
|
||||
MultipleArgs=true
|
||||
Type=Link
|
||||
URL=https://localhost:8443/webui
|
||||
Categories=Applications;
|
||||
Icon=idempiere-gotoonlineforum.png
|
||||
Encoding=UTF-8
|
||||
Name=iDempiere Web Client
|
||||
Name[es]=Cliente Web iDempiere
|
|
@ -0,0 +1,6 @@
|
|||
[Desktop Entry]
|
||||
Icon=idempiere-gethelp.png
|
||||
Type=Directory
|
||||
Encoding=UTF-8
|
||||
Name=Get Help
|
||||
Name[es]=Obtener Ayuda
|
|
@ -0,0 +1,7 @@
|
|||
[Desktop Entry]
|
||||
Icon=idempiere.png
|
||||
Type=Directory
|
||||
Encoding=UTF-8
|
||||
|
||||
Name=iDempiere ERP
|
||||
Name[es]=iDempiere ERP
|
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 3.7 KiB |
After Width: | Height: | Size: 3.7 KiB |
After Width: | Height: | Size: 3.7 KiB |
After Width: | Height: | Size: 3.7 KiB |
After Width: | Height: | Size: 3.7 KiB |
After Width: | Height: | Size: 3.7 KiB |
|
@ -0,0 +1,23 @@
|
|||
VERSION=dev
|
||||
TIMESTAMP=`date +%Y%m%d`
|
||||
TMP=/tmp
|
||||
cd `dirname $0`/../../..
|
||||
IDEMPIERE_HOME=`pwd`
|
||||
RWD=$IDEMPIERE_HOME/idempiere-server/utils/unix
|
||||
PACKAGE=`ls -d $IDEMPIERE_HOME`
|
||||
PACKAGE=`basename $PACKAGE`
|
||||
PACKFILE=$IDEMPIERE_HOME/../${PACKAGE}_${VERSION}_${TIMESTAMP}.deb
|
||||
find $RWD/../.. -name "*.sh" -exec chmod +x {} \;
|
||||
chmod +x $RWD/DebianInstaller/etc/init.d/idempiere
|
||||
rm -f $TMP/debian-binary $TMP/control.tar.gz $TMP/data.tar.gz $TMP/control.tar $TMP/data.tar $PACKFILE
|
||||
echo 2.0 > $TMP/debian-binary
|
||||
tar cvf $TMP/control.tar -C $RWD/DebianInstaller/DEBIAN .
|
||||
gzip -v -9 $TMP/control.tar
|
||||
tar cvf $TMP/data.tar -C $RWD/DebianInstaller/ ./usr
|
||||
tar rvf $TMP/data.tar --exclude='idempiere.gtk.linux.x86_64/idempiere-server/utils/unix/createDEBpackage.sh' --exclude='idempiere.gtk.linux.x86_64/idempiere-server/utils/unix/DebianInstaller' --transform 's:^idempiere.gtk.linux.x86_64/idempiere-server:./opt/idempiere-server:' -C $RWD/../../../.. $PACKAGE > /dev/null
|
||||
tar rvf $TMP/data.tar -C $RWD/DebianInstaller/ ./etc
|
||||
gzip -v -9 $TMP/data.tar
|
||||
cd $TMP
|
||||
ar q $PACKFILE debian-binary control.tar.gz data.tar.gz
|
||||
rm debian-binary control.tar.gz data.tar.gz
|
||||
echo "Created $PACKFILE"
|
|
@ -0,0 +1,7 @@
|
|||
<!-- iDempiere -->
|
||||
<Menu>
|
||||
<Name>iDempiere</Name>
|
||||
<MergeFile>idempiere.menu</MergeFile>
|
||||
</Menu>
|
||||
<!-- End of iDempiere -->
|
||||
|
|
@ -136,10 +136,15 @@ public class ConfigPostgreSQL implements IDatabaseConfig
|
|||
if (!pass) {
|
||||
if (isDBExists) {
|
||||
log.warning(error);
|
||||
} else {
|
||||
if ("^TryLocalConnection^".equals(systemPassword)) {
|
||||
// Debian installer uses postgres socket domain connection
|
||||
log.warning(error);
|
||||
} else {
|
||||
return error;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (log.isLoggable(Level.INFO)) log.info("OK: System Connection = " + urlSystem);
|
||||
data.setProperty(ConfigurationData.ADEMPIERE_DB_SYSTEM, systemPassword);
|
||||
|
||||
|
|