#!/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 2009 Sun Microsystems, Inc.  All rights reserved.
# Use is subject to license terms.
#
# i.manifest - smf(5) service manifest install class action script
#

repfile=$PKG_INSTALL_ROOT/etc/svc/repository.db
export repfile

SVCCFG=/usr/sbin/svccfg
SVCADM=/usr/sbin/svcadm
AWK=/usr/bin/awk
RM=/usr/bin/rm
CP=/usr/bin/cp
MV=/usr/bin/mv
CHMOD=/usr/bin/chmod
CHOWN=/usr/bin/chown

#
# Helper function. Handle services deathrow file.
# Arguments: $1:manifest file.
#
svc_deathrow()
{
	TEMP=/tmp/svc_deathrow.$$
	DEATHROW_FILE=${PKG_INSTALL_ROOT}/etc/svc/deathrow
	#
	# Services deathrow file handling, file format:
	# <fmri>< ><manifest file>< ><package name>
	# (field separator is a space character)
	#
	if [ -s ${DEATHROW_FILE} ]; then
		#
		# Manifest file could be from another Solaris version, bypass
		# the service bundle and validation (we only need the fmris
		# list). Calling svccfg inventory with SVCCFG_NOVALIDATE=1 is
		# safe because there is no access to the alternate repository.
		#
		ENTITIES=`SVCCFG_NOVALIDATE=1 $SVCCFG inventory $1`
		for fmri in $ENTITIES; do
			#
			# If fmri matches one in deathrow file, remove the
			# line from the file.
			#
			>${TEMP}
			$AWK "(\$1==\"$fmri\") \
			    {next}; {print}" ${DEATHROW_FILE} >>${TEMP} && \
			    $MV ${TEMP} ${DEATHROW_FILE}
			$RM -f ${TEMP}
		done
	fi
}

#
# If the repository does not yet exist, create it from the appropriate seed.  If
# for some reason the seeds do not exist, svccfg(1M) will create the repository
# automatically.
#
if [ ! -f $repfile ]; then
	if [ -n "$SUNW_PKG_INSTALL_ZONENAME" -a \
	    "$SUNW_PKG_INSTALL_ZONENAME" != "global" ]; then
		[ -f $PKG_INSTALL_ROOT/lib/svc/seed/nonglobal.db ] && \
		$CP $PKG_INSTALL_ROOT/lib/svc/seed/nonglobal.db $repfile
	else
		[ -f $PKG_INSTALL_ROOT/lib/svc/seed/global.db ] && \
		$CP $PKG_INSTALL_ROOT/lib/svc/seed/global.db $repfile
	fi
	$CHMOD 0600 $repfile
	$CHOWN root:sys $repfile
fi

if [ ! -r $PKG_INSTALL_ROOT/etc/svc/volatile/repository_door ]; then
	#
	# smf(5) is not presently running for the destination environment.
	# Since we presently cannot refresh without a running svc.startd(1M), we
	# cannot consistently handle dependent placement.  Defer to next boot.
	#
	while read src dst; do
		$CP -p $src $dst
		# deathrow handling
		svc_deathrow $dst
	done
else
	#
	# Local package install.
	#
	while read src dst; do
		$CP -p $src $dst

		[ "$PKG_INSTALL_ROOT" = "" -o "$PKG_INSTALL_ROOT" = "/" ] && \
		    $SVCADM restart svc:/system/manifest-import:default
	done
fi

exit 0