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