#!/bin/sh
#
# $NetBSD: header,v 1.3 2014/12/30 15:13:20 wiz Exp $

SELF="$0"
PKGNAME="$1"
STAGE="$2"
shift 2

AWK="/usr/bin/awk"
BASENAME="/usr/bin/basename"
CAT="/bin/cat"
CHGRP="/usr/bin/chgrp"
CHMOD="/bin/chmod"
CHOWN="/usr/sbin/chown"
CMP="/usr/bin/cmp"
CP="/bin/cp"
DIRNAME="/usr/bin/dirname"
ECHO="echo"
ECHO_N="echo -n"
EGREP="/usr/bin/egrep"
EXPR="/bin/expr"
FALSE="false"
FIND="/usr/bin/find"
GREP="/usr/bin/grep"
GTAR=""
HEAD="/usr/bin/head"
ID="/usr/bin/id"
LINKFARM="/usr/sbin/linkfarm"
LN="/bin/ln"
LS="/bin/ls"
MKDIR="/bin/mkdir -p"
MV="mv -f"
PERL5="/usr/pkg/bin/perl"
PKG_ADMIN="/usr/sbin/pkg_admin"
PKG_INFO="/usr/sbin/pkg_info"
PWD_CMD="/bin/pwd"
RM="/bin/rm"
RMDIR="/bin/rmdir"
SED="/usr/bin/sed"
SETENV="/usr/bin/env"
SH="/bin/sh"
SORT="/usr/bin/sort"
SU="/usr/bin/su"
TEST="test"
TOUCH="/usr/bin/touch"
TR="/usr/bin/tr"
TRUE="true"
XARGS="/usr/bin/xargs"

CURDIR=`${PWD_CMD}`
: ${PKG_METADATA_DIR=${CURDIR}}
PKGBASE="freeradius"

LOCALBASE="/usr/pkg"
X11BASE="/usr/X11R7"
PREFIX="/usr/pkg"

PKG_SYSCONFBASE="/usr/pkg/etc"
PKG_SYSCONFBASEDIR="/usr/pkg/etc"
PKG_SYSCONFDIR="/usr/pkg/etc/raddb"
CONF_DEPENDS=""

CONF_IGNORE_FILES="*[~#] *.OLD *.orig *,v .pkgsrc */.pkgsrc"

case "${PKG_CONFIG:-YES}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_CONFIG=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_CONFIG=yes
	;;
esac

# $NetBSD: usergroup,v 1.3 2009/10/29 20:19:27 joerg Exp $
#
# Generate a +USERGROUP script that reference-counts users and groups
# that are required for the proper functioning of the package.
#
case "${STAGE},$1" in
UNPACK,|UNPACK,+USERGROUP)
	${CAT} > ./+USERGROUP << 'EOF'
#!/bin/sh
#
# +USERGROUP - users and groups management script
#
# Usage: ./+USERGROUP ADD|REMOVE [metadatadir]
#        ./+USERGROUP CHECK-ADD|CHECK-REMOVE [metadatadir]
#
# This script supports two actions, ADD and REMOVE, that will add or
# remove the users and groups needed by the package associated with
# <metadatadir>.  The CHECK-ADD action will check whether any users or
# groups needed by the package are missing, and print an informative
# message noting those users and groups.  The CHECK-REMOVE action will
# check whether any users and groups needed by the package still exist,
# and print an informative message noting those users and groups.  The
# CHECK-ADD and CHECK-REMOVE actions return non-zero if they detect
# either missing or existing users/groups, respectively.
#
# Lines starting with "# USER: " or "# GROUP: " are data read by this
# script that name the users and groups that this package requires to
# exist to function correctly, e.g.
#
#	# USER: foo:foogrp::The Foomister
#	# GROUP: foogrp
#
# The USER lines are of the form:
#
#	user:group[:[userid][:[descr][:[home][:shell]]]]
#
# Only the user and group are required; everything else is optional,
# but the colons must be in the right places when specifying optional
# bits.
#
# The GROUP lines are of the form:
#
#	group[:groupid]
#
# Only the group is required; the groupid is optional.
#
AWK="/usr/bin/awk"
CAT="/bin/cat"
CHGRP="/usr/bin/chgrp"
CHMOD="/bin/chmod"
CHOWN="/usr/sbin/chown"
ECHO="echo"
GREP="/usr/bin/grep"
LS="/bin/ls"
MKDIR="/bin/mkdir -p"
MV="mv -f"
PWD_CMD="/bin/pwd"
RM="/bin/rm"
RMDIR="/bin/rmdir"
SED="/usr/bin/sed"
SORT="/usr/bin/sort"
TEST="test"
TRUE="true"

SELF=$0
ACTION=$1

