Hallo Michael, Thanks for your feedback on the patch. This is my first attempt at doing this so I am not surprised that I need to fix some things. I will fix the install.sh script as mentioned below and redo the patch. On 18/05/2020 13:08, Michael Tremer wrote: > Hello Adolf, > > Thank you for submitting this patch. > > This looks very good, but there are some smaller problems in it: > >> On 16 May 2020, at 22:16, Adolf Belka wrote: >> >> Update bacula from 9.0.6 to 9.6.3 >> >> - Current version of bacula in ipfire is 9.0.6 and is over two and a half years old. >> >> - update config options in lfs to include bacula recommended smartalloc option. >> >> - Add install, uninstall and update files in src/paks/bacula >> >> - updated backup/includes to only backup the config file. >> >> Signed-off-by: Adolf Belka >> --- >> >> diff --git a/config/backup/includes/bacula b/config/backup/includes/bacula >> index 8d5c119f9..0da11db7d 100644 >> --- a/config/backup/includes/bacula >> +++ b/config/backup/includes/bacula >> @@ -1 +1 @@ >> -/etc/bacula/ >> +/etc/bacula/bacula-fd.conf >> diff --git a/lfs/bacula b/lfs/bacula >> index 8c96c7ba1..878aefa0c 100644 >> --- a/lfs/bacula >> +++ b/lfs/bacula >> @@ -24,17 +24,17 @@ >> >> include Config >> >> -VER = 9.0.6 >> +VER = 9.6.3 >> >> THISAPP = bacula-$(VER) >> DL_FILE = $(THISAPP).tar.gz >> -DL_FROM = $(URL_IPFIRE) >> +DL_FROM = https://www.bacula.org/download/10266/ >> DIR_APP = $(DIR_SRC)/$(THISAPP) >> TARGET = $(DIR_INFO)/$(THISAPP) >> PROG = bacula >> -PAK_VER = 4 >> +PAK_VER = 1 > We always increase the version number, even when VER is bumped, too. > > So, in this case it would have been 5. There person who merges this can fix this for you. I just wanted to let you know for next time. Thanks for letting me know. >> -DEPS = >> +DEPS = "" > We don’t have any “” in here any more. Thanks for letting me know. >> ############################################################################### >> # Top-level Rules >> @@ -44,7 +44,7 @@ objects = $(DL_FILE) >> >> $(DL_FILE) = $(DL_FROM)/$(DL_FILE) >> >> -$(DL_FILE)_MD5 = 9168e398808c42bf290515f60892f643 >> +$(DL_FILE)_MD5 = 6d64bc27de773ee0e0ca1d836cbe4008 >> >> install : $(TARGET) >> >> @@ -80,12 +80,13 @@ $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects)) >> $(UPDATE_AUTOMAKE) >> cd $(DIR_APP) && ./configure \ >> --prefix=/usr \ >> + --enable-smartalloc \ >> --sysconfdir=/etc/bacula \ >> --with-working-dir=/var/bacula/working \ >> --enable-client-only >> cd $(DIR_APP) && make $(MAKETUNING) >> cd $(DIR_APP) && make install >> - ln -s /etc/bacula/bacula-ctl-fd /etc/rc.d/init.d/bacula >> + ln -sf /etc/bacula/bacula-ctl-fd /etc/rc.d/init.d/bacula >> rm -f /root/.rnd >> @rm -rf $(DIR_APP) >> @$(POSTBUILD) >> diff --git a/src/paks/bacula/install.sh b/src/paks/bacula/install.sh >> new file mode 100644 >> index 000000000..fb45b593b >> --- /dev/null >> +++ b/src/paks/bacula/install.sh >> @@ -0,0 +1,44 @@ >> +#!/bin/bash >> +############################################################################ >> +# # >> +# This file is part of the IPFire Firewall. # >> +# # >> +# IPFire is free software; you can redistribute it and/or modify # >> +# it under the terms of the GNU General Public License as published by # >> +# the Free Software Foundation; either version 2 of the License, or # >> +# (at your option) any later version. # >> +# # >> +# IPFire is distributed in the hope that it will be useful, # >> +# but WITHOUT ANY WARRANTY; without even the implied warranty of # >> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # >> +# GNU General Public License for more details. # >> +# # >> +# You should have received a copy of the GNU General Public License # >> +# along with IPFire; if not, write to the Free Software # >> +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # >> +# # >> +# Copyright (C) 2007 IPFire-Team . # >> +# # >> +############################################################################ >> +# >> +. /opt/pakfire/lib/functions.sh >> +extract_files >> + >> +if [ -f /etc/bacula/bacula-fd.conf ]; then >> + mv /etc/bacula/bacula-fd.conf /etc/bacula/bacula-fd.conf.new >> +fi >> + >> +restore_backup ${NAME} >> + >> +if [ ! -f /etc/bacula/bacula-fd.conf ]; then >> + cp -a /etc/bacula/bacula-fd.conf.new /etc/bacula/bacula-fd.conf >> +fi > Why are you doing this? The backup should have taken care of this. Having had a think about it I realised I created my own problem. In the first if statement I used a mv command. If I use a cp command then for a new install the .conf file will be coped to a .conf.new file and the restore_backup will not have any file so the .conf and .conf.new files will be equivalent. For an update the restore_backup will overwrite the new .conf file with the previous version and the new .conf file will be available in .conf.new The second if statement then isn't needed. I will redo the patch with this change and the other items you highlighted and resend it. >> + >> +# create startlinks >> +ln -sf ../init.d/bacula /etc/rc.d/rc0.d/K35bacula >> +ln -sf ../init.d/bacula /etc/rc.d/rc3.d/S65bacula >> +ln -sf ../init.d/bacula /etc/rc.d/rc6.d/K35bacula >> + >> +start_service bacula >> + >> +exit 0 >> diff --git a/src/paks/bacula/uninstall.sh b/src/paks/bacula/uninstall.sh >> new file mode 100644 >> index 000000000..4a97eb3e9 >> --- /dev/null >> +++ b/src/paks/bacula/uninstall.sh >> @@ -0,0 +1,32 @@ >> +#!/bin/bash >> +############################################################################ >> +# # >> +# This file is part of the IPFire Firewall. # >> +# # >> +# IPFire is free software; you can redistribute it and/or modify # >> +# it under the terms of the GNU General Public License as published by # >> +# the Free Software Foundation; either version 2 of the License, or # >> +# (at your option) any later version. # >> +# # >> +# IPFire is distributed in the hope that it will be useful, # >> +# but WITHOUT ANY WARRANTY; without even the implied warranty of # >> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # >> +# GNU General Public License for more details. # >> +# # >> +# You should have received a copy of the GNU General Public License # >> +# along with IPFire; if not, write to the Free Software # >> +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # >> +# # >> +# Copyright (C) 2007 IPFire-Team . # >> +# # >> +############################################################################ >> +# >> +. /opt/pakfire/lib/functions.sh >> +stop_service ${NAME} >> +make_backup ${NAME} >> +remove_files >> + >> +# Remove all start links. >> +rm -rf /etc/rc.d/rc*.d/*bacula >> + >> +exit 0 >> diff --git a/src/paks/bacula/update.sh b/src/paks/bacula/update.sh >> new file mode 100644 >> index 000000000..89c40d0d7 >> --- /dev/null >> +++ b/src/paks/bacula/update.sh >> @@ -0,0 +1,26 @@ >> +#!/bin/bash >> +############################################################################ >> +# # >> +# This file is part of the IPFire Firewall. # >> +# # >> +# IPFire is free software; you can redistribute it and/or modify # >> +# it under the terms of the GNU General Public License as published by # >> +# the Free Software Foundation; either version 2 of the License, or # >> +# (at your option) any later version. # >> +# # >> +# IPFire is distributed in the hope that it will be useful, # >> +# but WITHOUT ANY WARRANTY; without even the implied warranty of # >> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # >> +# GNU General Public License for more details. # >> +# # >> +# You should have received a copy of the GNU General Public License # >> +# along with IPFire; if not, write to the Free Software # >> +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # >> +# # >> +# Copyright (C) 2007 IPFire-Team . # >> +# # >> +############################################################################ >> +# >> +. /opt/pakfire/lib/functions.sh >> +./uninstall.sh >> +./install.sh >> > -Michael >