2006-11-05 16:10:08 +01:00
|
|
|
# $NetBSD: unprivileged.mk,v 1.9 2006/11/05 15:10:08 joerg Exp $
|
2005-05-29 19:12:15 +02:00
|
|
|
#
|
2006-07-15 22:47:43 +02:00
|
|
|
# This file collects definitions that are useful when using pkgsrc as an
|
|
|
|
# unprivileged (non-root) user. It is included automatically by the
|
|
|
|
# pkgsrc infrastructure.
|
2005-05-29 19:12:15 +02:00
|
|
|
#
|
2006-07-15 22:47:43 +02:00
|
|
|
# The following variables may be set by the pkgsrc user in mk.conf:
|
2005-05-29 19:12:15 +02:00
|
|
|
#
|
2006-07-15 22:47:43 +02:00
|
|
|
# UNPRIVILEGED : YesNo (default: undefined)
|
|
|
|
# If set to 'yes', enable unprivileged builds.
|
2005-05-29 19:12:15 +02:00
|
|
|
#
|
2006-07-15 22:47:43 +02:00
|
|
|
# UNPRIVILEGED_GROUP : Groupname (default: the current group)
|
|
|
|
# Specifies the group name (or gid) that will be used to install
|
|
|
|
# files.
|
|
|
|
#
|
|
|
|
# UNPRIVILEGED_USER : Username (default: the current user)
|
|
|
|
# Specifies the user name (or uid) that will be used to install
|
|
|
|
# files.
|
2005-05-29 19:12:15 +02:00
|
|
|
|
2006-10-09 14:25:44 +02:00
|
|
|
.if (defined(UNPRIVILEGED) && !empty(UNPRIVILEGED:M[Yy][Ee][Ss])) || ${_USE_DESTDIR} == "user-destdir"
|
2005-05-29 19:12:15 +02:00
|
|
|
|
|
|
|
# Guess which user/group has to be used.
|
|
|
|
. if !defined(UNPRIVILEGED_USER) || empty(UNPRIVILEGED_USER)
|
|
|
|
UNPRIVILEGED_USER!= ${ID} -n -u
|
|
|
|
. endif
|
|
|
|
. if !defined(UNPRIVILEGED_GROUP) || empty(UNPRIVILEGED_GROUP)
|
|
|
|
UNPRIVILEGED_GROUP!= ${ID} -n -g
|
|
|
|
. endif
|
|
|
|
|
2006-10-09 14:25:44 +02:00
|
|
|
.if ${_USE_DESTDIR} == "user-destdir" && (!defined(UNPRIVILEGED) || empty(UNPRIVILEGED:M[Yy][Ee][Ss]))
|
|
|
|
_SU_ROOT_USER:= ${ROOT_USER}
|
2006-11-05 16:10:08 +01:00
|
|
|
REAL_ROOT_USER:= ${ROOT_USER}
|
|
|
|
REAL_ROOT_GROUP:= ${ROOT_GROUP}
|
2006-10-09 14:25:44 +02:00
|
|
|
.endif
|
|
|
|
|
2005-05-29 19:12:15 +02:00
|
|
|
# Override super-user account.
|
|
|
|
ROOT_GROUP= ${UNPRIVILEGED_GROUP}
|
|
|
|
ROOT_USER= ${UNPRIVILEGED_USER}
|
|
|
|
|
|
|
|
# Override user/group pairs used to install files.
|
|
|
|
BINGRP= ${UNPRIVILEGED_GROUP}
|
|
|
|
BINOWN= ${UNPRIVILEGED_USER}
|
|
|
|
GAMEGRP= ${UNPRIVILEGED_GROUP}
|
|
|
|
GAMEOWN= ${UNPRIVILEGED_USER}
|
|
|
|
MANGRP= ${UNPRIVILEGED_GROUP}
|
|
|
|
MANOWN= ${UNPRIVILEGED_USER}
|
|
|
|
SHAREGRP= ${UNPRIVILEGED_GROUP}
|
|
|
|
SHAREOWN= ${UNPRIVILEGED_USER}
|
2006-11-05 15:36:13 +01:00
|
|
|
DOCGRP= ${UNPRIVILEGED_GROUP}
|
|
|
|
DOCOWN= ${UNPRIVILEGED_USER}
|
2005-05-29 19:12:15 +02:00
|
|
|
|
|
|
|
# Override installation modes. As a regular user, we may have problems
|
|
|
|
# when overwriting files if they are not writable.
|
|
|
|
BINMODE= 755
|
|
|
|
NONBINMODE= 644
|
|
|
|
|
|
|
|
# mtree is useless as a regular user because it won't set directory
|
|
|
|
# ownerships correctly.
|
2005-09-28 23:55:32 +02:00
|
|
|
NO_MTREE= yes
|
2006-10-09 14:25:44 +02:00
|
|
|
.endif
|
2005-05-29 19:12:15 +02:00
|
|
|
|
2006-10-09 14:25:44 +02:00
|
|
|
.if (defined(UNPRIVILEGED) && !empty(UNPRIVILEGED:M[Yy][Ee][Ss]))
|
2005-05-29 19:12:15 +02:00
|
|
|
# As a regular user, creation of other users and groups won't work, so
|
|
|
|
# disable this step by default.
|
2005-08-22 19:13:28 +02:00
|
|
|
PKG_CREATE_USERGROUP= NO
|
2005-05-29 19:12:15 +02:00
|
|
|
|
|
|
|
# Override commands that won't work as a regular user.
|
2006-08-31 18:21:20 +02:00
|
|
|
TOOLS_PLATFORM.chgrp= ${TRUE} chgrp
|
|
|
|
TOOLS_PLATFORM.chown= ${TRUE} chown
|
2005-05-29 19:12:15 +02:00
|
|
|
SU_CMD= ${SH} -c
|
|
|
|
|
2005-08-22 19:13:28 +02:00
|
|
|
# Do not attempt to modify /etc/shells as a regular user.
|
|
|
|
PKG_REGISTER_SHELLS= NO
|
|
|
|
|
2005-05-29 19:12:15 +02:00
|
|
|
.endif
|