CURDIR=`${PWD_CMD}`
PKG_METADATA_DIR="${2-${CURDIR}}"
: ${PKGNAME=${PKG_METADATA_DIR##*/}}
: ${PKG_DBDIR=${PKG_METADATA_DIR%/*}}
: ${PKG_REFCOUNT_DBDIR=${PKG_DBDIR}.refcount}

PKG_REFCOUNT_USERS_DBDIR="${PKG_REFCOUNT_DBDIR}/users"
PKG_REFCOUNT_GROUPS_DBDIR="${PKG_REFCOUNT_DBDIR}/groups"

case "${PKG_CREATE_USERGROUP:-YES}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_CREATE_USERGROUP=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_CREATE_USERGROUP=no
	;;
esac

listwrap()
{
	_length=$1
	_buffer=
	while read _line; do
		set -- $_line
		for _word; do
			case $_buffer in
			"")	_buffer="$_word" ;;
			*)	_buffer="$_buffer  $_word" ;;
			esac
			if ${TEST} ${#_buffer} -gt $_length; then
				${ECHO} "	$_buffer"
				_buffer=
			fi
		done
	done
	case $_buffer in
	"")	;;
	*)	${ECHO} "	$_buffer" ;;
	esac
}

# DO NOT CHANGE THE FOLLOWING LINE!
# platform-specific adduser/addgroup functions
# $NetBSD: usergroupfuncs,v 1.4 2013/04/03 09:35:19 jperkin Exp $
#
# Default implementations of user_exists() and group_exists() shell
# functions for checking the existence of users and groups, and of
# adduser() and addgroup() shell functions for adding users and groups.
# Assume there are NetBSD/Solaris-compatible versions of useradd(8) and
# groupadd(8) available through ${USERADD} and ${GROUPADD}, respectively.
#
# Platform-specific replacements for this file should be located at:
#
#	pkgsrc/mk/pkginstall/usergroupfuncs.${OPSYS}
#

# group_exists group [groupid]
#	Returns 0 if $group exists and has gid $groupid
#	Returns 1 if neither $group nor $groupid exist
#	Returns 2 if $group or $groupid exist but don't match
#	Returns 3 for all errors
#
group_exists()
{
	_group="$1"; _groupid="$2"
	${TEST} -n "$_group" || return 3

	# Check using chgrp to work properly in an NSS/NIS environment.
	_tmpdir="./.pkginstall.$$"
	${MKDIR} -p $_tmpdir 2>/dev/null || return 3
	${CHMOD} 0700 $_tmpdir
	_testpath="$_tmpdir/group_exists"
	${ECHO} > $_testpath
	if ${CHGRP} $_group $_testpath >/dev/null 2>&1; then
		# $_group exists
		_id=`${LS} -ln $_testpath 2>/dev/null | ${AWK} '{ print $4 }'`
		${TEST} -n "$_groupid" || _groupid=$_id
		if ${TEST} "$_groupid" = "$_id"; then
			${RM} -fr $_tmpdir; return 0
		fi
		${RM} -fr $_tmpdir; return 2
	elif ${TEST} -z "$_groupid"; then
		# $_group doesn't exist and $_groupid is not set
		${RM} -fr $_tmpdir; return 1
	elif ${CHGRP} $_groupid $_testpath >/dev/null 2>&1; then
		_name=`${LS} -l $_testpath 2>/dev/null | ${AWK} '{ print $4 }'`
		if ${TEST} "$_name" != "$_groupid"; then
			# $_group doesn't exist, but $_groupid exists
			${RM} -fr $_tmpdir; return 2
		fi
		# neither $_group nor $_groupid exist
		${RM} -fr $_tmpdir; return 1
	fi
	${RM} -fr $_tmpdir; return 3
}

# user_exists user [userid]
#	Returns 0 if $user exists and has uid $userid
#	Returns 1 if neither $user nor $userid exist
#	Returns 2 if $user or $userid exist but don't match
#	Returns 3 for all errors
#
user_exists()
{
	_user="$1"; _userid="$2"
	${TEST} -n "$_user" || return 3

	# Check using chown to work properly in an NSS/NIS environment.
	_tmpdir="./.pkginstall.$$"
	${MKDIR} -p $_tmpdir 2>/dev/null || return 3
	${CHMOD} 0700 $_tmpdir
	_testpath="$_tmpdir/user_exists"
	${ECHO} > $_testpath
	if ${CHOWN} $_user $_testpath >/dev/null 2>&1; then
		# $_user exists
		_id=`${LS} -ln $_testpath 2>/dev/null | ${AWK} '{ print $3 }'`
		${TEST} -n "$_userid" || _userid=$_id
		if ${TEST} "$_userid" = "$_id"; then
			${RM} -fr $_tmpdir; return 0
		fi
		${RM} -fr $_tmpdir; return 2
	elif ${TEST} -z "$_userid"; then
		# $_user doesn't exist and $_userid is not set
		${RM} -fr $_tmpdir; return 1
	elif ${CHOWN} $_userid $_testpath >/dev/null 2>&1; then
		_name=`${LS} -l $_testpath 2>/dev/null | ${AWK} '{ print $3 }'`
		if ${TEST} "$_name" != "$_userid"; then
			# $_user doesn't exist, but $_userid exists
			${RM} -fr $_tmpdir; return 2
		fi
		# neither $_user nor $_userid exist
		${RM} -fr $_tmpdir; return 1
	fi
	${RM} -fr $_tmpdir; return 3
}

# adduser user group [userid] [descr] [home] [shell]
adduser()
{
	user="$1"; group="$2"; userid="$3"
	descr="$4"; home="$5" shell="$6"
	${TEST} $# -eq 6 || return 1
	${TEST} -n "$user" || return 2
	${TEST} -n "$group" || return 2

	USERADD="/usr/sbin/useradd"

	case $user in
	${PKGNAME%-[0-9]*})	descr_dflt="$user user" ;;
	*)			descr_dflt="${PKGNAME%-[0-9]*} $user user" ;;
	esac
	: ${descr:="$descr_dflt"}
	: ${home:="/nonexistent"}
	: ${shell:="/sbin/nologin"}

	if ${TEST} -n "${USERADD}" -a -x "${USERADD}"; then
		${ECHO} "${PKGNAME}: Creating user \`\`$user''"
		case $userid in
		"")
			${USERADD}					\
				-c "$descr" -d "$home" -s "$shell"	\
				-g $group $user
			;;
		*)
			${USERADD}					\
				-c "$descr" -d "$home" -s "$shell"	\
				-g $group -u $userid $user
			;;
		esac
	fi
	return 0
}

# addgroup group [groupid]
addgroup()
{
	group="$1"; groupid="$2"
	${TEST} $# -eq 2 || return 1
	${TEST} -n "$group" || return 2

	GROUPADD="/usr/sbin/groupadd"

	if ${TEST} -n "${GROUPADD}" -a -x "${GROUPADD}"; then
		${ECHO} "${PKGNAME}: Creating group \`\`$group''"
		case $groupid in
		"")	${GROUPADD} $group ;;
		*)	${GROUPADD} -g $groupid $group ;;
		esac
	fi
	return 0
}

exitcode=0
case $ACTION in
ADD)
	${SED} -n "/^\# GROUP: /{s/^\# GROUP: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		group="$1"; groupid="$2"
		IFS="$SAVEIFS"
		case $group in
		"")	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_GROUPS_DBDIR}/$group"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		if ${TEST} ! -d "$shadow_dir"; then
			${MKDIR} $shadow_dir
			group_exists $group $groupid &&
				${ECHO} "${PKGNAME}" > $preexist
		fi
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" $token >/dev/null; then
			:
		else
			${ECHO} "${PKG_METADATA_DIR}" >> $token
		fi
		case ${_PKG_CREATE_USERGROUP} in
		yes)
			group_exists $group $groupid
			case $? in
			0)	;;
			1)	addgroup "$group" "$groupid" ;;
			esac
			;;
		esac
	done; }
	${SED} -n "/^\# USER: /{s/^\# USER: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		user="$1"; group="$2"; userid="$3"
		descr="$4"; home="$5" shell="$6"
		IFS="$SAVEIFS"
		case $user in
		"")	continue ;;
		esac
		case $group in
		"")	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_USERS_DBDIR}/$user"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		if ${TEST} ! -d "$shadow_dir"; then
			${MKDIR} $shadow_dir
			user_exists $user $userid &&
				${ECHO} "${PKGNAME}" > $preexist
		fi
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" $token >/dev/null; then
			:
		else
			${ECHO} "${PKG_METADATA_DIR}" >> $token
		fi
		case ${_PKG_CREATE_USERGROUP} in
		yes)
			group_exists $group || continue
			user_exists $user $userid
			case $? in
			0)	;;
			1)	adduser "$user" "$group" "$userid"	\
					"$descr" "$home" "$shell"
				;;
			esac
			;;
		esac
	done; }
	;;

REMOVE)
	${SED} -n "/^\# USER: /{s/^\# USER: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		user="$1"; group="$2"; userid="$3"
		descr="$4"; home="$5" shell="$6"
		IFS="$SAVEIFS"
		case $user in
		"")	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_USERS_DBDIR}/$user"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		tokentmp="$token.tmp.$$"
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" $token >/dev/null; then
			${CAT} "$token" | ${GREP} -v "^${PKG_METADATA_DIR}$" > $tokentmp
			case `${CAT} $tokentmp | ${SED} -n "$="` in
			"")
				${RM} -f $preexist $token $token.tmp.*
				${RMDIR} -p $shadow_dir 2>/dev/null || ${TRUE}
				;;
			*)
				${MV} -f $tokentmp $token
				;;
			esac
		fi
	done; }
	${SED} -n "/^\# GROUP: /{s/^\# GROUP: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		group="$1"; groupid="$2"
		IFS="$SAVEIFS"
		case $group in
		"")	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_GROUPS_DBDIR}/$group"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		tokentmp="$token.tmp.$$"
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" $token >/dev/null; then
			${CAT} "$token" | ${GREP} -v "^${PKG_METADATA_DIR}$" > $tokentmp
			case `${CAT} $tokentmp | ${SED} -n "$="` in
			"")
				${RM} -f $preexist $token $token.tmp.*
				${RMDIR} -p $shadow_dir 2>/dev/null || ${TRUE}
				;;
			*)
				${MV} -f $tokentmp $token
				;;
			esac
		fi
	done; }
	;;

CHECK-ADD)
	${SED} -n "/^\# GROUP: /{s/^\# GROUP: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		group="$1"; groupid="$2"
		IFS="$SAVEIFS"
		case $group in
		"")	continue ;;
		*)	group_exists $group $groupid && continue ;;
		esac
		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following groups need to be created for ${PKGNAME}:"
			${ECHO} ""
			;;
		esac
		case $groupid in
		"")	${ECHO} "	$group" ;;
		*)	${ECHO} "	$group (gid = $groupid)" ;;
		esac
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	${SED} -n "/^\# USER: /{s/^\# USER: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		user="$1"; group="$2"; userid="$3"
		descr="$4"; home="$5" shell="$6"
		IFS="$SAVEIFS"
		case $user in
		"")	continue ;;
		*)	user_exists $user $userid && continue ;;
		esac
		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following users need to be created for ${PKGNAME}:"
			${ECHO} ""
			;;
		esac
		: ${home:="/nonexistent"}
		: ${shell:="/sbin/nologin"}
		case $userid in
		"")	${ECHO} "	$user: $group, $home, $shell" ;;
		*)	${ECHO} "	$user (uid = $userid): $group, $home, $shell" ;;
		esac
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	;;

CHECK-REMOVE)
	${SED} -n "/^\# USER: /{s/^\# USER: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		user="$1"; group="$2"; userid="$3"
		descr="$4"; home="$5" shell="$6"
		IFS="$SAVEIFS"
		case $user in
		"")	continue ;;
		*)	user_exists $user $userid || continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_USERS_DBDIR}/$user"
		${TEST} ! -d "$shadow_dir" || continue	# refcount isn't zero
		existing_users="$existing_users $user"
	done
	case $existing_users in
	"")	;;
	*)	${ECHO} "==========================================================================="
		${ECHO} "The following users are no longer being used by ${PKGNAME},"
		${ECHO} "and they can be removed if no other software is using them:"
		${ECHO} ""
		${ECHO} "$existing_users" | listwrap 40
		${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	${SED} -n "/^\# GROUP: /{s/^\# GROUP: //;p;}" ${SELF} | ${SORT} -u |
	{ while read line; do
		SAVEIFS="$IFS"; IFS=":"
		set -- $line
		group="$1"; groupid="$2"
		IFS="$SAVEIFS"
		case $group in
		"")	continue ;;
		*)	group_exists $group $groupid || continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_GROUPS_DBDIR}/$group"
		${TEST} ! -d "$shadow_dir" || continue	# refcount isn't zero
		existing_groups="$existing_groups $group"
	done
	case $existing_groups in
	"")	;;
	*)	${ECHO} "==========================================================================="
		${ECHO} "The following groups are no longer being used by ${PKGNAME},"
		${ECHO} "and they can be removed if no other software is using them:"
		${ECHO} ""
		${ECHO} "$existing_groups" | listwrap 40
		${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	;;

*)
	${ECHO} "Usage: ./+USERGROUP ADD|REMOVE [metadatadir]"
	${ECHO} "       ./+USERGROUP CHECK-ADD|CHECK-REMOVE [metadatadir]"
	;;
esac
exit $exitcode

EOF
	${SED} -n "/^\# GROUP: /p" ${SELF} >> ./+USERGROUP
	${SED} -n "/^\# USER: /p" ${SELF} >> ./+USERGROUP
	${CHMOD} +x ./+USERGROUP
	;;
esac

# $NetBSD: files,v 1.11 2020/04/15 13:33:32 sborrill Exp $
#
# Generate a +FILES script that reference counts config files that are
# required for the proper functioning of the package.
#
case "${STAGE},$1" in
UNPACK,|UNPACK,+FILES)
	${CAT} > ./+FILES << 'EOF'
#!/bin/sh
#
# +FILES - reference-counted configuration file management script
#
# Usage: ./+FILES ADD|REMOVE|PERMS [metadatadir]
#        ./+FILES CHECK-ADD|CHECK-REMOVE|CHECK-PERMS [metadatadir]
#
# This script supports two actions, ADD and REMOVE, that will add or
# remove the configuration files needed by the package associated with
# <metadatadir>.  The CHECK-ADD action will check whether any files
# needed by the package are missing, and print an informative message
# noting those files.  The CHECK-REMOVE action will check whether
# any files needed by the package still exist, and print an informative
# message noting those files.  The CHECK-ADD and CHECK-REMOVE actions
# return non-zero if they detect either missing or existing files,
# respectively.  The PERMS action
# will correct any ownership or permission discrepancies between the
# existing files and the data in this script, and the CHECK-PERMS
# action will check whether any files have the wrong ownership or
# permission and print an informative message noting those files.  The
# CHECK-PERMS action will return non-zero if it detects files with
# wrong ownership or permissions.
#
# Lines starting with "# FILE: " are data read by this script that
# name the files that this package requires to exist to function
# correctly, along with the locations of the example files, e.g.
#
#	# FILE: /etc/bar.conf c /example/bar.conf
#	# FILE: /etc/baz/conf c /example/baz.conf 0600 foo-user foo-group
#
# For each FILE entry, if the file path is relative, then it is taken to
# be relative to ${PKG_PREFIX}.
#
# The second field in each FILE entry is a set of flags with the following
# meaning:
#
#	c	file is copied into place
#	f	ignore ${PKG_CONFIG}
#	r	file is an rc.d script (consider ${PKG_RCD_SCRIPTS})
#
AWK="/usr/bin/awk"
CAT="/bin/cat"
CP="/bin/cp"
CHGRP="/usr/bin/chgrp"
CHMOD="/bin/chmod"
CHOWN="/usr/sbin/chown"
CMP="/usr/bin/cmp"
ECHO="echo"
GREP="/usr/bin/grep"
LS="/bin/ls"
MKDIR="/bin/mkdir -p"
MV="mv -f"
PWD_CMD="/bin/pwd"
RM="/bin/rm"
RMDIR="/bin/rmdir"
SED="/usr/bin/sed"
SORT="/usr/bin/sort"
TEST="test"
TRUE="true"

SELF=$0
ACTION=$1

: "${PKG_PREFIX=/usr/pkg}"

case "${PKG_CONFIG:-YES}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_CONFIG=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_CONFIG=no
	;;
esac
case "${PKG_CONFIG_PERMS:-NO}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_CONFIG_PERMS=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_CONFIG_PERMS=no
	;;
esac
case "${PKG_RCD_SCRIPTS:-NO}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_RCD_SCRIPTS=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_RCD_SCRIPTS=no
	;;
esac

CURDIR=`${PWD_CMD}`
PKG_METADATA_DIR="${2-${CURDIR}}"
: ${PKGNAME="${PKG_METADATA_DIR##*/}"}
: ${PKG_DBDIR="${PKG_METADATA_DIR%/*}"}
: "${PKG_REFCOUNT_DBDIR=${PKG_DBDIR}.refcount}"
PKG_REFCOUNT_FILES_DBDIR="${PKG_REFCOUNT_DBDIR}/files"

exitcode=0
case $ACTION in
ADD)
	${SED} -n "/^\# FILE: /{s/^\# FILE: //;p;}" "${SELF}" | ${SORT} -u |
	while read file f_flags f_eg f_mode f_user f_group; do
		case $file in
		"")	continue ;;
		[!/]*)	file="${PKG_PREFIX}/$file" ;;
		esac
		case $f_flags in
		*c*)	;;
		*)	continue ;;
		esac
		case $f_eg in
		"")	continue ;;
		[!/]*)	f_eg="${PKG_PREFIX}/$f_eg" ;;
		esac

		shadow_dir="${PKG_REFCOUNT_FILES_DBDIR}$file"
		perms="$shadow_dir/+PERMISSIONS"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		if ${TEST} ! -d "$shadow_dir"; then
			${MKDIR} "$shadow_dir"
			${TEST} ! -f "$file" ||
				${ECHO} "${PKGNAME}" > "$preexist"
		fi
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" "$token" >/dev/null; then
			:
		else
			${ECHO} "${PKG_METADATA_DIR}" >> "$token"
		fi

		case $f_mode$f_user$f_group in
		"")	;;
	 	*)	${ECHO} "$f_mode $f_user $f_group" > "$perms" ;;
		esac
		if ${TEST} ! -f "$file" -a ! -f "$f_eg" -a ! -c "$f_eg"; then
			:
		else
			case "$f_flags:$_PKG_CONFIG:$_PKG_RCD_SCRIPTS" in
			*f*:*:*|[!r]:yes:*|[!r][!r]:yes:*|[!r][!r][!r]:yes:*|*r*:yes:yes)
				if ${TEST} -f "$file"; then
					${ECHO} "${PKGNAME}: $file already exists"
				elif ${TEST} -f "$f_eg" -o -c "$f_eg"; then
					${ECHO} "${PKGNAME}: copying $f_eg to $file"
					${CP} "$f_eg" "$file"
					case $f_user in
					"")	;;
					*)	${CHOWN} "$f_user" "$file" ;;
					esac
					case $f_group in
					"")	;;
					*)	${CHGRP} "$f_group" "$file" ;;
					esac
					case $f_mode in
					"")	;;
					*)	${CHMOD} "$f_mode" "$file" ;;
					esac
				fi
				;;
			esac
		fi
	done
	;;

