mirror of
https://git.freebsd.org/ports.git
synced 2025-07-18 17:59:20 -04:00
sysutils/bacula15-server: patch to fix upgrade script
With upcoming removal of bacula9 and bacula11, let's make this work. These patches have been submitted upstream but not released: *0200b14613
*716952b15b
While here, remove Makefile.old committed during9df94c4d9d
PR: 281542
This commit is contained in:
parent
59efdc09db
commit
7ebb2c9f2a
3 changed files with 51 additions and 208 deletions
|
@ -1,6 +1,6 @@
|
|||
PORTNAME= bacula
|
||||
DISTVERSION= 15.0.2
|
||||
PORTREVISION= 4
|
||||
PORTREVISION= 5
|
||||
CATEGORIES?= sysutils
|
||||
MASTER_SITES= SF/bacula/bacula/${DISTVERSION}
|
||||
PKGNAMEPREFIX?= #
|
||||
|
|
|
@ -1,207 +0,0 @@
|
|||
PORTNAME= bacula
|
||||
DISTVERSION= 15.0.2
|
||||
PORTREVISION= 2
|
||||
CATEGORIES?= sysutils
|
||||
MASTER_SITES= SF/bacula/bacula/${DISTVERSION}
|
||||
PKGNAMEPREFIX?= #
|
||||
PKGNAMESUFFIX?= 15-server
|
||||
|
||||
MAINTAINER= dvl@FreeBSD.org
|
||||
COMMENT?= Network backup solution (server)
|
||||
WWW= https://www.bacula.org/
|
||||
|
||||
LICENSE= AGPLv3
|
||||
LICENSE_FILE= ${WRKSRC}/LICENSE
|
||||
|
||||
USES+= cpe libtool localbase python:env readline shebangfix ssl
|
||||
|
||||
SHEBANG_FILES= scripts/get_malware_abuse.ch scripts/key-manager.py.in \
|
||||
scripts/md5tobase64.py src/cats/make_catalog_backup.pl.in
|
||||
#scripts/baculabackupreport.in
|
||||
|
||||
CONFLICTS?= bacula13-server bacula11-server bacula9-server
|
||||
|
||||
LIB_DEPENDS+= liblzo2.so:archivers/lzo2
|
||||
|
||||
USERS= bacula
|
||||
GROUPS= ${USERS}
|
||||
|
||||
LIB_VERSION= ${DISTVERSION}
|
||||
|
||||
PLIST_SUB+= LIB_VERSION=${LIB_VERSION}
|
||||
|
||||
GNU_CONFIGURE= yes
|
||||
GNU_CONFIGURE_MANPREFIX= ${PREFIX}/share
|
||||
USE_LDCONFIG= yes
|
||||
|
||||
OPTIONS_DEFINE?= IPV6 MTX NLS S3
|
||||
MTX_DESC= Install mtx for control of autochanger devices
|
||||
S3_DESC= Install S3 plugin
|
||||
|
||||
.if ${PKGNAMESUFFIX} == "15-server"
|
||||
OPTIONS_MULTI= BACKEND
|
||||
OPTIONS_MULTI_BACKEND= MYSQL PGSQL SQLITE3
|
||||
OPTIONS_DEFAULT+= PGSQL
|
||||
.endif
|
||||
|
||||
OPTIONS_SUB= yes
|
||||
|
||||
.if ${PKGNAMESUFFIX} == "15-client" || ${PKGNAMESUFFIX} == "15-server" #Till end of the file
|
||||
|
||||
.if !defined(WITH_CLIENT_ONLY)
|
||||
LIB_DEPENDS+= libbac-${LIB_VERSION}.so:sysutils/bacula15-client
|
||||
USE_RC_SUBR?= bacula-dir bacula-sd
|
||||
.endif
|
||||
|
||||
.if defined(WITH_CLIENT_ONLY)
|
||||
SUB_FILES+= pkg-deinstall.client pkg-install.client pkg-message.client
|
||||
.else
|
||||
SUB_FILES+= pkg-message.server
|
||||
.endif
|
||||
|
||||
CONFIGURE_ARGS+= --disable-conio \
|
||||
--enable-batch-insert \
|
||||
--enable-smartalloc \
|
||||
--sysconfdir=${ETCDIR} \
|
||||
--with-baseport=9101 \
|
||||
--with-db-name=bacula \
|
||||
--with-db-user=bacula \
|
||||
--with-dump-email=root@localhost \
|
||||
--with-job-email=root@localhost \
|
||||
--with-logdir=/var/log \
|
||||
--with-plugindir=${PREFIX}/lib \
|
||||
--with-readline=${LOCALBASE} \
|
||||
--with-sbin-perm=755 \
|
||||
--with-scriptdir=${PREFIX}/share/${PORTNAME} \
|
||||
--with-tcp-wrappers=/usr/lib \
|
||||
--with-working-dir=${BACULA_DIR}
|
||||
|
||||
.if defined(WITH_CLIENT_ONLY)
|
||||
CONFIGURE_ARGS+= --with-fd-group=wheel \
|
||||
--with-fd-user=root
|
||||
.else
|
||||
CONFIGURE_ARGS+= --with-dir-group=${BACULA_GROUP} \
|
||||
--with-dir-user=${BACULA_USER} \
|
||||
--with-sd-group=operator \
|
||||
--with-sd-user=${BACULA_USER}
|
||||
.endif
|
||||
|
||||
# The user/group IDs below are registered, see
|
||||
# http://www.freebsd.org/doc/en_US.ISO8859-1/books/porters-handbook/book.html#users-and-groups
|
||||
#
|
||||
BACULA_USER?= bacula
|
||||
BACULA_GROUP?= ${BACULA_USER}
|
||||
BACULA_UID?= bacula
|
||||
BACULA_GID?= ${BACULA_UID}
|
||||
BACULA_DIR?= /var/db/bacula
|
||||
|
||||
PLIST_SUB+= BACULA_DIR=${BACULA_DIR}
|
||||
|
||||
SUB_LIST+= BACULA_DIR=${BACULA_DIR} \
|
||||
BACULA_GID=${BACULA_GID} \
|
||||
BACULA_GROUP=${BACULA_GROUP} \
|
||||
BACULA_UID=${BACULA_UID} \
|
||||
BACULA_USER=${BACULA_USER}
|
||||
|
||||
NLS_USES= gettext
|
||||
NLS_CONFIGURE_ENABLE= nls
|
||||
|
||||
# Client only or full server version
|
||||
.if defined(WITH_CLIENT_ONLY)
|
||||
CONFFILES= fd
|
||||
CONFIGURE_ARGS+= --enable-client-only
|
||||
|
||||
PKGDEINSTALL= ${FILESDIR}/pkg-deinstall.client
|
||||
PKGINSTALL= ${FILESDIR}/pkg-install.client
|
||||
.else
|
||||
# Server only Options
|
||||
CONFFILES= sd dir
|
||||
# Server default database
|
||||
|
||||
MYSQL_CONFIGURE_ON= --with-mysql=yes
|
||||
MYSQL_USES= mysql
|
||||
MYSQL_SUB_LIST= REQ_MYSQL=mysql
|
||||
MYSQL_SUB_LIST_OFF= REQ_MYSQL=""
|
||||
SQLITE3_CONFIGURE_ON= --with-sqlite3=yes
|
||||
SQLITE3_USES= sqlite:3
|
||||
PGSQL_CONFIGURE_ON= --with-postgresql=yes
|
||||
PGSQL_USES= pgsql
|
||||
PGSQL_SUB_LIST= REQ_PGSQL=postgresql
|
||||
PGSQL_SUB_LIST_OFF= REQ_PGSQL=""
|
||||
|
||||
MTX_RUN_DEPENDS= ${LOCALBASE}/sbin/mtx:misc/mtx
|
||||
|
||||
.endif
|
||||
|
||||
S3_CONFIGURE_ARGS= --enable-s3
|
||||
S3_LIB_DEPENDS= libs3.so:sysutils/bacula-libs3
|
||||
|
||||
.include <bsd.port.pre.mk>
|
||||
|
||||
.if defined(WITH_CLIENT_ONLY)
|
||||
MP8+= bacula.8 bacula-fd.8 bconsole.8
|
||||
.else
|
||||
MP8+= bacula-dir.8 bacula-sd.8 bcopy.8 bextract.8 bls.8 bscan.8 \
|
||||
btape.8 btraceback.8 dbcheck.8 bwild.8 bregex.8
|
||||
MP1+= bsmtp.1 bacula-tray-monitor.1
|
||||
.endif
|
||||
|
||||
MAKE_ENV+= MAN1="${MP1}" \
|
||||
MAN8="${MP8}"
|
||||
|
||||
post-patch:
|
||||
# This port does not install docs. See bacula-docs for that
|
||||
@${REINPLACE_CMD} -e '/docdir/d' ${WRKSRC}/Makefile.in
|
||||
# Change $(ECHO) to echo in some Makefile.in files
|
||||
@${REINPLACE_CMD} -e 's|$$(ECHO)|echo|g' \
|
||||
${WRKSRC}/src/filed/Makefile.in \
|
||||
${WRKSRC}/src/console/Makefile.in \
|
||||
${WRKSRC}/src/cats/Makefile.in \
|
||||
${WRKSRC}/src/dird/Makefile.in \
|
||||
${WRKSRC}/src/stored/Makefile.in \
|
||||
${WRKSRC}/src/tools/Makefile.in
|
||||
|
||||
# Default bconsole.conf is in ${ETCDIR}
|
||||
@${REINPLACE_CMD} -e 's|./bconsole.conf|${ETCDIR}/bconsole.conf|g' ${WRKSRC}/src/console/console.c
|
||||
@${REINPLACE_CMD} -e 's|^MAN8 =|MAN8 ?=|g' -e 's|^MAN1 =|MAN1 ?=|g' ${WRKSRC}/manpages/Makefile.in
|
||||
.if defined(WITH_CLIENT_ONLY)
|
||||
# In client port only install startup script out of script dir (see below post-install)
|
||||
# Dont mkdir ${PREFIX}/share/bacula cause it's empty
|
||||
@${REINPLACE_CMD} -e 's|^\(fd_subdirs = .*\)scripts\(.*\)|\1\2|g' ${WRKSRC}/Makefile.in
|
||||
@${REINPLACE_CMD} -e 's|\(.*$${MKDIR} $${DESTDIR}$${scriptdir}\)|#\1|g' ${WRKSRC}/Makefile.in
|
||||
.else
|
||||
# In server port don't install filed
|
||||
@${REINPLACE_CMD} -e '/^fd_subdirs = /s|src/filed||' -e 's|src/console||' \
|
||||
${WRKSRC}/Makefile.in
|
||||
.endif
|
||||
|
||||
.if !target(post-install)
|
||||
post-install:
|
||||
.if defined(WITH_CLIENT_ONLY)
|
||||
${MV} ${STAGEDIR}${ETCDIR}/bconsole.conf ${STAGEDIR}${ETCDIR}/bconsole.conf.sample
|
||||
${INSTALL_DATA} ${WRKSRC}/examples/sample-query.sql ${STAGEDIR}${LOCALBASE}/share/bacula/query.sql.sample
|
||||
.else
|
||||
${INSTALL_SCRIPT} ${FILESDIR}/chio-bacula ${STAGEDIR}${PREFIX}/sbin
|
||||
${INSTALL_DATA} ${FILESDIR}/bacula-barcodes ${STAGEDIR}${ETCDIR}/bacula-barcodes.sample
|
||||
# bacula-dir attempts to install query.sql as bpart of bacula-server, but that should only installed by bacula-client.
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/share/bacula/query.sql
|
||||
|
||||
#the following are installed by the -CLIENT port, and I (ler@lerctr.org)
|
||||
#don't know how to remove them from being built for the -SERVER port.
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/bpipe-fd.so
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/libbac-${LIB_VERSION}.so
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/libbac.so
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/libbaccfg-${LIB_VERSION}.so
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/libbaccfg.so
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/libbacfind-${LIB_VERSION}.so
|
||||
${RM} ${STAGEDIR}${LOCALBASE}/lib/libbacfind.so
|
||||
.endif
|
||||
for na in ${CONFFILES}; do \
|
||||
${MV} ${STAGEDIR}${ETCDIR}/bacula-$$na.conf ${STAGEDIR}${ETCDIR}/bacula-$$na.conf.sample; \
|
||||
done
|
||||
.endif
|
||||
.else
|
||||
.include "${MASTERDIR}/Makefile.common"
|
||||
.endif # 15-client and 15-server are defined
|
||||
|
||||
.include <bsd.port.post.mk>
|
|
@ -0,0 +1,50 @@
|
|||
--- src/cats/update_postgresql_tables.in.orig 2024-09-16 19:41:23 UTC
|
||||
+++ src/cats/update_postgresql_tables.in
|
||||
@@ -186,7 +186,7 @@ if [ "$DBVERSION" -eq 15 -o "$DBVERSION" -eq 16 ]; the
|
||||
echo " doesn't have write permission on the current directory,"
|
||||
echo " or if the system doesn't have enough space to store a"
|
||||
echo " compressed export of the File table"
|
||||
- psql --set ON_ERROR_STOP=1 -d ${db_name} $* -c "set work_mem='$WORKMEM';"'set enable_mergejoin to off ; set enable_hashjoin to off; copy (SELECT FileId, FileIndex, JobId, PathId, Filename.Name, DeltaSeq, MarkId, LStat, Md5 FROM File JOIN Filename USING (FilenameId)) TO STDOUT' | $COMP -1 -c > file1017.data
|
||||
+ psql -q --set ON_ERROR_STOP=1 -d ${db_name} $* -c "set work_mem='$WORKMEM';"'set enable_mergejoin to off ; set enable_hashjoin to off; copy (SELECT FileId, FileIndex, JobId, PathId, Filename.Name, DeltaSeq, MarkId, LStat, Md5 FROM File JOIN Filename USING (FilenameId)) TO STDOUT' | $COMP -1 -c > file1017.data
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Error while dumping file table to $PWD/file1017.data"
|
||||
@@ -219,12 +219,12 @@ EOF
|
||||
exit 1
|
||||
fi
|
||||
|
||||
- echo "Loading the File table from $PWD/file.$$.data..."
|
||||
+ echo "Loading the File table from $PWD/file1017.data..."
|
||||
# we do everything in the same commit to avoid creating WALs on this operation
|
||||
cat file1017.data | $COMP -d | psql --set ON_ERROR_STOP=1 -d ${db_name} $* -c "BEGIN; TRUNCATE File; COPY File FROM STDIN; set maintenance_work_mem='2000MB'; CREATE INDEX file_jpfid_idx on File (JobId, PathId, Filename text_pattern_ops); ALTER TABLE ONLY File ADD CONSTRAINT file_pkey PRIMARY KEY (FileId); COMMIT;"
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
- echo "Inserting File data from file.$$.data failed."
|
||||
+ echo "Inserting File data from file1017.data failed."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
@@ -285,7 +285,7 @@ if [ "$STOP1015" = "" -a "$DBVERSION" -eq 1015 ]; then
|
||||
echo " doesn't have write permission on the current directory,"
|
||||
echo " or if the system doesn't have enough space to store a"
|
||||
echo " compressed export of the File table"
|
||||
- psql --set ON_ERROR_STOP=1 -d ${db_name} $* -c "set work_mem='$WORKMEM';"'set enable_mergejoin to off ; set enable_hashjoin to off; copy (SELECT FileId, FileIndex, JobId, PathId, Filename.Name, DeltaSeq, MarkId, LStat, Md5 FROM File JOIN Filename USING (FilenameId)) TO STDOUT' | $COMP -1 -c > file1016.data
|
||||
+ psql -q --set ON_ERROR_STOP=1 -d ${db_name} $* -c "set work_mem='$WORKMEM';"'set enable_mergejoin to off ; set enable_hashjoin to off; copy (SELECT FileId, FileIndex, JobId, PathId, Filename.Name, DeltaSeq, MarkId, LStat, Md5 FROM File JOIN Filename USING (FilenameId)) TO STDOUT' | $COMP -1 -c > file1016.data
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Error while dumping file table to $PWD/file1016.data"
|
||||
@@ -318,12 +318,12 @@ EOF
|
||||
exit 1
|
||||
fi
|
||||
|
||||
- echo "Loading the File table from $PWD/file.$$.data..."
|
||||
+ echo "Loading the File table from $PWD/file1016.data..."
|
||||
# we do everything in the same commit to avoid creating WALs on this operation
|
||||
cat file1016.data | $COMP -d | psql --set ON_ERROR_STOP=1 -d ${db_name} $* -c "BEGIN; TRUNCATE File; COPY File FROM STDIN; set maintenance_work_mem='2000MB'; CREATE INDEX file_jpfid_idx on File (JobId, PathId, Filename text_pattern_ops); ALTER TABLE ONLY File ADD CONSTRAINT file_pkey PRIMARY KEY (FileId); COMMIT;"
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
- echo "Inserting File data from file.$$.data failed."
|
||||
+ echo "Inserting File data from file1016.data failed."
|
||||
exit 1
|
||||
fi
|
||||
|
Loading…
Add table
Reference in a new issue