xref: /onnv-gate/usr/src/cmd/cmd-crypto/scripts/i.pkcs11conf (revision 0:68f95e015346)
1*0Sstevel@tonic-gate#
2*0Sstevel@tonic-gate# Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
3*0Sstevel@tonic-gate# Use is subject to license terms.
4*0Sstevel@tonic-gate#
5*0Sstevel@tonic-gate# CDDL HEADER START
6*0Sstevel@tonic-gate#
7*0Sstevel@tonic-gate# The contents of this file are subject to the terms of the
8*0Sstevel@tonic-gate# Common Development and Distribution License, Version 1.0 only
9*0Sstevel@tonic-gate# (the "License").  You may not use this file except in compliance
10*0Sstevel@tonic-gate# with the License.
11*0Sstevel@tonic-gate#
12*0Sstevel@tonic-gate# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
13*0Sstevel@tonic-gate# or http://www.opensolaris.org/os/licensing.
14*0Sstevel@tonic-gate# See the License for the specific language governing permissions
15*0Sstevel@tonic-gate# and limitations under the License.
16*0Sstevel@tonic-gate#
17*0Sstevel@tonic-gate# When distributing Covered Code, include this CDDL HEADER in each
18*0Sstevel@tonic-gate# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
19*0Sstevel@tonic-gate# If applicable, add the following below this CDDL HEADER, with the
20*0Sstevel@tonic-gate# fields enclosed by brackets "[]" replaced with your own identifying
21*0Sstevel@tonic-gate# information: Portions Copyright [yyyy] [name of copyright owner]
22*0Sstevel@tonic-gate#
23*0Sstevel@tonic-gate# CDDL HEADER END
24*0Sstevel@tonic-gate#
25*0Sstevel@tonic-gate# ident	"%Z%%M%	%I%	%E% SMI"
26*0Sstevel@tonic-gate#
27*0Sstevel@tonic-gate# Class action script for "pkcs11conf" class files.
28*0Sstevel@tonic-gate#
29*0Sstevel@tonic-gate# This script appends the input file from the package to the
30*0Sstevel@tonic-gate# /etc/crypto/pkcs11.conf file.
31*0Sstevel@tonic-gate#
32*0Sstevel@tonic-gate# The syntax of the input file is <file_name>
33*0Sstevel@tonic-gate# Where
34*0Sstevel@tonic-gate#   The file name should contain the full path.
35*0Sstevel@tonic-gate#   One entry per file name.
36*0Sstevel@tonic-gate#
37*0Sstevel@tonic-gatepkg_start="# Start $PKGINST"
38*0Sstevel@tonic-gatepkg_end="# End $PKGINST"
39*0Sstevel@tonic-gatetmpfile=/tmp/$$pkcs11conf
40*0Sstevel@tonic-gateerror=no
41*0Sstevel@tonic-gate
42*0Sstevel@tonic-gatewhile read src dest
43*0Sstevel@tonic-gatedo
44*0Sstevel@tonic-gate	[ "$src" = /dev/null ] && continue
45*0Sstevel@tonic-gate
46*0Sstevel@tonic-gate	if [ -f "$dest" ]
47*0Sstevel@tonic-gate	then
48*0Sstevel@tonic-gate		# For multiple input files; exit if error occurred in previous
49*0Sstevel@tonic-gate		# input file.
50*0Sstevel@tonic-gate		if [ "$error" = yes ]
51*0Sstevel@tonic-gate		then
52*0Sstevel@tonic-gate			echo "$0: failed to update $lastdest for $PKGINST."
53*0Sstevel@tonic-gate			exit 2
54*0Sstevel@tonic-gate		fi
55*0Sstevel@tonic-gate		lastdest=$dest
56*0Sstevel@tonic-gate
57*0Sstevel@tonic-gate		#
58*0Sstevel@tonic-gate		# If the package has been already installed, remove old entries
59*0Sstevel@tonic-gate		#
60*0Sstevel@tonic-gate		start=0;
61*0Sstevel@tonic-gate		end=0;
62*0Sstevel@tonic-gate		egrep -s "$pkg_start" $dest && start=1
63*0Sstevel@tonic-gate		egrep -s "$pkg_end" $dest && end=1
64*0Sstevel@tonic-gate
65*0Sstevel@tonic-gate		if [ $start -ne $end ]
66*0Sstevel@tonic-gate		then
67*0Sstevel@tonic-gate			echo "$0: missing Start or End delimiters for \
68*0Sstevel@tonic-gate			    $PKGINST in $dest."
69*0Sstevel@tonic-gate			echo "$0: $dest may be corrupted and was not updated."
70*0Sstevel@tonic-gate			error=yes
71*0Sstevel@tonic-gate			continue
72*0Sstevel@tonic-gate		fi
73*0Sstevel@tonic-gate
74*0Sstevel@tonic-gate		if [ $start -eq 1 ]
75*0Sstevel@tonic-gate		then
76*0Sstevel@tonic-gate			sed -e "/$pkg_start/,/$pkg_end/d" $dest > $tmpfile \
77*0Sstevel@tonic-gate                        || error=yes
78*0Sstevel@tonic-gate		else
79*0Sstevel@tonic-gate			cp $dest $tmpfile || error=yes
80*0Sstevel@tonic-gate		fi
81*0Sstevel@tonic-gate
82*0Sstevel@tonic-gate		#
83*0Sstevel@tonic-gate		# Check the input file syntax (each line should start with /)
84*0Sstevel@tonic-gate		# and append the input entries with the package delimiters.
85*0Sstevel@tonic-gate		#
86*0Sstevel@tonic-gate		line_count=`wc -l $src | awk '{ print $1}'`
87*0Sstevel@tonic-gate		file_count=`grep "^/" $src | wc -l`
88*0Sstevel@tonic-gate
89*0Sstevel@tonic-gate		if [ $line_count -ne $file_count ]
90*0Sstevel@tonic-gate		then
91*0Sstevel@tonic-gate			echo "$0: Syntax Error - $src for $PKGINST."
92*0Sstevel@tonic-gate			error=yes
93*0Sstevel@tonic-gate			continue
94*0Sstevel@tonic-gate		else
95*0Sstevel@tonic-gate			echo "$pkg_start" >> $tmpfile || error=yes
96*0Sstevel@tonic-gate			cat $src >> $tmpfile || error=yes
97*0Sstevel@tonic-gate			echo "$pkg_end" >> $tmpfile || error=yes
98*0Sstevel@tonic-gate		fi
99*0Sstevel@tonic-gate
100*0Sstevel@tonic-gate		# Install the updated config file and clean up the tmp file
101*0Sstevel@tonic-gate                if [ "$error" = no ]
102*0Sstevel@tonic-gate                then
103*0Sstevel@tonic-gate			mv $tmpfile $dest || error=yes
104*0Sstevel@tonic-gate		fi
105*0Sstevel@tonic-gate		rm -f $tmpfile
106*0Sstevel@tonic-gate	else
107*0Sstevel@tonic-gate		echo "$0: ERROR - $dest doesn't exist for $PKGINST."
108*0Sstevel@tonic-gate		exit 2
109*0Sstevel@tonic-gate	fi
110*0Sstevel@tonic-gatedone
111*0Sstevel@tonic-gate
112*0Sstevel@tonic-gateif [ "$error" = yes ]
113*0Sstevel@tonic-gatethen
114*0Sstevel@tonic-gate	echo "$0: ERROR - failed to update $lastdest for $PKGINST."
115*0Sstevel@tonic-gate	exit 2
116*0Sstevel@tonic-gatefi
117*0Sstevel@tonic-gate
118*0Sstevel@tonic-gateexit 0
119