REMOVE)
	${SED} -n "/^\# FILE: /{s/^\# FILE: //;p;}" "${SELF}" | ${SORT} -ru |
	while read file f_flags f_eg f_mode f_user f_group; do
		case $file in
		"")	continue ;;
		[!/]*)	file="${PKG_PREFIX}/$file" ;;
		esac
		case $f_flags in
		*c*)	;;
		*)	continue ;;
		esac
		case $f_eg in
		"")	continue ;;
		[!/]*)	f_eg="${PKG_PREFIX}/$f_eg" ;;
		esac

		shadow_dir="${PKG_REFCOUNT_FILES_DBDIR}$file"
		perms="$shadow_dir/+PERMISSIONS"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		tokentmp="$token.tmp.$$"
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" "$token" >/dev/null; then
			${CAT} "$token" | ${GREP} -v "^${PKG_METADATA_DIR}$" > "$tokentmp"
			case `${CAT} "$tokentmp" | ${SED} -n "$="` in
			"")
				if ${TEST} -f "$preexist"; then
					:
				elif ${TEST} -f "$file" -a \( -f "$f_eg" -o -c "$f_eg" \) && \
				     ${CMP} -s "$file" "$f_eg"; then
					case "$f_flags:$_PKG_CONFIG:$_PKG_RCD_SCRIPTS" in
					*f*:*:*|[!r]:yes:*|[!r][!r]:yes:*|[!r][!r][!r]:yes:*|*r*:yes:yes)
						${RM} -f "$file"
						;;
					esac
				fi
				${RM} -f "$perms" "$preexist" "$token" "$token.tmp".*
				${RMDIR} -p "$shadow_dir" 2>/dev/null || ${TRUE}
				;;
			*)
				${MV} -f "$tokentmp" "$token"
				;;
			esac
		fi
	done
	;;

PERMS)
	${SED} -n "/^\# FILE: /{s/^\# FILE: //;p;}" "${SELF}" | ${SORT} -ru |
	while read file f_flags f_eg f_mode f_user f_group; do
		case $_PKG_CONFIG:$_PKG_CONFIG_PERMS in
		yes:yes)	;;
		*)		continue ;;
		esac
		case $file in
		"")	continue ;;
		[!/]*)	file="${PKG_PREFIX}/$file" ;;
		esac
		case $f_user in
		"")	;;
		*)	${CHOWN} "$f_user" "$file" ;;
		esac
		case $f_group in
		"")	;;
		*)	${CHGRP} "$f_group" "$file" ;;
		esac
		case $f_mode in
		"")	;;
		*)	${CHMOD} "$f_mode" "$file" ;;
		esac
	done
	;;

