pkgsrc/security/pks/Makefile
jlam 4390d56940 Make it easier to build and install packages "unprivileged", where
the owner of all installed files is a non-root user.  This change
affects most packages that require special users or groups by making
them use the specified unprivileged user and group instead.

(1) Add two new variables PKG_GROUPS_VARS and PKG_USERS_VARS to
    unprivileged.mk.  These two variables are lists of other bmake
    variables that define package-specific users and groups.  Packages
    that have user-settable variables for users and groups, e.g. apache
    and APACHE_{USER,GROUP}, courier-mta and COURIER_{USER,GROUP},
    etc., should list these variables in PKG_USERS_VARS and PKG_GROUPS_VARS
    so that unprivileged.mk can know to set them to ${UNPRIVILEGED_USER}
    and ${UNPRIVILEGED_GROUP}.

(2) Modify packages to use PKG_GROUPS_VARS and PKG_USERS_VARS.
2007-07-04 20:54:31 +00:00

72 lines
1.9 KiB
Makefile

# $NetBSD: Makefile,v 1.26 2007/07/04 20:54:58 jlam Exp $
DISTNAME= pks-0.9.4
PKGREVISION= 3
CATEGORIES= security www
MASTER_SITES+= http://www.mit.edu/people/marc/pks/ \
ftp://ftp.neonramp.com/pub/pksd/
PATCH_SITES= http://www.mit.edu/people/marc/pks/ \
ftp://ftp.neonramp.com/pub/pksd/
PATCHFILES= pks094-patch2 \
pks094-patch3
PATCH_DIST_STRIP= -p1
MAINTAINER= burgess@neonramp.com
HOMEPAGE= http://www.mit.edu/people/marc/pks/
COMMENT= PGP Public Key Server
GNU_CONFIGURE= YES
PKG_GROUPS_VARS+= PKS_GROUP
PKG_USERS_VARS+= PKS_USER
PKS_USER= pks
PKS_GROUP= pks
PKS_SERVER?= localhost
PKS_HOME= ${VARBASE}/pks
PKG_GROUPS= ${PKS_GROUP}
PKG_USERS= ${PKS_USER}:${PKS_GROUP}
PKG_GECOS.${PKS_USER}= PGP Key Server
PKG_HOME.${PKS_USER}= ${PKS_HOME}
BDB_ACCEPTED= db2
BUILD_DEFS+= PKS_SERVER
EGDIR= ${PREFIX}/share/examples
CONF_FILES= ${EGDIR}/pksd.conf ${PKG_SYSCONFDIR}/pksd.conf
RCD_SCRIPTS= pksd
FILES_SUBST+= PKS_USER=${PKS_USER:Q}
FILES_SUBST+= PKS_GROUP=${PKS_GROUP:Q}
OWN_DIRS_PERMS+= ${PKS_HOME} ${PKS_USER} ${PKS_GROUP} 0770
OWN_DIRS_PERMS+= ${PKS_HOME}/db ${PKS_USER} ${PKS_GROUP} 0770
OWN_DIRS_PERMS+= ${PKS_HOME}/incoming ${PKS_USER} ${PKS_GROUP} 0770
CONFIGURE_ARGS+= --datadir=${PREFIX}/share/pks
CONFIGURE_ARGS+= --localstatedir=${PKS_HOME:Q}
#
# pksd doesn't actually look for its config file anywhere; it must be
# specified directly on the command-line. Setting sysconfdir here just
# causes the example pksd.conf file to be installed at the named location.
#
CONFIGURE_ARGS+= --sysconfdir=${EGDIR:Q}
SUBST_CLASSES+= paths
SUBST_MESSAGE.paths= Fixing hardcoded paths.
SUBST_STAGE.paths= post-patch
SUBST_FILES.paths= pks-commands.html
SUBST_SED.paths= -e "s|localhost|${PKS_SERVER}|g"
.include "../../databases/db/buildlink3.mk"
post-install:
${INSTALL_DATA} ${WRKSRC}/pks-commands.html ${PKS_HOME}/db/index.html
@${CHOWN} ${PKS_USER} ${PKS_HOME}/db/index.html
@${CHGRP} ${PKS_GROUP} ${PKS_HOME}/db/index.html
.include "../../mk/bsd.pkg.mk"