summaryrefslogtreecommitdiffstats
path: root/base/migrate/70ToTxt/run.sh
blob: 294bb63c7c49f5b7410055fdfe95c987ce02e5aa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
#!/bin/sh
# --- BEGIN COPYRIGHT BLOCK ---
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
#
# Copyright (C) 2007 Red Hat, Inc.
# All rights reserved.
# --- END COPYRIGHT BLOCK ---

#####################################################################
###                                                               ###
###  This script converts a pre-existing CMS 7.0/7.01 ldif data   ###
###  file (e. g. - created via a utility such as db2ldif)         ###
###  into a normalized CMS 7.0/7.01 ldif text file.               ###
###                                                               ###
###  This subsequent normalized CMS 7.0/7.01 ldif text file       ###
###  can be migrated into CMS 7.0/7.01 or later utilizing         ###
###  the corresponding TxtTo<Target CMS Version> script which     ###
###  converts this normalized CMS 7.0/7.01 ldif text file into    ###
###  a <Target CMS Version> ldif data file.                       ###
###                                                               ###
###  This <Target CMS Version> ldif data file can then be         ###
###  imported into the internal database of the desired CMS       ###
###  server using a utility such as ldif2db.                      ###
###                                                               ###
#####################################################################


###
###  SERVER_ROOT - fully qualified path of the location of the server
###

#SERVER_ROOT=/export/home/migrate/cms701
#export SERVER_ROOT


###
###  INSTANCE  - if the CMS instance directory is called 'cert-ca',
###              set the CMS instance to 'ca'
###
###              NOTE:  When a single SERVER_ROOT contains more than
###                     one CMS instance, this script must be run multiple
###                     times.  To do this, there is only a need to change
###                     the INSTANCE parameter.
###

#INSTANCE=ca
#export INSTANCE


############################################################################
###                                                                      ###
###             *** DON'T CHANGE ANYTHING BELOW THIS LINE ***            ###
###                                                                      ###
############################################################################


###
###  Script-defined constants
###

CMS="CMS 7.0"
export CMS


OS_NAME=`uname`
export OS_NAME


##
##  Perform a usage check for the appropriate number of arguments:
##

if [ $# -lt 1 -o $# -gt 2 ] ; then
	echo
	echo "Usage:  $0 input [errors] > output"
	echo
	echo "        where:  input  - the specified ${CMS} ldif data file,"
	echo "                errors - an optional errors file containing"
	echo "                         skipped attributes, and"
	echo "                output - the normalized ${CMS} ldif text file."
	echo
	echo "                NOTE:  If no redirection is provided to"
	echo "                       'output', then the normalized"
	echo "                       ${CMS} ldif text will merely"
	echo "                       be echoed to stdout."
	echo
	exit 1
fi


###
###  Check that the specified "input" file exists and is a regular file.
###

if [ ! -f $1 ] ; then
	echo "ERROR:  Either the specified 'input' file, '$1', does not exist, "
	echo "        or it is not a regular file!"
	echo
	exit 2
fi


###
###  Check that the specified "input" file exists and is not empty.
###

if [ ! -s $1 ] ; then
	echo "ERROR:  The specified 'input' file, '$1', is empty!"
	echo
	exit 3
fi


###
###  If an "errors" file is specified, then check that it does not already
###  exist.
###

if [ $# -eq 2 ] ; then
	if [ -f $2 ] ; then
		echo "ERROR:  The specified 'errors' file, '$2', already exists!"
		echo "        Please specify a different file!"
		echo
		exit 4
	fi
fi


###
###  Check presence of user-defined variables
###

if [ -z "${SERVER_ROOT}" -o -z "${INSTANCE}" ] ; then
	echo "ERROR:  Please specify the SERVER_ROOT and INSTANCE "
	echo "        environment variables for this script!"
	echo
	exit 5
fi


###
###  Check that the specified SERVER_ROOT exists and is a directory
###

if [ ! -d "${SERVER_ROOT}" ] ; then
	echo "ERROR:  Either the specified SERVER_ROOT does not exist, "
	echo "        or it is not a directory!"
	echo
	exit 6
fi


###
###  Check that the specified INSTANCE exists and is a directory
###

if [ ! -d "${SERVER_ROOT}/cert-${INSTANCE}" ] ; then
	echo "ERROR:  Either the specified INSTANCE does not exist, "
	echo "        or it is not a directory!"
	echo
	exit 7
fi


###
###  Setup the appropriate library path environment variable
###  based upon the platform
###

if [ ${OS_NAME} = "HP-UX" ] ; then
	SHLIB_PATH=${SERVER_ROOT}/bin/cert/lib:${SERVER_ROOT}/bin/cert/jre/lib:${SERVER_ROOT}/bin/cert/jre/lib/PA_RISC/native_threads
	export SHLIB_PATH
elif [ ${OS_NAME} = "Linux" ] ; then
	LD_LIBRARY_PATH=${SERVER_ROOT}/bin/cert/lib:${SERVER_ROOT}/bin/cert/jre/lib:${SERVER_ROOT}/bin/cert/jre/lib/i386/native_threads
	export LD_LIBRARY_PATH
else # SunOS
	LD_LIBRARY_PATH=${SERVER_ROOT}/bin/cert/lib:${SERVER_ROOT}/bin/cert/jre/lib:${SERVER_ROOT}/bin/cert/jre/lib/sparc/native_threads
	export LD_LIBRARY_PATH
fi


###
###  Convert the specified ${CMS} ldif data file
###  into a normalized ${CMS} ldif text file.
###
###  NOTE:  As of SunOS JDK 1.4.0, the required "Unicode" classes
###         have been moved from "i18n.jar" to "rt.jar".
###

${SERVER_ROOT}/bin/cert/jre/bin/java -classpath ./classes:${SERVER_ROOT}/cert-${INSTANCE}/classes:${SERVER_ROOT}/bin/cert/classes:${SERVER_ROOT}/bin/cert/jars/certsrv.jar:${SERVER_ROOT}/bin/cert/jars/cmscore.jar:${SERVER_ROOT}/bin/cert/jars/nsutil.jar:${SERVER_ROOT}/bin/cert/jars/jss3.jar:${SERVER_ROOT}/bin/cert/jre/lib/rt.jar Main $1 $2