CHECK-ADD)
	${SED} -n "/^\# FILE: /{s/^\# FILE: //;p;}" "${SELF}" | ${SORT} -ru |
	{ while read file f_flags f_eg f_mode f_user f_group; do
		case $file in
		"")	continue ;;
		[!/]*)	file="${PKG_PREFIX}/$file" ;;
		esac
		${TEST} ! -f "$file" || continue
		case $f_flags in
		*c*)	;;
		*)	continue ;;
		esac
		case $f_eg in
		"")	continue ;;
		[!/]*)	f_eg="${PKG_PREFIX}/$f_eg" ;;
		esac

		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following files should be created for ${PKGNAME}:"
			;;
		esac
		${ECHO} ""
		case $f_mode:$f_user:$f_group in
		::)
			${ECHO} "	$file"
			;;
		[!:]*::)
			${ECHO} "	$file (m=$f_mode)"
			;;
		[!:]*:[!:]*:)
			${ECHO} "	$file (m=$f_mode, o=$f_user)"
			;;
		[!:]*:[!:]*:[!:]*)
			${ECHO} "	$file (m=$f_mode, o=$f_user, g=$f_group)"
			;;
		esac
		${TEST} ! -f "$f_eg" || ${ECHO} "	    [$f_eg]"
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	;;

CHECK-REMOVE)
	${SED} -n "/^\# FILE: /{s/^\# FILE: //;p;}" "${SELF}" | ${SORT} -ru |
	{ while read file f_flags f_eg f_mode f_user f_group; do
		case $file in
		"")	continue ;;
		[!/]*)	file="${PKG_PREFIX}/$file" ;;
		esac
		${TEST} -f "$file" || continue
		shadow_dir="${PKG_REFCOUNT_FILES_DBDIR}$file"
		${TEST} ! -d "$shadow_dir" || continue	# refcount isn't zero
		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following files are no longer being used by ${PKGNAME},"
			${ECHO} "and they can be removed if no other packages are using them:"
			${ECHO} ""
			;;
		esac
		${ECHO} "	$file"
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	;;

CHECK-PERMS)
	tmpdir="./.pkginstall.$$"
	${MKDIR} -p "$tmpdir" 2>/dev/null || exit 1
	${CHMOD} 0700 "$tmpdir"
	${SED} -n "/^\# FILE: /{s/^\# FILE: //;p;}" "${SELF}" | ${SORT} -ru |
	{ while read file f_flags f_eg f_mode f_user f_group; do
		case $file in
		"")	continue ;;
		[!/]*)	file="${PKG_PREFIX}/$file" ;;
		esac
		${TEST} -f "$file" || continue
		case $f_mode:$f_user:$f_group in
		::)	continue ;;
		esac

		perms=`${LS} -l "$file" | ${AWK} '{ print $1":"$3":"$4 }'`
		testpath="$tmpdir/file_perms"
		${ECHO} > "$testpath"
		${CHMOD} "$f_mode" "$testpath" 2>/dev/null
		longmode=`${LS} -l "$testpath" | ${AWK} '{ print $1 }'`
		case $f_mode:$f_user:$f_group in
		:[!:]*:)
			case "$perms" in
			*:"$f_user":*)	continue ;;
			esac
			;;
		:[!:]*:[!:]*)
			case "$perms" in
			*:"$f_user":"$f_group")	continue ;;
			esac
			;;
		[!:]*::)
			case "$perms" in
			"$longmode":*:*)	continue ;;
			esac
			;;
		[!:]*:[!:]*:)
			case "$perms" in
			"$longmode":"$f_user":*)	continue ;;
			esac
			;;
		[!:]*:[!:]*:[!:]*)
			case "$perms" in
			"$longmode":"$f_user":"$f_group")	continue ;;
			esac
			;;
		esac

		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following files are used by ${PKGNAME} and have"
			${ECHO} "the wrong ownership and/or permissions:"
			${ECHO} ""
			;;
		esac
		case $f_mode:$f_user:$f_group in
		[!:]*::)
			${ECHO} "	$file (m=$f_mode)"
			;;
		[!:]*:[!:]*:)
			${ECHO} "	$file (m=$f_mode, o=$f_user)"
			;;
		[!:]*:[!:]*:[!:]*)
			${ECHO} "	$file (m=$f_mode, o=$f_user, g=$f_group)"
			;;
		esac
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	${RM} -fr "$tmpdir"
	;;

*)
	${ECHO} "Usage: ./+FILES ADD|REMOVE|PERMS [metadatadir]"
	${ECHO} "       ./+FILES CHECK-ADD|CHECK-REMOVE|CHECK-PERMS [metadatadir]"
	;;
esac
exit $exitcode

EOF
	${SED} -n "/^\# FILE: /p" "${SELF}" >> ./+FILES
	${CHMOD} +x ./+FILES
	;;
esac
# $NetBSD: dirs,v 1.4 2008/01/04 21:50:27 heinz Exp $
#
# Generate a +DIRS script that reference counts directories that are
# required for the proper functioning of the package.
#
case "${STAGE},$1" in
UNPACK,|UNPACK,+DIRS)
	${CAT} > ./+DIRS << 'EOF'
#!/bin/sh
#
# +DIRS - reference-counted directory management script
#
# Usage: ./+DIRS ADD|REMOVE|PERMS [metadatadir]
#        ./+DIRS CHECK-ADD|CHECK-REMOVE|CHECK-PERMS [metadatadir]
#
# This script supports two actions, ADD and REMOVE, that will add or
# remove the directories needed by the package associated with
# <metadatadir>.  The CHECK-ADD action will check whether any directories
# needed by the package are missing, and print an informative message
# noting those directories.  The CHECK-REMOVE action will check whether
# any directories needed by the package still exist, and print an
# informative message noting those directories.  The CHECK-ADD and
# CHECK-REMOVE actions return non-zero if they detect either missing
# or existing directories, respectively.  The PERMS action will correct
# any ownership or permission discrepancies between the existing
# directories and the data in this script, and the CHECK-PERMS action
# will check whether any directories have the wrong ownership or
# permission and print an informative message noting those directories.
# The CHECK-PERMS action will return non-zero if it detects directories
# with wrong ownership or permissions.
#
# Lines starting with "# DIR: " are data read by this script that
# name the directories that this package requires to exist to function
# correctly, e.g.
#
#	# DIR: /etc/foo m
#	# DIR: /var/log/foo/tmp mo 0700 foo-user foo-group
#	# DIR: share/foo-plugins fm
#
# For each DIR entry, if the directory path is relative, then it is taken
# to be relative to ${PKG_PREFIX}.
#
# The second field in each DIR entry is a set of flags with the following
# meanings:
#
#	f	ignore ${PKG_CONFIG}
#	m	create (make) the directory when ADDing
#	o	directory is owned by the package
#
AWK="/usr/bin/awk"
CAT="/bin/cat"
CHGRP="/usr/bin/chgrp"
CHMOD="/bin/chmod"
CHOWN="/usr/sbin/chown"
ECHO="echo"
GREP="/usr/bin/grep"
LS="/bin/ls"
MKDIR="/bin/mkdir -p"
MV="mv -f"
PWD_CMD="/bin/pwd"
RM="/bin/rm"
RMDIR="/bin/rmdir"
SED="/usr/bin/sed"
SORT="/usr/bin/sort"
TEST="test"
TRUE="true"

SELF=$0
ACTION=$1

