#! /usr/bin/sh
#
# CDDL HEADER START
#
# The contents of this file are subject to the terms of the
# Common Development and Distribution License (the "License").
# You may not use this file except in compliance with the License.
#
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
# or http://www.opensolaris.org/os/licensing.
# See the License for the specific language governing permissions
# and limitations under the License.
#
# When distributing Covered Code, include this CDDL HEADER in each
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
# If applicable, add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your own identifying
# information: Portions Copyright [yyyy] [name of copyright owner]
#
# CDDL HEADER END
#

#
# Copyright (c) 2009, 2010, Oracle and/or its affiliates. All rights reserved.
#

. /lib/svc/share/smf_include.sh

files='/etc/user_attr /etc/security/auth_attr /etc/security/exec_attr
    /etc/security/prof_attr'

PKGINST=
export PKGINST

irbac=/usr/sadm/install/scripts/i.rbac

if [ ! -x $irbac ]
then
	echo "${irbac}: not found."
	exit $SMF_EXIT_ERR_FATAL
fi

case "$1" in
start|refresh)
	;;
stop)
	exit $SMF_EXIT_OK;;
*)
	echo "Usage: $0 { start | refresh | stop }"
	exit $SMF_EXIT_ERR_FATAL;;
esac
	
tmp_rbac=`/usr/bin/mktemp -d /tmp/rbac.XXXXXX`
if [ -z "$tmp_rbac" ]
then
	echo "Could not create temporary directory."
	exit $SMF_EXIT_ERR_FATAL
fi
tmp_frag=$tmp_rbac/frag
tmp_file=$tmp_rbac/file

for f in $files
do
	d=${f}.d
	if [ ! -d ${d} ]
	then
		# No directory, nothing to do
		continue
	fi
	# cache user/owner of file to update
	ownergroup=`ls -ln $f | awk '{printf("%s:%s\n", $3, $4);'}`
	#
	# List all the files in the directory and the destination file
	# in the order of their timestamp.  Older files are displayed
	# first.  If a fragment file is listed before the destination
	# file, it is an older fragment that has already been processed.
	# If a fragment file is listed after the destination file, it is
	# new, and the destination file must be updated.
	#
	# Comments are processed separately from the other file contents.
	# For new fragments only, the comments are processed as they are
	# encountered.  For all fragments, the non-comment contents are
	# saved in a temporary file.  After all fragments have been
	# processed, and only if new fragments were found, the contents
	# of the temporary file are processed.  This ensures that older
	# but still valid entries are retained in the destination file.
	#
	/usr/bin/rm -f $tmp_file
	new_frag=0
	update=0
	for frag in `ls -tr $f $d/* 2> /dev/null`
	do
		if [ "$frag" = "$f" ]
		then
			new_frag=1
			continue
		fi
		if [ -f "$frag" ]
		then
			if [ $new_frag -eq 1 ]
			then
				/usr/bin/rm -f $tmp_frag
				/usr/bin/grep '^#' $frag > $tmp_frag
				update=1
				echo $tmp_frag $f | $irbac
			fi
			/usr/bin/grep -v '^#' $frag >> $tmp_file
		fi
	done
	if [ $update -eq 1 ]
	then
		echo $tmp_file $f | $irbac
		chown $ownergroup $f
	fi
done

/usr/bin/rm -rf $tmp_rbac

exit $SMF_EXIT_OK