CURDIR=`${PWD_CMD}`
PKG_METADATA_DIR="${2-${CURDIR}}"
: ${PKGNAME=${PKG_METADATA_DIR##*/}}
: ${PKG_DBDIR=${PKG_METADATA_DIR%/*}}
: ${PKG_REFCOUNT_DBDIR=${PKG_DBDIR}.refcount}
: ${PKG_PREFIX=/usr/pkg}

PKG_REFCOUNT_DIRS_DBDIR="${PKG_REFCOUNT_DBDIR}/dirs"

case "${PKG_CONFIG:-YES}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_CONFIG=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_CONFIG=no
	;;
esac
case "${PKG_CONFIG_PERMS:-NO}" in
[Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
	_PKG_CONFIG_PERMS=yes
	;;
[Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
	_PKG_CONFIG_PERMS=no
	;;
esac

exitcode=0
case $ACTION in
ADD)
	${SED} -n "/^\# DIR: /{s/^\# DIR: //;p;}" ${SELF} | ${SORT} -u |
	while read dir d_flags d_mode d_user d_group; do
		case $dir in
		"")	continue ;;
		[!/]*)	dir="${PKG_PREFIX}/$dir" ;;
		esac
		case $d_flags in
		*m*)	;;
		*)	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_DIRS_DBDIR}$dir"
		perms="$shadow_dir/+PERMISSIONS"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		if ${TEST} ! -d "$shadow_dir"; then
			${MKDIR} $shadow_dir
			${TEST} ! -d "$dir" ||
				${ECHO} "${PKGNAME}" > $preexist
		fi
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" $token >/dev/null; then
			:
		else
			${ECHO} "${PKG_METADATA_DIR}" >> $token
		fi
		case $d_mode$d_user$d_group in
		"")	;;
		*)	${ECHO} "$d_user $d_group $d_mode" > $perms ;;
		esac
		case $d_flags:$_PKG_CONFIG in
		*f*:*|*:yes)
			${MKDIR} $dir
			case $d_user in
			"")	;;
			*)	${CHOWN} $d_user $dir ;;
			esac
			case $d_group in
			"")	;;
			*)	${CHGRP} $d_group $dir ;;
			esac
			case $d_mode in
			"")	;;
			*)	${CHMOD} $d_mode $dir ;;
			esac
			;;
		esac
	done
	;;

REMOVE)
	${SED} -n "/^\# DIR: /{s/^\# DIR: //;p;}" ${SELF} | ${SORT} -ru |
	while read dir d_flags d_mode d_user d_group; do
		case $dir in
		"")	continue ;;
		[!/]*)	dir="${PKG_PREFIX}/$dir" ;;
		esac
		case $d_flags in
		*m*)	;;
		*)	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_DIRS_DBDIR}$dir"
		perms="$shadow_dir/+PERMISSIONS"
		preexist="$shadow_dir/+PREEXISTING"
		token="$shadow_dir/${PKGNAME}"
		tokentmp="$token.tmp.$$"
		if ${TEST} -f "$token" && \
		   ${GREP} "^${PKG_METADATA_DIR}$" $token >/dev/null; then
			${CAT} "$token" | ${GREP} -v "^${PKG_METADATA_DIR}$" > $tokentmp
			case `${CAT} $tokentmp | ${SED} -n "$="` in
			"")
				${TEST} -f "$preexist" ||
					{ case $d_flags:$_PKG_CONFIG in
					  *f*:*|*:yes)
						${RMDIR} -p $dir 2>/dev/null || ${TRUE};
						;;
					  esac; }
				${RM} -f $perms $preexist $token $token.tmp.*
				${RMDIR} -p $shadow_dir 2>/dev/null || ${TRUE}
				;;
			*)
				${MV} -f $tokentmp $token
				;;
			esac
		fi
	done
	;;

PERMS)
	${SED} -n "/^\# DIR: /{s/^\# DIR: //;p;}" ${SELF} | ${SORT} -u |
	while read dir d_flags d_mode d_user d_group; do
		case $_PKG_CONFIG:$_PKG_CONFIG_PERMS in
		yes:yes)	;;
		*)		continue ;;
		esac
		case $dir in
		"")	continue ;;
		[!/]*)	dir="${PKG_PREFIX}/$dir" ;;
		esac
		case $d_user in
		"")	;;
		*)	${CHOWN} $d_user $dir ;;
		esac
		case $d_group in
		"")	;;
		*)	${CHGRP} $d_group $dir ;;
		esac
		case $d_mode in
		"")	;;
		*)	${CHMOD} $d_mode $dir ;;
		esac
	done
	;;

CHECK-ADD)
	${SED} -n "/^\# DIR: /{s/^\# DIR: //;p;}" ${SELF} | ${SORT} -u |
	{ while read dir d_flags d_mode d_user d_group; do
		case $dir in
		"")	continue ;;
		[!/]*)	dir="${PKG_PREFIX}/$dir" ;;
		esac
		${TEST} ! -d "$dir" || continue
		case $d_flags in
		*m*)	;;
		*)	continue ;;
		esac
		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following directories should be created for ${PKGNAME}:"
			${ECHO} ""
			;;
		esac
		case $d_user:$d_group:$d_mode in
		[!:]*:[!:]*:[!:]*)
			${ECHO} "	$dir (m=$d_mode, o=$d_user, g=$d_group)"
			;;
		*)
			${ECHO} "	$dir"
			;;
		esac
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	;;

CHECK-REMOVE)
	${SED} -n "/^\# DIR: /{s/^\# DIR: //;p;}" ${SELF} | ${SORT} -ru |
	{ while read dir d_flags d_mode d_user d_group; do
		case $dir in
		"")	continue ;;
		[!/]*)	dir="${PKG_PREFIX}/$dir" ;;
		esac
		${TEST} -d "$dir" || continue
		case $d_flags in
		*o*)	;;
		*)	continue ;;
		esac
		shadow_dir="${PKG_REFCOUNT_DIRS_DBDIR}$dir"
		${TEST} ! -d "$shadow_dir" || continue	# refcount isn't zero
		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following directories are no longer being used by ${PKGNAME},"
			${ECHO} "and they can be removed if no other packages are using them:"
			${ECHO} ""
			;;
		esac
		${ECHO} "	$dir"
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	;;

CHECK-PERMS)
	tmpdir="./.pkginstall.$$"
	${MKDIR} -p $tmpdir 2>/dev/null || exit 1
	${CHMOD} 0700 $tmpdir
	${SED} -n "/^\# DIR: /{s/^\# DIR: //;p;}" ${SELF} | ${SORT} -ru |
	{ while read dir d_flags d_mode d_user d_group; do
		case $dir in
		"")	continue ;;
		[!/]*)	dir="${PKG_PREFIX}/$dir" ;;
		esac
		${TEST} -d "$dir" || continue
		case $d_user:$d_group:$d_mode in
		::)	continue ;;
		esac

		perms=`${LS} -ld $dir | ${AWK} '{ print $1":"$3":"$4 }'`
		testpath="$tmpdir/dir_perms"
		${MKDIR} -p $testpath
		${CHMOD} $d_mode $testpath 2>/dev/null
		longmode=`${LS} -ld $testpath | ${AWK} '{ print $1 }'`
		case $d_mode:$d_user:$d_group in
		:[!:]*:)
			case "$perms" in
			*:$d_user:*)	continue ;;
			esac
			;;
		:[!:]*:[!:]*)
			case "$perms" in
			*:$d_user:$d_group)	continue ;;
			esac
			;;
		[!:]*::)
			case "$perms" in
			$longmode:*:*)	continue ;;
			esac
			;;
		[!:]*:[!:]*:)
			case "$perms" in
			$longmode:$d_user:*)	continue ;;
			esac
			;;
		[!:]*:[!:]*:[!:]*)
			case "$perms" in
			$longmode:$d_user:$d_group)	continue ;;
			esac
			;;
		esac

		case "$printed_header" in
		yes)	;;
		*)	printed_header=yes
			${ECHO} "==========================================================================="
			${ECHO} "The following directories are used by ${PKGNAME} and"
			${ECHO} "have the wrong ownership and/or permissions:"
			${ECHO} ""
			;;
		esac
		case $d_mode:$d_user:$d_group in
		[!:]*::)
			${ECHO} "	$dir (m=$d_mode)"
			;;
		[!:]*:[!:]*:)
			${ECHO} "	$dir (m=$d_mode, o=$d_user)"
			;;
		[!:]*:[!:]*:[!:]*)
			${ECHO} "	$dir (m=$d_mode, o=$d_user, g=$d_group)"
			;;
		esac
	done
	case "$printed_header" in
	yes)	${ECHO} ""
		${ECHO} "==========================================================================="
		exit 1
		;;
	esac; }
	${TEST} $? -eq 0 || exitcode=1
	${RM} -fr $tmpdir
	;;

*)
	${ECHO} "Usage: ./+DIRS ADD|REMOVE|PERMS [metadatadir]"
	${ECHO} "       ./+DIRS CHECK-ADD|CHECK-REMOVE|CHECK-PERMS [metadatadir]"
	;;
esac
exit $exitcode

EOF
	${SED} -n "/^\# DIR: /p" ${SELF} >> ./+DIRS
	${CHMOD} +x ./+DIRS
	;;
esac

# $NetBSD: install,v 1.5 2017/06/14 16:23:09 prlw1 Exp $

case ${STAGE} in
PRE-INSTALL)
	#
	# Unpack the helper scriptlets.
	#
	${SH} ${SELF} ${PKGNAME} UNPACK
	#
	# Require that necessary users and groups exist or else fail the
	# installation of the package.
	#
	${TEST} ! -x ./+USERGROUP ||
		{ ./+USERGROUP ADD ${PKG_METADATA_DIR}
		  if ./+USERGROUP CHECK-ADD ${PKG_METADATA_DIR}; then
			:
		  else
			exit 1
		  fi; }
	${TEST} ! -x ./+DIRS ||
		./+DIRS ADD ${PKG_METADATA_DIR}
	${TEST} ! -x ./+DIRS ||
		./+DIRS PERMS ${PKG_METADATA_DIR}
        ;;

POST-INSTALL)
	#
	# Rebuild the system run-time library search path database.
	#
	${TEST} ! -x ./+SHLIBS ||
		./+SHLIBS ADD ${PKG_METADATA_DIR}
	#
	# Copy configuration/support files into place.
	#
        ${TEST} ! -x ./+FILES ||
		./+FILES ADD ${PKG_METADATA_DIR}
        ${TEST} ! -x ./+FILES ||
		./+FILES PERMS ${PKG_METADATA_DIR}
	#
	# Set special permissions on any files/directories that need them.
	#
	${TEST} ! -x ./+PERMS ||
		./+PERMS ${PKG_METADATA_DIR}
	#
	# Update any fonts databases.
	#
	${TEST} ! -x ./+FONTS ||
		./+FONTS ${PKG_METADATA_DIR}

	#
	# Update any icon theme caches.
	#
	${TEST} ! -x ./+ICON_THEMES ||
		./+ICON_THEMES UPDATE ${PKG_METADATA_DIR}

	# Check for any missing bits after we're finished installing.
	#
	${TEST} ! -x ./+DIRS ||
		./+DIRS CHECK-ADD ${PKG_METADATA_DIR}
	${TEST} ! -x ./+DIRS ||
		./+DIRS CHECK-PERMS ${PKG_METADATA_DIR}
	${TEST} ! -x ./+FILES ||
		./+FILES CHECK-ADD ${PKG_METADATA_DIR}
	${TEST} ! -x ./+FILES ||
		./+FILES CHECK-PERMS ${PKG_METADATA_DIR}

	#
	# Register shells in /etc/shells.
	#
	${TEST} ! -x ./+SHELL ||
		./+SHELL ADD ${PKG_METADATA_DIR}
	${TEST} ! -x ./+SHELL ||
		./+SHELL CHECK-ADD ${PKG_METADATA_DIR}
	#
	# Register info files.
	#
	${TEST} ! -x ./+INFO_FILES ||
		./+INFO_FILES ADD ${PKG_METADATA_DIR}

  #
  # Register package into ocaml-findlib.
  #
  ${TEST} ! -x ./+OCAML_FINDLIB_REGISTER ||
    ./+OCAML_FINDLIB_REGISTER ADD ${PKG_METADATA_DIR}
	;;
esac

# $NetBSD: INSTALL,v 1.4 2023/04/05 09:16:42 adam Exp $
#
# Create default symlinks in ${PKG_SYSCONFDIR} for enabled modules/sites
#

SITES_ENABLED="default inner-tunnel"
MODS_ENABLED="always attr_filter chap date detail detail.log
	      digest dynamic_clients eap echo exec expiration expr
	      files linelog logintime mschap ntlm_auth pap passwd preprocess
	      radutmp realm replicate soh sradutmp totp unix unpack utf8"

case ${STAGE} in
POST-INSTALL)
	${ECHO} "Enabling default modules and sites"
	${LN} -sf ./mods-config/preprocess/hints /usr/pkg/etc/raddb/hints
	${LN} -sf ./mods-config/preprocess/huntgroups /usr/pkg/etc/raddb/huntgroups
	${LN} -sf ./mods-config/files/authorize /usr/pkg/etc/raddb/users
	for s in ${SITES_ENABLED}; do
	    ${LN} -sf ../sites-available/${s} /usr/pkg/etc/raddb/sites-enabled/${s}
	done
	for m in ${MODS_ENABLED}; do
	    ${LN} -sf ../mods-available/${m} /usr/pkg/etc/raddb/mods-enabled/${m}
	done
	;;
esac
# $NetBSD: footer,v 1.1 2006/05/21 23:50:15 jlam Exp $

exit 0

# GROUP: radiusd
# USER: radiusd:radiusd:::/var/log/radiusd
# FILE: /etc/rc.d/radiusd cr share/examples/rc.d/radiusd 0755
# FILE: etc/raddb/README.rst c share/examples/freeradius/README.rst 0640 radiusd radiusd
# FILE: etc/raddb/certs/Makefile c share/examples/freeradius/certs/Makefile 0640 radiusd radiusd
# FILE: etc/raddb/certs/README.md c share/examples/freeradius/certs/README.md 0640 radiusd radiusd
# FILE: etc/raddb/certs/bootstrap c share/examples/freeradius/certs/bootstrap 0640 radiusd radiusd
# FILE: etc/raddb/certs/ca.cnf c share/examples/freeradius/certs/ca.cnf 0640 radiusd radiusd
# FILE: etc/raddb/certs/client.cnf c share/examples/freeradius/certs/client.cnf 0640 radiusd radiusd
# FILE: etc/raddb/certs/inner-server.cnf c share/examples/freeradius/certs/inner-server.cnf 0640 radiusd radiusd
# FILE: etc/raddb/certs/server.cnf c share/examples/freeradius/certs/server.cnf 0640 radiusd radiusd
# FILE: etc/raddb/certs/xpextensions c share/examples/freeradius/certs/xpextensions 0640 radiusd radiusd
# FILE: etc/raddb/clients.conf c share/examples/freeradius/clients.conf 0640 radiusd radiusd
# FILE: etc/raddb/dictionary c share/examples/freeradius/dictionary 0640 radiusd radiusd
# FILE: etc/raddb/experimental.conf c share/examples/freeradius/experimental.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/README.rst c share/examples/freeradius/mods-available/README.rst 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/abfab_psk_sql c share/examples/freeradius/mods-available/abfab_psk_sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/always c share/examples/freeradius/mods-available/always 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/attr_filter c share/examples/freeradius/mods-available/attr_filter 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/cache c share/examples/freeradius/mods-available/cache 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/cache_auth c share/examples/freeradius/mods-available/cache_auth 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/chap c share/examples/freeradius/mods-available/chap 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/couchbase c share/examples/freeradius/mods-available/couchbase 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/counter c share/examples/freeradius/mods-available/counter 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/cui c share/examples/freeradius/mods-available/cui 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/date c share/examples/freeradius/mods-available/date 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/detail c share/examples/freeradius/mods-available/detail 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/detail.example.com c share/examples/freeradius/mods-available/detail.example.com 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/detail.log c share/examples/freeradius/mods-available/detail.log 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/dhcp c share/examples/freeradius/mods-available/dhcp 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/dhcp_files c share/examples/freeradius/mods-available/dhcp_files 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/dhcp_passwd c share/examples/freeradius/mods-available/dhcp_passwd 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/dhcp_sql c share/examples/freeradius/mods-available/dhcp_sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/dhcp_sqlippool c share/examples/freeradius/mods-available/dhcp_sqlippool 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/digest c share/examples/freeradius/mods-available/digest 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/dynamic_clients c share/examples/freeradius/mods-available/dynamic_clients 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/eap c share/examples/freeradius/mods-available/eap 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/echo c share/examples/freeradius/mods-available/echo 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/etc_group c share/examples/freeradius/mods-available/etc_group 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/exec c share/examples/freeradius/mods-available/exec 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/expiration c share/examples/freeradius/mods-available/expiration 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/expr c share/examples/freeradius/mods-available/expr 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/files c share/examples/freeradius/mods-available/files 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/idn c share/examples/freeradius/mods-available/idn 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/inner-eap c share/examples/freeradius/mods-available/inner-eap 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/ippool c share/examples/freeradius/mods-available/ippool 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/json c share/examples/freeradius/mods-available/json 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/krb5 c share/examples/freeradius/mods-available/krb5 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/ldap c share/examples/freeradius/mods-available/ldap 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/ldap_google c share/examples/freeradius/mods-available/ldap_google 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/linelog c share/examples/freeradius/mods-available/linelog 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/logintime c share/examples/freeradius/mods-available/logintime 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/mac2ip c share/examples/freeradius/mods-available/mac2ip 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/mac2vlan c share/examples/freeradius/mods-available/mac2vlan 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/moonshot-targeted-ids c share/examples/freeradius/mods-available/moonshot-targeted-ids 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/mschap c share/examples/freeradius/mods-available/mschap 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/ntlm_auth c share/examples/freeradius/mods-available/ntlm_auth 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/opendirectory c share/examples/freeradius/mods-available/opendirectory 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/pam c share/examples/freeradius/mods-available/pam 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/pap c share/examples/freeradius/mods-available/pap 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/passwd c share/examples/freeradius/mods-available/passwd 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/perl c share/examples/freeradius/mods-available/perl 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/preprocess c share/examples/freeradius/mods-available/preprocess 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/python c share/examples/freeradius/mods-available/python 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/python3 c share/examples/freeradius/mods-available/python3 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/radutmp c share/examples/freeradius/mods-available/radutmp 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/realm c share/examples/freeradius/mods-available/realm 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/redis c share/examples/freeradius/mods-available/redis 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/rediswho c share/examples/freeradius/mods-available/rediswho 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/replicate c share/examples/freeradius/mods-available/replicate 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/rest c share/examples/freeradius/mods-available/rest 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/smbpasswd c share/examples/freeradius/mods-available/smbpasswd 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/smsotp c share/examples/freeradius/mods-available/smsotp 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/soh c share/examples/freeradius/mods-available/soh 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/sometimes c share/examples/freeradius/mods-available/sometimes 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/sql c share/examples/freeradius/mods-available/sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/sql_map c share/examples/freeradius/mods-available/sql_map 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/sqlcounter c share/examples/freeradius/mods-available/sqlcounter 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/sqlippool c share/examples/freeradius/mods-available/sqlippool 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/sradutmp c share/examples/freeradius/mods-available/sradutmp 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/totp c share/examples/freeradius/mods-available/totp 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/unbound c share/examples/freeradius/mods-available/unbound 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/unix c share/examples/freeradius/mods-available/unix 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/unpack c share/examples/freeradius/mods-available/unpack 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/utf8 c share/examples/freeradius/mods-available/utf8 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/wimax c share/examples/freeradius/mods-available/wimax 0640 radiusd radiusd
# FILE: etc/raddb/mods-available/yubikey c share/examples/freeradius/mods-available/yubikey 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/README.rst c share/examples/freeradius/mods-config/README.rst 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/attr_filter/access_challenge c share/examples/freeradius/mods-config/attr_filter/access_challenge 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/attr_filter/access_reject c share/examples/freeradius/mods-config/attr_filter/access_reject 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/attr_filter/accounting_response c share/examples/freeradius/mods-config/attr_filter/accounting_response 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/attr_filter/coa c share/examples/freeradius/mods-config/attr_filter/coa 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/attr_filter/post-proxy c share/examples/freeradius/mods-config/attr_filter/post-proxy 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/attr_filter/pre-proxy c share/examples/freeradius/mods-config/attr_filter/pre-proxy 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/files/accounting c share/examples/freeradius/mods-config/files/accounting 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/files/authorize c share/examples/freeradius/mods-config/files/authorize 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/files/dhcp c share/examples/freeradius/mods-config/files/dhcp 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/files/pre-proxy c share/examples/freeradius/mods-config/files/pre-proxy 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/perl/example.pl c share/examples/freeradius/mods-config/perl/example.pl 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/preprocess/hints c share/examples/freeradius/mods-config/preprocess/hints 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/preprocess/huntgroups c share/examples/freeradius/mods-config/preprocess/huntgroups 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/realm/freeradius-naptr-to-home-server.sh c share/examples/freeradius/mods-config/realm/freeradius-naptr-to-home-server.sh 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/mysql/dailycounter.conf c share/examples/freeradius/mods-config/sql/counter/mysql/dailycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/mysql/expire_on_login.conf c share/examples/freeradius/mods-config/sql/counter/mysql/expire_on_login.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/mysql/monthlycounter.conf c share/examples/freeradius/mods-config/sql/counter/mysql/monthlycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/mysql/noresetcounter.conf c share/examples/freeradius/mods-config/sql/counter/mysql/noresetcounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/mysql/weeklycounter.conf c share/examples/freeradius/mods-config/sql/counter/mysql/weeklycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/postgresql/dailycounter.conf c share/examples/freeradius/mods-config/sql/counter/postgresql/dailycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/postgresql/expire_on_login.conf c share/examples/freeradius/mods-config/sql/counter/postgresql/expire_on_login.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/postgresql/monthlycounter.conf c share/examples/freeradius/mods-config/sql/counter/postgresql/monthlycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/postgresql/noresetcounter.conf c share/examples/freeradius/mods-config/sql/counter/postgresql/noresetcounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/postgresql/weeklycounter.conf c share/examples/freeradius/mods-config/sql/counter/postgresql/weeklycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/sqlite/dailycounter.conf c share/examples/freeradius/mods-config/sql/counter/sqlite/dailycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/sqlite/expire_on_login.conf c share/examples/freeradius/mods-config/sql/counter/sqlite/expire_on_login.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/sqlite/monthlycounter.conf c share/examples/freeradius/mods-config/sql/counter/sqlite/monthlycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/sqlite/noresetcounter.conf c share/examples/freeradius/mods-config/sql/counter/sqlite/noresetcounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/counter/sqlite/weeklycounter.conf c share/examples/freeradius/mods-config/sql/counter/sqlite/weeklycounter.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/cui/mysql/queries.conf c share/examples/freeradius/mods-config/sql/cui/mysql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/cui/mysql/schema.sql c share/examples/freeradius/mods-config/sql/cui/mysql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/cui/postgresql/queries.conf c share/examples/freeradius/mods-config/sql/cui/postgresql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/cui/postgresql/schema.sql c share/examples/freeradius/mods-config/sql/cui/postgresql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/cui/sqlite/queries.conf c share/examples/freeradius/mods-config/sql/cui/sqlite/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/cui/sqlite/schema.sql c share/examples/freeradius/mods-config/sql/cui/sqlite/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/mssql/queries.conf c share/examples/freeradius/mods-config/sql/dhcp/mssql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/mssql/schema.sql c share/examples/freeradius/mods-config/sql/dhcp/mssql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/mysql/queries.conf c share/examples/freeradius/mods-config/sql/dhcp/mysql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/mysql/schema.sql c share/examples/freeradius/mods-config/sql/dhcp/mysql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/mysql/setup.sql c share/examples/freeradius/mods-config/sql/dhcp/mysql/setup.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/oracle/queries.conf c share/examples/freeradius/mods-config/sql/dhcp/oracle/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/oracle/schema.sql c share/examples/freeradius/mods-config/sql/dhcp/oracle/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/postgresql/queries.conf c share/examples/freeradius/mods-config/sql/dhcp/postgresql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/postgresql/schema.sql c share/examples/freeradius/mods-config/sql/dhcp/postgresql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/postgresql/setup.sql c share/examples/freeradius/mods-config/sql/dhcp/postgresql/setup.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/sqlite/queries.conf c share/examples/freeradius/mods-config/sql/dhcp/sqlite/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/dhcp/sqlite/schema.sql c share/examples/freeradius/mods-config/sql/dhcp/sqlite/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mssql/procedure.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/mssql/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mssql/queries.conf c share/examples/freeradius/mods-config/sql/ippool-dhcp/mssql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mssql/schema.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/mssql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mysql/procedure-no-skip-locked.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/mysql/procedure-no-skip-locked.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mysql/procedure.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/mysql/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mysql/queries.conf c share/examples/freeradius/mods-config/sql/ippool-dhcp/mysql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/mysql/schema.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/mysql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/oracle/procedure.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/oracle/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/oracle/queries.conf c share/examples/freeradius/mods-config/sql/ippool-dhcp/oracle/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/oracle/schema.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/oracle/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/postgresql/procedure.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/postgresql/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/postgresql/queries.conf c share/examples/freeradius/mods-config/sql/ippool-dhcp/postgresql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/postgresql/schema.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/postgresql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/sqlite/queries.conf c share/examples/freeradius/mods-config/sql/ippool-dhcp/sqlite/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool-dhcp/sqlite/schema.sql c share/examples/freeradius/mods-config/sql/ippool-dhcp/sqlite/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mongo/queries.conf c share/examples/freeradius/mods-config/sql/ippool/mongo/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mssql/procedure.sql c share/examples/freeradius/mods-config/sql/ippool/mssql/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mssql/queries.conf c share/examples/freeradius/mods-config/sql/ippool/mssql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mssql/schema.sql c share/examples/freeradius/mods-config/sql/ippool/mssql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mysql/procedure-no-skip-locked.sql c share/examples/freeradius/mods-config/sql/ippool/mysql/procedure-no-skip-locked.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mysql/procedure.sql c share/examples/freeradius/mods-config/sql/ippool/mysql/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mysql/queries.conf c share/examples/freeradius/mods-config/sql/ippool/mysql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/mysql/schema.sql c share/examples/freeradius/mods-config/sql/ippool/mysql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/oracle/procedure.sql c share/examples/freeradius/mods-config/sql/ippool/oracle/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/oracle/queries.conf c share/examples/freeradius/mods-config/sql/ippool/oracle/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/oracle/schema.sql c share/examples/freeradius/mods-config/sql/ippool/oracle/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/postgresql/procedure.sql c share/examples/freeradius/mods-config/sql/ippool/postgresql/procedure.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/postgresql/queries.conf c share/examples/freeradius/mods-config/sql/ippool/postgresql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/postgresql/schema.sql c share/examples/freeradius/mods-config/sql/ippool/postgresql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/sqlite/queries.conf c share/examples/freeradius/mods-config/sql/ippool/sqlite/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/ippool/sqlite/schema.sql c share/examples/freeradius/mods-config/sql/ippool/sqlite/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mongo/queries.conf c share/examples/freeradius/mods-config/sql/main/mongo/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mssql/process-radacct.sql c share/examples/freeradius/mods-config/sql/main/mssql/process-radacct.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mssql/queries.conf c share/examples/freeradius/mods-config/sql/main/mssql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mssql/schema.sql c share/examples/freeradius/mods-config/sql/main/mssql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mysql/extras/wimax/queries.conf c share/examples/freeradius/mods-config/sql/main/mysql/extras/wimax/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mysql/extras/wimax/schema.sql c share/examples/freeradius/mods-config/sql/main/mysql/extras/wimax/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mysql/process-radacct.sql c share/examples/freeradius/mods-config/sql/main/mysql/process-radacct.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mysql/queries.conf c share/examples/freeradius/mods-config/sql/main/mysql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mysql/schema.sql c share/examples/freeradius/mods-config/sql/main/mysql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/mysql/setup.sql c share/examples/freeradius/mods-config/sql/main/mysql/setup.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/ndb/README c share/examples/freeradius/mods-config/sql/main/ndb/README 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/ndb/schema.sql c share/examples/freeradius/mods-config/sql/main/ndb/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/ndb/setup.sql c share/examples/freeradius/mods-config/sql/main/ndb/setup.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/oracle/process-radacct.sql c share/examples/freeradius/mods-config/sql/main/oracle/process-radacct.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/oracle/queries.conf c share/examples/freeradius/mods-config/sql/main/oracle/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/oracle/schema.sql c share/examples/freeradius/mods-config/sql/main/oracle/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/postgresql/extras/cisco_h323_db_schema.sql c share/examples/freeradius/mods-config/sql/main/postgresql/extras/cisco_h323_db_schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/postgresql/extras/voip-postpaid.conf c share/examples/freeradius/mods-config/sql/main/postgresql/extras/voip-postpaid.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/postgresql/process-radacct.sql c share/examples/freeradius/mods-config/sql/main/postgresql/process-radacct.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/postgresql/queries.conf c share/examples/freeradius/mods-config/sql/main/postgresql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/postgresql/schema.sql c share/examples/freeradius/mods-config/sql/main/postgresql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/postgresql/setup.sql c share/examples/freeradius/mods-config/sql/main/postgresql/setup.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/sqlite/process-radacct-close-after-reload.pl c share/examples/freeradius/mods-config/sql/main/sqlite/process-radacct-close-after-reload.pl 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/sqlite/process-radacct-new-data-usage-period.sh c share/examples/freeradius/mods-config/sql/main/sqlite/process-radacct-new-data-usage-period.sh 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/sqlite/process-radacct-schema.sql c share/examples/freeradius/mods-config/sql/main/sqlite/process-radacct-schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/sqlite/queries.conf c share/examples/freeradius/mods-config/sql/main/sqlite/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/main/sqlite/schema.sql c share/examples/freeradius/mods-config/sql/main/sqlite/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/moonshot-targeted-ids/mysql/queries.conf c share/examples/freeradius/mods-config/sql/moonshot-targeted-ids/mysql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/moonshot-targeted-ids/mysql/schema.sql c share/examples/freeradius/mods-config/sql/moonshot-targeted-ids/mysql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/moonshot-targeted-ids/postgresql/queries.conf c share/examples/freeradius/mods-config/sql/moonshot-targeted-ids/postgresql/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/moonshot-targeted-ids/postgresql/schema.sql c share/examples/freeradius/mods-config/sql/moonshot-targeted-ids/postgresql/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/moonshot-targeted-ids/sqlite/queries.conf c share/examples/freeradius/mods-config/sql/moonshot-targeted-ids/sqlite/queries.conf 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/sql/moonshot-targeted-ids/sqlite/schema.sql c share/examples/freeradius/mods-config/sql/moonshot-targeted-ids/sqlite/schema.sql 0640 radiusd radiusd
# FILE: etc/raddb/mods-config/unbound/default.conf c share/examples/freeradius/mods-config/unbound/default.conf 0640 radiusd radiusd
# FILE: etc/raddb/panic.gdb c share/examples/freeradius/panic.gdb 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/abfab-tr c share/examples/freeradius/policy.d/abfab-tr 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/accounting c share/examples/freeradius/policy.d/accounting 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/canonicalization c share/examples/freeradius/policy.d/canonicalization 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/control c share/examples/freeradius/policy.d/control 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/cui c share/examples/freeradius/policy.d/cui 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/debug c share/examples/freeradius/policy.d/debug 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/dhcp c share/examples/freeradius/policy.d/dhcp 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/eap c share/examples/freeradius/policy.d/eap 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/filter c share/examples/freeradius/policy.d/filter 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/moonshot-targeted-ids c share/examples/freeradius/policy.d/moonshot-targeted-ids 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/operator-name c share/examples/freeradius/policy.d/operator-name 0640 radiusd radiusd
# FILE: etc/raddb/policy.d/rfc7542 c share/examples/freeradius/policy.d/rfc7542 0640 radiusd radiusd
# FILE: etc/raddb/proxy.conf c share/examples/freeradius/proxy.conf 0640 radiusd radiusd
# FILE: etc/raddb/radiusd.conf c share/examples/freeradius/radiusd.conf 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/README c share/examples/freeradius/sites-available/README 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/abfab-tls c share/examples/freeradius/sites-available/abfab-tls 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/abfab-tr-idp c share/examples/freeradius/sites-available/abfab-tr-idp 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/aws-nlb c share/examples/freeradius/sites-available/aws-nlb 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/buffered-sql c share/examples/freeradius/sites-available/buffered-sql 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/challenge c share/examples/freeradius/sites-available/challenge 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/channel_bindings c share/examples/freeradius/sites-available/channel_bindings 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/check-eap-tls c share/examples/freeradius/sites-available/check-eap-tls 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/coa c share/examples/freeradius/sites-available/coa 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/coa-relay c share/examples/freeradius/sites-available/coa-relay 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/control-socket c share/examples/freeradius/sites-available/control-socket 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/copy-acct-to-home-server c share/examples/freeradius/sites-available/copy-acct-to-home-server 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/decoupled-accounting c share/examples/freeradius/sites-available/decoupled-accounting 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/default c share/examples/freeradius/sites-available/default 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/dhcp c share/examples/freeradius/sites-available/dhcp 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/dhcp.relay c share/examples/freeradius/sites-available/dhcp.relay 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/dynamic-clients c share/examples/freeradius/sites-available/dynamic-clients 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/example c share/examples/freeradius/sites-available/example 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/google-ldap-auth c share/examples/freeradius/sites-available/google-ldap-auth 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/inner-tunnel c share/examples/freeradius/sites-available/inner-tunnel 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/originate-coa c share/examples/freeradius/sites-available/originate-coa 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/proxy-inner-tunnel c share/examples/freeradius/sites-available/proxy-inner-tunnel 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/resource-check c share/examples/freeradius/sites-available/resource-check 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/robust-proxy-accounting c share/examples/freeradius/sites-available/robust-proxy-accounting 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/soh c share/examples/freeradius/sites-available/soh 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/status c share/examples/freeradius/sites-available/status 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/tls c share/examples/freeradius/sites-available/tls 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/tls-cache c share/examples/freeradius/sites-available/tls-cache 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/totp c share/examples/freeradius/sites-available/totp 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/virtual.example.com c share/examples/freeradius/sites-available/virtual.example.com 0640 radiusd radiusd
# FILE: etc/raddb/sites-available/vmps c share/examples/freeradius/sites-available/vmps 0640 radiusd radiusd
# FILE: etc/raddb/templates.conf c share/examples/freeradius/templates.conf 0640 radiusd radiusd
# FILE: etc/raddb/trigger.conf c share/examples/freeradius/trigger.conf 0640 radiusd radiusd
# FILE: etc/raddb/certs/bootstrap c share/examples/freeradius/certs/bootstrap 0750 radiusd radiusd
# DIR: etc/raddb m 755 root wheel
# DIR: /etc/rc.d m
# DIR: /var/log/radiusd mo 0750 radiusd radiusd
# DIR: /var/run/radiusd mo 0750 radiusd radiusd
# DIR: etc/raddb/certs mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-available mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/attr_filter mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/files mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/perl mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/preprocess mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/counter mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/counter/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/counter/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/counter/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/cui mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/cui/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/cui/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/cui/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/dhcp mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/dhcp/mssql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/dhcp/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/dhcp/oracle mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/dhcp/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/dhcp/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool-dhcp mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool-dhcp/mssql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool-dhcp/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool-dhcp/oracle mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool-dhcp/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool-dhcp/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool/mongo mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool/mssql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool/oracle mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/ippool/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/mongo mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/mssql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/mysql/extras mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/mysql/extras/wimax mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/ndb mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/oracle mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/postgresql/extras mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/main/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/moonshot-targeted-ids mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/moonshot-targeted-ids/mysql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/moonshot-targeted-ids/postgresql mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/sql/moonshot-targeted-ids/sqlite mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-config/unbound mo 0750 radiusd radiusd
# DIR: etc/raddb/mods-enabled mo 0750 radiusd radiusd
# DIR: etc/raddb/policy.d mo 0750 radiusd radiusd
# DIR: etc/raddb/sites-available mo 0750 radiusd radiusd
# DIR: etc/raddb/sites-enabled mo 0750 radiusd radiusd
