Compare commits
	
		
			2 Commits
		
	
	
		
			OpenSSL_0_
			...
			BEFORE_COM
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					fe8767737b | ||
| 
						 | 
					606efc54e6 | 
@@ -1,5 +1,4 @@
 | 
				
			|||||||
openssl.pc
 | 
					Makefile.ssl
 | 
				
			||||||
Makefile
 | 
					 | 
				
			||||||
MINFO
 | 
					MINFO
 | 
				
			||||||
makefile.one
 | 
					makefile.one
 | 
				
			||||||
tmp
 | 
					tmp
 | 
				
			||||||
@@ -14,7 +13,3 @@ cctest.c
 | 
				
			|||||||
cctest.a
 | 
					cctest.a
 | 
				
			||||||
libcrypto.so.*
 | 
					libcrypto.so.*
 | 
				
			||||||
libssl.so.*
 | 
					libssl.so.*
 | 
				
			||||||
libcrypto.sha1
 | 
					 | 
				
			||||||
libcrypto.a.sha1
 | 
					 | 
				
			||||||
*.flc
 | 
					 | 
				
			||||||
semantic.cache
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										243
									
								
								FAQ
									
									
									
									
									
								
							
							
						
						
									
										243
									
								
								FAQ
									
									
									
									
									
								
							@@ -9,7 +9,6 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* Where can I get a compiled version of OpenSSL?
 | 
					* Where can I get a compiled version of OpenSSL?
 | 
				
			||||||
* Why aren't tools like 'autoconf' and 'libtool' used?
 | 
					* Why aren't tools like 'autoconf' and 'libtool' used?
 | 
				
			||||||
* What is an 'engine' version?
 | 
					* What is an 'engine' version?
 | 
				
			||||||
* How do I check the authenticity of the OpenSSL distribution?
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
[LEGAL] Legal questions
 | 
					[LEGAL] Legal questions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -37,22 +36,15 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* Why does the linker complain about undefined symbols?
 | 
					* Why does the linker complain about undefined symbols?
 | 
				
			||||||
* Why does the OpenSSL test fail with "bc: command not found"?
 | 
					* Why does the OpenSSL test fail with "bc: command not found"?
 | 
				
			||||||
* Why does the OpenSSL test fail with "bc: 1 no implemented"?
 | 
					* Why does the OpenSSL test fail with "bc: 1 no implemented"?
 | 
				
			||||||
* Why does the OpenSSL test fail with "bc: stack empty"?
 | 
					 | 
				
			||||||
* Why does the OpenSSL compilation fail on Alpha Tru64 Unix?
 | 
					* Why does the OpenSSL compilation fail on Alpha Tru64 Unix?
 | 
				
			||||||
* Why does the OpenSSL compilation fail with "ar: command not found"?
 | 
					* Why does the OpenSSL compilation fail with "ar: command not found"?
 | 
				
			||||||
* Why does the OpenSSL compilation fail on Win32 with VC++?
 | 
					* Why does the OpenSSL compilation fail on Win32 with VC++?
 | 
				
			||||||
* What is special about OpenSSL on Redhat?
 | 
					 | 
				
			||||||
* Why does the OpenSSL compilation fail on MacOS X?
 | 
					 | 
				
			||||||
* Why does the OpenSSL test suite fail on MacOS X?
 | 
					 | 
				
			||||||
* Why does the OpenSSL test suite fail in BN_sqr test [on a 64-bit platform]?
 | 
					 | 
				
			||||||
* Why does OpenBSD-i386 build fail on des-586.s with "Unimplemented segment type"?
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
[PROG] Questions about programming with OpenSSL
 | 
					[PROG] Questions about programming with OpenSSL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Is OpenSSL thread-safe?
 | 
					* Is OpenSSL thread-safe?
 | 
				
			||||||
* I've compiled a program under Windows and it crashes: why?
 | 
					* I've compiled a program under Windows and it crashes: why?
 | 
				
			||||||
* How do I read or write a DER encoded buffer using the ASN1 functions?
 | 
					* How do I read or write a DER encoded buffer using the ASN1 functions?
 | 
				
			||||||
* OpenSSL uses DER but I need BER format: does OpenSSL support BER?
 | 
					 | 
				
			||||||
* I've tried using <M_some_evil_pkcs12_macro> and I get errors why?
 | 
					* I've tried using <M_some_evil_pkcs12_macro> and I get errors why?
 | 
				
			||||||
* I've called <some function> and it fails, why?
 | 
					* I've called <some function> and it fails, why?
 | 
				
			||||||
* I just get a load of numbers for the error output, what do they mean?
 | 
					* I just get a load of numbers for the error output, what do they mean?
 | 
				
			||||||
@@ -60,8 +52,6 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* Why can't the OpenSSH configure script detect OpenSSL?
 | 
					* Why can't the OpenSSH configure script detect OpenSSL?
 | 
				
			||||||
* Can I use OpenSSL's SSL library with non-blocking I/O?
 | 
					* Can I use OpenSSL's SSL library with non-blocking I/O?
 | 
				
			||||||
* Why doesn't my server application receive a client certificate?
 | 
					* Why doesn't my server application receive a client certificate?
 | 
				
			||||||
* Why does compilation fail due to an undefined symbol NID_uniqueIdentifier?
 | 
					 | 
				
			||||||
* I think I've detected a memory leak, is this a bug?
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
===============================================================================
 | 
					===============================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -70,7 +60,7 @@ OpenSSL  -  Frequently Asked Questions
 | 
				
			|||||||
* Which is the current version of OpenSSL?
 | 
					* Which is the current version of OpenSSL?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The current version is available from <URL: http://www.openssl.org>.
 | 
					The current version is available from <URL: http://www.openssl.org>.
 | 
				
			||||||
OpenSSL 0.9.7m was released on Feb 23rd, 2007.
 | 
					OpenSSL 0.9.6d was released on May 9, 2002.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
In addition to the current stable release, you can also access daily
 | 
					In addition to the current stable release, you can also access daily
 | 
				
			||||||
snapshots of the OpenSSL development version at <URL:
 | 
					snapshots of the OpenSSL development version at <URL:
 | 
				
			||||||
@@ -118,14 +108,11 @@ OpenSSL.  Information on the OpenSSL mailing lists is available from
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
* Where can I get a compiled version of OpenSSL?
 | 
					* Where can I get a compiled version of OpenSSL?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
You can finder pointers to binary distributions in
 | 
					 | 
				
			||||||
http://www.openssl.org/related/binaries.html .
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Some applications that use OpenSSL are distributed in binary form.
 | 
					Some applications that use OpenSSL are distributed in binary form.
 | 
				
			||||||
When using such an application, you don't need to install OpenSSL
 | 
					When using such an application, you don't need to install OpenSSL
 | 
				
			||||||
yourself; the application will include the required parts (e.g. DLLs).
 | 
					yourself; the application will include the required parts (e.g. DLLs).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If you want to build OpenSSL on a Windows system and you don't have
 | 
					If you want to install OpenSSL on a Windows system and you don't have
 | 
				
			||||||
a C compiler, read the "Mingw32" section of INSTALL.W32 for information
 | 
					a C compiler, read the "Mingw32" section of INSTALL.W32 for information
 | 
				
			||||||
on how to obtain and install the free GNU C compiler.
 | 
					on how to obtain and install the free GNU C compiler.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -141,21 +128,8 @@ less Unix-centric, it might have been used much earlier.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
With version 0.9.6 OpenSSL was extended to interface to external crypto
 | 
					With version 0.9.6 OpenSSL was extended to interface to external crypto
 | 
				
			||||||
hardware. This was realized in a special release '0.9.6-engine'. With
 | 
					hardware. This was realized in a special release '0.9.6-engine'. With
 | 
				
			||||||
version 0.9.7 the changes were merged into the main development line,
 | 
					version 0.9.7 (not yet released) the changes were merged into the main
 | 
				
			||||||
so that the special release is no longer necessary.
 | 
					development line, so that the special release is no longer necessary.
 | 
				
			||||||
 | 
					 | 
				
			||||||
* How do I check the authenticity of the OpenSSL distribution?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
We provide MD5 digests and ASC signatures of each tarball.
 | 
					 | 
				
			||||||
Use MD5 to check that a tarball from a mirror site is identical:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   md5sum TARBALL | awk '{print $1;}' | cmp - TARBALL.md5
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
You can check authenticity using pgp or gpg. You need the OpenSSL team
 | 
					 | 
				
			||||||
member public key used to sign it (download it from a key server). Then
 | 
					 | 
				
			||||||
just do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   pgp TARBALL.asc
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
[LEGAL] =======================================================================
 | 
					[LEGAL] =======================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -194,30 +168,18 @@ for permission to use their software with OpenSSL.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
Cryptographic software needs a source of unpredictable data to work
 | 
					Cryptographic software needs a source of unpredictable data to work
 | 
				
			||||||
correctly.  Many open source operating systems provide a "randomness
 | 
					correctly.  Many open source operating systems provide a "randomness
 | 
				
			||||||
device" (/dev/urandom or /dev/random) that serves this purpose.
 | 
					device" that serves this purpose.  On other systems, applications have
 | 
				
			||||||
All OpenSSL versions try to use /dev/urandom by default; starting with
 | 
					to call the RAND_add() or RAND_seed() function with appropriate data
 | 
				
			||||||
version 0.9.7, OpenSSL also tries /dev/random if /dev/urandom is not
 | 
					before generating keys or performing public key encryption.
 | 
				
			||||||
available.
 | 
					(These functions initialize the pseudo-random number generator, PRNG.)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
On other systems, applications have to call the RAND_add() or
 | 
					Some broken applications do not do this.  As of version 0.9.5, the
 | 
				
			||||||
RAND_seed() function with appropriate data before generating keys or
 | 
					OpenSSL functions that need randomness report an error if the random
 | 
				
			||||||
performing public key encryption. (These functions initialize the
 | 
					number generator has not been seeded with at least 128 bits of
 | 
				
			||||||
pseudo-random number generator, PRNG.)  Some broken applications do
 | 
					randomness.  If this error occurs, please contact the author of the
 | 
				
			||||||
not do this.  As of version 0.9.5, the OpenSSL functions that need
 | 
					application you are using.  It is likely that it never worked
 | 
				
			||||||
randomness report an error if the random number generator has not been
 | 
					correctly.  OpenSSL 0.9.5 and later make the error visible by refusing
 | 
				
			||||||
seeded with at least 128 bits of randomness.  If this error occurs and
 | 
					to perform potentially insecure encryption.
 | 
				
			||||||
is not discussed in the documentation of the application you are
 | 
					 | 
				
			||||||
using, please contact the author of that application; it is likely
 | 
					 | 
				
			||||||
that it never worked correctly.  OpenSSL 0.9.5 and later make the
 | 
					 | 
				
			||||||
error visible by refusing to perform potentially insecure encryption.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If you are using Solaris 8, you can add /dev/urandom and /dev/random
 | 
					 | 
				
			||||||
devices by installing patch 112438 (Sparc) or 112439 (x86), which are
 | 
					 | 
				
			||||||
available via the Patchfinder at <URL: http://sunsolve.sun.com>
 | 
					 | 
				
			||||||
(Solaris 9 includes these devices by default). For /dev/random support
 | 
					 | 
				
			||||||
for earlier Solaris versions, see Sun's statement at
 | 
					 | 
				
			||||||
<URL: http://sunsolve.sun.com/pub-cgi/retrieve.pl?doc=fsrdb/27606&zone_32=SUNWski>
 | 
					 | 
				
			||||||
(the SUNWski package is available in patch 105710).
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
On systems without /dev/urandom and /dev/random, it is a good idea to
 | 
					On systems without /dev/urandom and /dev/random, it is a good idea to
 | 
				
			||||||
use the Entropy Gathering Demon (EGD); see the RAND_egd() manpage for
 | 
					use the Entropy Gathering Demon (EGD); see the RAND_egd() manpage for
 | 
				
			||||||
@@ -250,6 +212,13 @@ OpenSSL command line tools. Applications using the OpenSSL library
 | 
				
			|||||||
provide their own configuration options to specify the entropy source,
 | 
					provide their own configuration options to specify the entropy source,
 | 
				
			||||||
please check out the documentation coming the with application.
 | 
					please check out the documentation coming the with application.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					For Solaris 2.6, Tim Nibbe <tnibbe@sprint.net> and others have suggested
 | 
				
			||||||
 | 
					installing the SUNski package from Sun patch 105710-01 (Sparc) which
 | 
				
			||||||
 | 
					adds a /dev/random device and make sure it gets used, usually through
 | 
				
			||||||
 | 
					$RANDFILE.  There are probably similar patches for the other Solaris
 | 
				
			||||||
 | 
					versions.  However, be warned that /dev/random is usually a blocking
 | 
				
			||||||
 | 
					device, which may have some effects on OpenSSL.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Why do I get an "unable to write 'random state'" error message?
 | 
					* Why do I get an "unable to write 'random state'" error message?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -426,17 +395,6 @@ and compile/install it.  GNU bc (see http://www.gnu.org/software/software.html
 | 
				
			|||||||
for download instructions) can be safely used, for example.
 | 
					for download instructions) can be safely used, for example.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Why does the OpenSSL test fail with "bc: stack empty"?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
On some DG/ux versions, bc seems to have a too small stack for calculations
 | 
					 | 
				
			||||||
that the OpenSSL bntest throws at it.  This gets triggered when you run the
 | 
					 | 
				
			||||||
test suite (using "make test").  The message returned is "bc: stack empty".
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The best way to deal with this is to find another implementation of bc
 | 
					 | 
				
			||||||
and compile/install it.  GNU bc (see http://www.gnu.org/software/software.html
 | 
					 | 
				
			||||||
for download instructions) can be safely used, for example.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Why does the OpenSSL compilation fail on Alpha Tru64 Unix?
 | 
					* Why does the OpenSSL compilation fail on Alpha Tru64 Unix?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
On some Alpha installations running Tru64 Unix and Compaq C, the compilation
 | 
					On some Alpha installations running Tru64 Unix and Compaq C, the compilation
 | 
				
			||||||
@@ -462,7 +420,7 @@ get the best result from OpenSSL.  A bit more complicated solution is the
 | 
				
			|||||||
following:
 | 
					following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
----- snip:start -----
 | 
					----- snip:start -----
 | 
				
			||||||
  make DIRS=crypto SDIRS=sha "`grep '^CFLAG=' Makefile | \
 | 
					  make DIRS=crypto SDIRS=sha "`grep '^CFLAG=' Makefile.ssl | \
 | 
				
			||||||
       sed -e 's/ -O[0-9] / -O0 /'`"
 | 
					       sed -e 's/ -O[0-9] / -O0 /'`"
 | 
				
			||||||
  rm `ls crypto/*.o crypto/sha/*.o | grep -v 'sha_dgst\.o'`
 | 
					  rm `ls crypto/*.o crypto/sha/*.o | grep -v 'sha_dgst\.o'`
 | 
				
			||||||
  make
 | 
					  make
 | 
				
			||||||
@@ -472,10 +430,6 @@ This will only compile sha_dgst.c with -O0, the rest with the optimization
 | 
				
			|||||||
level chosen by the configuration process.  When the above is done, do the
 | 
					level chosen by the configuration process.  When the above is done, do the
 | 
				
			||||||
test and installation and you're set.
 | 
					test and installation and you're set.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
3. Reconfigure the toolkit with no-sha0 option to leave out SHA0. It
 | 
					 | 
				
			||||||
should not be used and is not used in SSL/TLS nor any other recognized
 | 
					 | 
				
			||||||
protocol in either case.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Why does the OpenSSL compilation fail with "ar: command not found"?
 | 
					* Why does the OpenSSL compilation fail with "ar: command not found"?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -499,104 +453,12 @@ and then redo the compilation.  What you should really do is make sure
 | 
				
			|||||||
Sometimes, you may get reports from VC++ command line (cl) that it
 | 
					Sometimes, you may get reports from VC++ command line (cl) that it
 | 
				
			||||||
can't find standard include files like stdio.h and other weirdnesses.
 | 
					can't find standard include files like stdio.h and other weirdnesses.
 | 
				
			||||||
One possible cause is that the environment isn't correctly set up.
 | 
					One possible cause is that the environment isn't correctly set up.
 | 
				
			||||||
To solve that problem for VC++ versions up to 6, one should run
 | 
					To solve that problem, one should run VCVARS32.BAT which is found in
 | 
				
			||||||
VCVARS32.BAT which is found in the 'bin' subdirectory of the VC++
 | 
					the 'bin' subdirectory of the VC++ installation directory (somewhere
 | 
				
			||||||
installation directory (somewhere under 'Program Files').  For VC++
 | 
					under 'Program Files').  This needs to be done prior to running NMAKE,
 | 
				
			||||||
version 7 (and up?), which is also called VS.NET, the file is called
 | 
					and the changes are only valid for the current DOS session.
 | 
				
			||||||
VSVARS32.BAT instead.
 | 
					 | 
				
			||||||
This needs to be done prior to running NMAKE, and the changes are only
 | 
					 | 
				
			||||||
valid for the current DOS session.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* What is special about OpenSSL on Redhat?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Red Hat Linux (release 7.0 and later) include a preinstalled limited
 | 
					 | 
				
			||||||
version of OpenSSL. For patent reasons, support for IDEA, RC5 and MDC2
 | 
					 | 
				
			||||||
is disabled in this version. The same may apply to other Linux distributions.
 | 
					 | 
				
			||||||
Users may therefore wish to install more or all of the features left out.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
To do this you MUST ensure that you do not overwrite the openssl that is in
 | 
					 | 
				
			||||||
/usr/bin on your Red Hat machine. Several packages depend on this file,
 | 
					 | 
				
			||||||
including sendmail and ssh. /usr/local/bin is a good alternative choice. The
 | 
					 | 
				
			||||||
libraries that come with Red Hat 7.0 onwards have different names and so are
 | 
					 | 
				
			||||||
not affected. (eg For Red Hat 7.2 they are /lib/libssl.so.0.9.6b and
 | 
					 | 
				
			||||||
/lib/libcrypto.so.0.9.6b with symlinks /lib/libssl.so.2 and
 | 
					 | 
				
			||||||
/lib/libcrypto.so.2 respectively).
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Please note that we have been advised by Red Hat attempting to recompile the
 | 
					 | 
				
			||||||
openssl rpm with all the cryptography enabled will not work. All other
 | 
					 | 
				
			||||||
packages depend on the original Red Hat supplied openssl package. It is also
 | 
					 | 
				
			||||||
worth noting that due to the way Red Hat supplies its packages, updates to
 | 
					 | 
				
			||||||
openssl on each distribution never change the package version, only the
 | 
					 | 
				
			||||||
build number. For example, on Red Hat 7.1, the latest openssl package has
 | 
					 | 
				
			||||||
version number 0.9.6 and build number 9 even though it contains all the
 | 
					 | 
				
			||||||
relevant updates in packages up to and including 0.9.6b.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
A possible way around this is to persuade Red Hat to produce a non-US
 | 
					 | 
				
			||||||
version of Red Hat Linux.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FYI: Patent numbers and expiry dates of US patents:
 | 
					 | 
				
			||||||
MDC-2: 4,908,861 13/03/2007
 | 
					 | 
				
			||||||
IDEA:  5,214,703 25/05/2010
 | 
					 | 
				
			||||||
RC5:   5,724,428 03/03/2015
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Why does the OpenSSL compilation fail on MacOS X?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If the failure happens when trying to build the "openssl" binary, with
 | 
					 | 
				
			||||||
a large number of undefined symbols, it's very probable that you have
 | 
					 | 
				
			||||||
OpenSSL 0.9.6b delivered with the operating system (you can find out by
 | 
					 | 
				
			||||||
running '/usr/bin/openssl version') and that you were trying to build
 | 
					 | 
				
			||||||
OpenSSL 0.9.7 or newer.  The problem is that the loader ('ld') in
 | 
					 | 
				
			||||||
MacOS X has a misfeature that's quite difficult to go around.
 | 
					 | 
				
			||||||
Look in the file PROBLEMS for a more detailed explanation and for possible
 | 
					 | 
				
			||||||
solutions.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Why does the OpenSSL test suite fail on MacOS X?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
If the failure happens when running 'make test' and the RC4 test fails,
 | 
					 | 
				
			||||||
it's very probable that you have OpenSSL 0.9.6b delivered with the
 | 
					 | 
				
			||||||
operating system (you can find out by running '/usr/bin/openssl version')
 | 
					 | 
				
			||||||
and that you were trying to build OpenSSL 0.9.6d.  The problem is that
 | 
					 | 
				
			||||||
the loader ('ld') in MacOS X has a misfeature that's quite difficult to
 | 
					 | 
				
			||||||
go around and has linked the programs "openssl" and the test programs
 | 
					 | 
				
			||||||
with /usr/lib/libcrypto.dylib and /usr/lib/libssl.dylib instead of the
 | 
					 | 
				
			||||||
libraries you just built.
 | 
					 | 
				
			||||||
Look in the file PROBLEMS for a more detailed explanation and for possible
 | 
					 | 
				
			||||||
solutions.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Why does the OpenSSL test suite fail in BN_sqr test [on a 64-bit platform]?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Failure in BN_sqr test is most likely caused by a failure to configure the
 | 
					 | 
				
			||||||
toolkit for current platform or lack of support for the platform in question.
 | 
					 | 
				
			||||||
Run './config -t' and './apps/openssl version -p'. Do these platform
 | 
					 | 
				
			||||||
identifiers match? If they don't, then you most likely failed to run
 | 
					 | 
				
			||||||
./config and you're hereby advised to do so before filing a bug report.
 | 
					 | 
				
			||||||
If ./config itself fails to run, then it's most likely problem with your
 | 
					 | 
				
			||||||
local environment and you should turn to your system administrator (or
 | 
					 | 
				
			||||||
similar). If identifiers match (and/or no alternative identifier is
 | 
					 | 
				
			||||||
suggested by ./config script), then the platform is unsupported. There might
 | 
					 | 
				
			||||||
or might not be a workaround. Most notably on SPARC64 platforms with GNU
 | 
					 | 
				
			||||||
C compiler you should be able to produce a working build by running
 | 
					 | 
				
			||||||
'./config -m32'. I understand that -m32 might not be what you want/need,
 | 
					 | 
				
			||||||
but the build should be operational. For further details turn to
 | 
					 | 
				
			||||||
<openssl-dev@openssl.org>.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Why does OpenBSD-i386 build fail on des-586.s with "Unimplemented segment type"?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
As of 0.9.7 assembler routines were overhauled for position independence
 | 
					 | 
				
			||||||
of the machine code, which is essential for shared library support. For
 | 
					 | 
				
			||||||
some reason OpenBSD is equipped with an out-of-date GNU assembler which
 | 
					 | 
				
			||||||
finds the new code offensive. To work around the problem, configure with
 | 
					 | 
				
			||||||
no-asm (and sacrifice a great deal of performance) or patch your assembler
 | 
					 | 
				
			||||||
according to <URL: http://www.openssl.org/~appro/gas-1.92.3.OpenBSD.patch>.
 | 
					 | 
				
			||||||
For your convenience a pre-compiled replacement binary is provided at
 | 
					 | 
				
			||||||
<URL: http://www.openssl.org/~appro/gas-1.92.3.static.aout.bin>.
 | 
					 | 
				
			||||||
Reportedly elder *BSD a.out platforms also suffer from this problem and
 | 
					 | 
				
			||||||
remedy should be same. Provided binary is statically linked and should be
 | 
					 | 
				
			||||||
working across wider range of *BSD branches, not just OpenBSD.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
[PROG] ========================================================================
 | 
					[PROG] ========================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Is OpenSSL thread-safe?
 | 
					* Is OpenSSL thread-safe?
 | 
				
			||||||
@@ -608,9 +470,8 @@ libraries.  If your platform is not one of these, consult the INSTALL
 | 
				
			|||||||
file.
 | 
					file.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Multi-threaded applications must provide two callback functions to
 | 
					Multi-threaded applications must provide two callback functions to
 | 
				
			||||||
OpenSSL by calling CRYPTO_set_locking_callback() and
 | 
					OpenSSL.  This is described in the threads(3) manpage.
 | 
				
			||||||
CRYPTO_set_id_callback().  This is described in the threads(3)
 | 
					
 | 
				
			||||||
manpage.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
* I've compiled a program under Windows and it crashes: why?
 | 
					* I've compiled a program under Windows and it crashes: why?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -690,20 +551,6 @@ and attempts to free the buffer will have unpredictable results
 | 
				
			|||||||
because it no longer points to the same address.
 | 
					because it no longer points to the same address.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* OpenSSL uses DER but I need BER format: does OpenSSL support BER?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The short answer is yes, because DER is a special case of BER and OpenSSL
 | 
					 | 
				
			||||||
ASN1 decoders can process BER.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The longer answer is that ASN1 structures can be encoded in a number of
 | 
					 | 
				
			||||||
different ways. One set of ways is the Basic Encoding Rules (BER) with various
 | 
					 | 
				
			||||||
permissible encodings. A restriction of BER is the Distinguished Encoding
 | 
					 | 
				
			||||||
Rules (DER): these uniquely specify how a given structure is encoded.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Therefore, because DER is a special case of BER, DER is an acceptable encoding
 | 
					 | 
				
			||||||
for BER.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* I've tried using <M_some_evil_pkcs12_macro> and I get errors why?
 | 
					* I've tried using <M_some_evil_pkcs12_macro> and I get errors why?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
This usually happens when you try compiling something using the PKCS#12
 | 
					This usually happens when you try compiling something using the PKCS#12
 | 
				
			||||||
@@ -756,7 +603,6 @@ The general answer is to check the config.log file generated when running
 | 
				
			|||||||
the OpenSSH configure script. It should contain the detailed information
 | 
					the OpenSSH configure script. It should contain the detailed information
 | 
				
			||||||
on why the OpenSSL library was not detected or considered incompatible.
 | 
					on why the OpenSSL library was not detected or considered incompatible.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
* Can I use OpenSSL's SSL library with non-blocking I/O?
 | 
					* Can I use OpenSSL's SSL library with non-blocking I/O?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Yes; make sure to read the SSL_get_error(3) manual page!
 | 
					Yes; make sure to read the SSL_get_error(3) manual page!
 | 
				
			||||||
@@ -778,36 +624,5 @@ if explicitly asked by the server. Use the SSL_VERIFY_PEER flag of the
 | 
				
			|||||||
SSL_CTX_set_verify() function to enable the use of client certificates.
 | 
					SSL_CTX_set_verify() function to enable the use of client certificates.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Why does compilation fail due to an undefined symbol NID_uniqueIdentifier?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
For OpenSSL 0.9.7 the OID table was extended and corrected. In earlier
 | 
					 | 
				
			||||||
versions, uniqueIdentifier was incorrectly used for X.509 certificates.
 | 
					 | 
				
			||||||
The correct name according to RFC2256 (LDAP) is x500UniqueIdentifier.
 | 
					 | 
				
			||||||
Change your code to use the new name when compiling against OpenSSL 0.9.7.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* I think I've detected a memory leak, is this a bug?
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
In most cases the cause of an apparent memory leak is an OpenSSL internal table
 | 
					 | 
				
			||||||
that is allocated when an application starts up. Since such tables do not grow
 | 
					 | 
				
			||||||
in size over time they are harmless.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
These internal tables can be freed up when an application closes using various
 | 
					 | 
				
			||||||
functions.  Currently these include following:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Thread-local cleanup functions:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  ERR_remove_state()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Application-global cleanup functions that are aware of usage (and therefore
 | 
					 | 
				
			||||||
thread-safe):
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  ENGINE_cleanup() and CONF_modules_unload()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
"Brutal" (thread-unsafe) Application-global cleanup functions:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  ERR_free_strings(), EVP_cleanup() and CRYPTO_cleanup_all_ex_data().
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
===============================================================================
 | 
					===============================================================================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										56
									
								
								INSTALL
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								INSTALL
									
									
									
									
									
								
							@@ -2,10 +2,8 @@
 | 
				
			|||||||
 INSTALLATION ON THE UNIX PLATFORM
 | 
					 INSTALLATION ON THE UNIX PLATFORM
 | 
				
			||||||
 ---------------------------------
 | 
					 ---------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 [Installation on DOS (with djgpp), Windows, OpenVMS and MacOS (before MacOS X)
 | 
					 [Installation on Windows, OpenVMS and MacOS (before MacOS X) is described
 | 
				
			||||||
  is described in INSTALL.DJGPP, INSTALL.W32, INSTALL.VMS and INSTALL.MacOS.
 | 
					  in INSTALL.W32, INSTALL.VMS and INSTALL.MacOS.]
 | 
				
			||||||
  This document describes installation on operating systems in the Unix
 | 
					 | 
				
			||||||
  family.]
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 To install OpenSSL, you will need:
 | 
					 To install OpenSSL, you will need:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -123,7 +121,7 @@
 | 
				
			|||||||
     generic configurations "cc" or "gcc" should usually work on 32 bit
 | 
					     generic configurations "cc" or "gcc" should usually work on 32 bit
 | 
				
			||||||
     systems.
 | 
					     systems.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
     Configure creates the file Makefile from Makefile.org and
 | 
					     Configure creates the file Makefile.ssl from Makefile.org and
 | 
				
			||||||
     defines various macros in crypto/opensslconf.h (generated from
 | 
					     defines various macros in crypto/opensslconf.h (generated from
 | 
				
			||||||
     crypto/opensslconf.h.in).
 | 
					     crypto/opensslconf.h.in).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -139,11 +137,8 @@
 | 
				
			|||||||
     the failure that aren't problems in OpenSSL itself (like missing
 | 
					     the failure that aren't problems in OpenSSL itself (like missing
 | 
				
			||||||
     standard headers).  If it is a problem with OpenSSL itself, please
 | 
					     standard headers).  If it is a problem with OpenSSL itself, please
 | 
				
			||||||
     report the problem to <openssl-bugs@openssl.org> (note that your
 | 
					     report the problem to <openssl-bugs@openssl.org> (note that your
 | 
				
			||||||
     message will be recorded in the request tracker publicly readable
 | 
					     message will be forwarded to a public mailing list).  Include the
 | 
				
			||||||
     via http://www.openssl.org/support/rt.html and will be forwarded to a
 | 
					     output of "make report" in your message.
 | 
				
			||||||
     public mailing list). Include the output of "make report" in your message.
 | 
					 | 
				
			||||||
     Please check out the request tracker. Maybe the bug was already
 | 
					 | 
				
			||||||
     reported or has already been fixed.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
     [If you encounter assembler error messages, try the "no-asm"
 | 
					     [If you encounter assembler error messages, try the "no-asm"
 | 
				
			||||||
     configuration option as an immediate fix.]
 | 
					     configuration option as an immediate fix.]
 | 
				
			||||||
@@ -158,11 +153,10 @@
 | 
				
			|||||||
     If a test fails, look at the output.  There may be reasons for
 | 
					     If a test fails, look at the output.  There may be reasons for
 | 
				
			||||||
     the failure that isn't a problem in OpenSSL itself (like a missing
 | 
					     the failure that isn't a problem in OpenSSL itself (like a missing
 | 
				
			||||||
     or malfunctioning bc).  If it is a problem with OpenSSL itself,
 | 
					     or malfunctioning bc).  If it is a problem with OpenSSL itself,
 | 
				
			||||||
     try removing any compiler optimization flags from the CFLAG line
 | 
					     try removing any compiler optimization flags from the CFLAGS line
 | 
				
			||||||
     in Makefile and run "make clean; make". Please send a bug
 | 
					     in Makefile.ssl and run "make clean; make". Please send a bug
 | 
				
			||||||
     report to <openssl-bugs@openssl.org>, including the output of
 | 
					     report to <openssl-bugs@openssl.org>, including the output of
 | 
				
			||||||
     "make report" in order to be added to the request tracker at
 | 
					     "make report".
 | 
				
			||||||
     http://www.openssl.org/support/rt.html.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  4. If everything tests ok, install OpenSSL with
 | 
					  4. If everything tests ok, install OpenSSL with
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -296,37 +290,3 @@
 | 
				
			|||||||
 targets for shared library creation, like linux-shared.  Those targets
 | 
					 targets for shared library creation, like linux-shared.  Those targets
 | 
				
			||||||
 can currently be used on their own just as well, but this is expected
 | 
					 can currently be used on their own just as well, but this is expected
 | 
				
			||||||
 to change in future versions of OpenSSL.
 | 
					 to change in future versions of OpenSSL.
 | 
				
			||||||
 | 
					 | 
				
			||||||
 Note on random number generation
 | 
					 | 
				
			||||||
 --------------------------------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Availability of cryptographically secure random numbers is required for
 | 
					 | 
				
			||||||
 secret key generation. OpenSSL provides several options to seed the
 | 
					 | 
				
			||||||
 internal PRNG. If not properly seeded, the internal PRNG will refuse
 | 
					 | 
				
			||||||
 to deliver random bytes and a "PRNG not seeded error" will occur.
 | 
					 | 
				
			||||||
 On systems without /dev/urandom (or similar) device, it may be necessary
 | 
					 | 
				
			||||||
 to install additional support software to obtain random seed.
 | 
					 | 
				
			||||||
 Please check out the manual pages for RAND_add(), RAND_bytes(), RAND_egd(),
 | 
					 | 
				
			||||||
 and the FAQ for more information.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Note on support for multiple builds
 | 
					 | 
				
			||||||
 -----------------------------------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 OpenSSL is usually built in it's source tree.  Unfortunately, this doesn't
 | 
					 | 
				
			||||||
 support building for multiple platforms from the same source tree very well.
 | 
					 | 
				
			||||||
 It is however possible to build in a separate tree through the use of lots
 | 
					 | 
				
			||||||
 of symbolic links, which should be prepared like this:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	mkdir -p objtree/"`uname -s`-`uname -r`-`uname -m`"
 | 
					 | 
				
			||||||
	cd objtree/"`uname -s`-`uname -r`-`uname -m`"
 | 
					 | 
				
			||||||
	(cd $OPENSSL_SOURCE; find . -type f) | while read F; do
 | 
					 | 
				
			||||||
		mkdir -p `dirname $F`
 | 
					 | 
				
			||||||
		rm -f $F; ln -s $OPENSSL_SOURCE/$F $F
 | 
					 | 
				
			||||||
		echo $F '->' $OPENSSL_SOURCE/$F
 | 
					 | 
				
			||||||
	done
 | 
					 | 
				
			||||||
	make -f Makefile.org clean
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 OPENSSL_SOURCE is an environment variable that contains the absolute (this
 | 
					 | 
				
			||||||
 is important!) path to the OpenSSL source tree.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Also, operations like 'make update' should still be made in the source tree.
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,47 +0,0 @@
 | 
				
			|||||||
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 INSTALLATION ON THE DOS PLATFORM WITH DJGPP
 | 
					 | 
				
			||||||
 -------------------------------------------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 OpenSSL has been ported to DJGPP, a Unix look-alike 32-bit run-time
 | 
					 | 
				
			||||||
 environment for 16-bit DOS, but only with long filename support.
 | 
					 | 
				
			||||||
 If you wish to compile on native DOS with 8+3 filenames, you will
 | 
					 | 
				
			||||||
 have to tweak the installation yourself, including renaming files
 | 
					 | 
				
			||||||
 with illegal or duplicate names.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 You should have a full DJGPP environment installed, including the
 | 
					 | 
				
			||||||
 latest versions of DJGPP, GCC, BINUTILS, BASH, etc. This package
 | 
					 | 
				
			||||||
 requires that PERL and BC also be installed.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 All of these can be obtained from the usual DJGPP mirror sites or
 | 
					 | 
				
			||||||
 directly at "http://www.delorie.com/pub/djgpp". For help on which
 | 
					 | 
				
			||||||
 files to download, see the DJGPP "ZIP PICKER" page at
 | 
					 | 
				
			||||||
 "http://www.delorie.com/djgpp/zip-picker.html". You also need to have
 | 
					 | 
				
			||||||
 the WATT-32 networking package installed before you try to compile
 | 
					 | 
				
			||||||
 OpenSSL. This can be obtained from "http://www.bgnett.no/~giva/".
 | 
					 | 
				
			||||||
 The Makefile assumes that the WATT-32 code is in the directory
 | 
					 | 
				
			||||||
 specified by the environment variable WATT_ROOT. If you have watt-32
 | 
					 | 
				
			||||||
 in directory "watt32" under your main DJGPP directory, specify
 | 
					 | 
				
			||||||
 WATT_ROOT="/dev/env/DJDIR/watt32".
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 To compile OpenSSL, start your BASH shell, then configure for DJGPP by
 | 
					 | 
				
			||||||
 running "./Configure" with appropriate arguments:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	./Configure no-threads --prefix=/dev/env/DJDIR DJGPP
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 And finally fire up "make". You may run out of DPMI selectors when
 | 
					 | 
				
			||||||
 running in a DOS box under Windows. If so, just close the BASH
 | 
					 | 
				
			||||||
 shell, go back to Windows, and restart BASH. Then run "make" again.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 RUN-TIME CAVEAT LECTOR
 | 
					 | 
				
			||||||
 --------------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Quoting FAQ:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  "Cryptographic software needs a source of unpredictable data to work
 | 
					 | 
				
			||||||
   correctly.  Many open source operating systems provide a "randomness
 | 
					 | 
				
			||||||
   device" (/dev/urandom or /dev/random) that serves this purpose."
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 As of version 0.9.7f DJGPP port checks upon /dev/urandom$ for a 3rd
 | 
					 | 
				
			||||||
 party "randomness" DOS driver. One such driver, NOISE.SYS, can be
 | 
					 | 
				
			||||||
 obtained from "http://www.rahul.net/dkaufman/index.html".
 | 
					 | 
				
			||||||
@@ -20,12 +20,3 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 If that finishes successfully you will find the libraries and programs in the
 | 
					 If that finishes successfully you will find the libraries and programs in the
 | 
				
			||||||
 "out" directory.
 | 
					 "out" directory.
 | 
				
			||||||
 | 
					 | 
				
			||||||
 Alternatively, you can make a dynamic build that puts the library code into
 | 
					 | 
				
			||||||
 crypto.dll and ssl.dll by running
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 > make -f os2-emx-dll.mak
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 This will build the above mentioned dlls and a matching pair of import
 | 
					 | 
				
			||||||
 libraries in the "out_dll" directory along with the set of test programs
 | 
					 | 
				
			||||||
 and the openssl application.
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										177
									
								
								INSTALL.W32
									
									
									
									
									
								
							
							
						
						
									
										177
									
								
								INSTALL.W32
									
									
									
									
									
								
							@@ -2,28 +2,19 @@
 | 
				
			|||||||
 INSTALLATION ON THE WIN32 PLATFORM
 | 
					 INSTALLATION ON THE WIN32 PLATFORM
 | 
				
			||||||
 ----------------------------------
 | 
					 ----------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 [Instructions for building for Windows CE can be found in INSTALL.WCE]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Heres a few comments about building OpenSSL in Windows environments.  Most
 | 
					 Heres a few comments about building OpenSSL in Windows environments.  Most
 | 
				
			||||||
 of this is tested on Win32 but it may also work in Win 3.1 with some
 | 
					 of this is tested on Win32 but it may also work in Win 3.1 with some
 | 
				
			||||||
 modification.
 | 
					 modification.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 You need Perl for Win32.  Unless you will build on Cygwin, you will need
 | 
					 You need Perl for Win32.  Unless you will build on Cygwin, you will need
 | 
				
			||||||
 ActiveState Perl, available from http://www.activestate.com/ActivePerl.
 | 
					 ActiveState Perl, available from http://www.activestate.com/ActivePerl.
 | 
				
			||||||
 | 
					 For Cygwin users, there's more info in the Cygwin section.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 and one of the following C compilers:
 | 
					 and one of the following C compilers:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  * Visual C++
 | 
					  * Visual C++
 | 
				
			||||||
  * Borland C
 | 
					  * Borland C
 | 
				
			||||||
  * GNU C (Cygwin or MinGW)
 | 
					  * GNU C (Mingw32 or Cygwin)
 | 
				
			||||||
 | 
					 | 
				
			||||||
 If you are compiling from a tarball or a CVS snapshot then the Win32 files
 | 
					 | 
				
			||||||
 may well be not up to date. This may mean that some "tweaking" is required to
 | 
					 | 
				
			||||||
 get it all to work. See the trouble shooting section later on for if (when?)
 | 
					 | 
				
			||||||
 it goes wrong.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Visual C++
 | 
					 | 
				
			||||||
 ----------
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you want to compile in the assembly language routines with Visual C++ then
 | 
					 If you want to compile in the assembly language routines with Visual C++ then
 | 
				
			||||||
 you will need an assembler. This is worth doing because it will result in
 | 
					 you will need an assembler. This is worth doing because it will result in
 | 
				
			||||||
@@ -33,26 +24,32 @@
 | 
				
			|||||||
  * Microsoft MASM (aka "ml")
 | 
					  * Microsoft MASM (aka "ml")
 | 
				
			||||||
  * Free Netwide Assembler NASM.
 | 
					  * Free Netwide Assembler NASM.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 MASM is distributed with most versions of VC++. For the versions where it is
 | 
					 MASM was at one point distributed with VC++. It is now distributed with some
 | 
				
			||||||
 not included in VC++, it is also distributed with some Microsoft DDKs, for
 | 
					 Microsoft DDKs, for example the Windows NT 4.0 DDK and the Windows 98 DDK. If
 | 
				
			||||||
 example the Windows NT 4.0 DDK and the Windows 98 DDK. If you do not have
 | 
					 you do not have either of these DDKs then you can just download the binaries
 | 
				
			||||||
 either of these DDKs then you can just download the binaries for the Windows
 | 
					 for the Windows 98 DDK and extract and rename the two files XXXXXml.exe and
 | 
				
			||||||
 98 DDK and extract and rename the two files XXXXXml.exe and XXXXXml.err, to
 | 
					 XXXXXml.err, to ml.exe and ml.err and install somewhere on your PATH. Both
 | 
				
			||||||
 ml.exe and ml.err and install somewhere on your PATH. Both DDKs can be
 | 
					 DDKs can be downloaded from the Microsoft developers site www.msdn.com.
 | 
				
			||||||
 downloaded from the Microsoft developers site www.msdn.com.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 NASM is freely available. Version 0.98 was used during testing: other versions
 | 
					 NASM is freely available. Version 0.98 was used during testing: other versions
 | 
				
			||||||
 may also work. It is available from many places, see for example:
 | 
					 may also work. It is available from many places, see for example:
 | 
				
			||||||
 http://www.kernel.org/pub/software/devel/nasm/binaries/win32/
 | 
					 http://www.kernel.org/pub/software/devel/nasm/binaries/win32/
 | 
				
			||||||
 The NASM binary nasmw.exe needs to be installed anywhere on your PATH.
 | 
					 The NASM binary nasmw.exe needs to be installed anywhere on your PATH.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Firstly you should run Configure (to build a FIPS-certified variant of
 | 
					 If you are compiling from a tarball or a CVS snapshot then the Win32 files
 | 
				
			||||||
 OpenSSL, add the option "fips"):
 | 
					 may well be not up to date. This may mean that some "tweaking" is required to
 | 
				
			||||||
 | 
					 get it all to work. See the trouble shooting section later on for if (when?)
 | 
				
			||||||
 | 
					 it goes wrong.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Visual C++
 | 
				
			||||||
 | 
					 ----------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Firstly you should run Configure:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 > perl Configure VC-WIN32
 | 
					 > perl Configure VC-WIN32
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Next you need to build the Makefiles and optionally the assembly language
 | 
					 Next you need to build the Makefiles and optionally the assembly language
 | 
				
			||||||
 files (to build a FIPS-certified variant of OpenSSL, add the argument "fips"):
 | 
					 files:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 - If you are using MASM then run:
 | 
					 - If you are using MASM then run:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -85,8 +82,7 @@
 | 
				
			|||||||
 There are various changes you can make to the Win32 compile environment. By
 | 
					 There are various changes you can make to the Win32 compile environment. By
 | 
				
			||||||
 default the library is not compiled with debugging symbols. If you add 'debug'
 | 
					 default the library is not compiled with debugging symbols. If you add 'debug'
 | 
				
			||||||
 to the mk1mf.pl lines in the do_* batch file then debugging symbols will be
 | 
					 to the mk1mf.pl lines in the do_* batch file then debugging symbols will be
 | 
				
			||||||
 compiled in. Note that mk1mf.pl expects the platform to be the last argument
 | 
					 compiled in.
 | 
				
			||||||
 on the command line, so 'debug' must appear before that, as all other options.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 The default Win32 environment is to leave out any Windows NT specific
 | 
					 The default Win32 environment is to leave out any Windows NT specific
 | 
				
			||||||
 features.
 | 
					 features.
 | 
				
			||||||
@@ -98,20 +94,6 @@
 | 
				
			|||||||
 You can also build a static version of the library using the Makefile
 | 
					 You can also build a static version of the library using the Makefile
 | 
				
			||||||
 ms\nt.mak
 | 
					 ms\nt.mak
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Borland C++ builder 5
 | 
					 | 
				
			||||||
 ---------------------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Configure for building with Borland Builder (to build a FIPS-certified
 | 
					 | 
				
			||||||
   variant of OpenSSL, add the option "fips"):
 | 
					 | 
				
			||||||
   > perl Configure BC-32
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Create the appropriate makefile (to build a FIPS-certified variant of
 | 
					 | 
				
			||||||
   OpenSSL, add the argument "fips")
 | 
					 | 
				
			||||||
   > ms\do_nasm
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Build
 | 
					 | 
				
			||||||
   > make -f ms\bcb.mak
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Borland C++ builder 3 and 4
 | 
					 Borland C++ builder 3 and 4
 | 
				
			||||||
 ---------------------------
 | 
					 ---------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -122,72 +104,18 @@
 | 
				
			|||||||
 * Run make:
 | 
					 * Run make:
 | 
				
			||||||
   > make -f bcb.mak
 | 
					   > make -f bcb.mak
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 GNU C (Cygwin)
 | 
					 GNU C (Mingw32)
 | 
				
			||||||
 --------------
 | 
					 ---------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Cygwin provides a bash shell and GNU tools environment running
 | 
					 To build OpenSSL, you need the Mingw32 package and GNU make.
 | 
				
			||||||
 on NT 4.0, Windows 9x, Windows ME, Windows 2000, and Windows XP.
 | 
					 | 
				
			||||||
 Consequently, a make of OpenSSL with Cygwin is closer to a GNU
 | 
					 | 
				
			||||||
 bash environment such as Linux than to other the other Win32
 | 
					 | 
				
			||||||
 makes.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Cygwin implements a Posix/Unix runtime system (cygwin1.dll).
 | 
					 | 
				
			||||||
 It is also possible to create Win32 binaries that only use the
 | 
					 | 
				
			||||||
 Microsoft C runtime system (msvcrt.dll or crtdll.dll) using
 | 
					 | 
				
			||||||
 MinGW. MinGW can be used in the Cygwin development environment
 | 
					 | 
				
			||||||
 or in a standalone setup as described in the following section.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 To build OpenSSL using Cygwin:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Install Cygwin (see http://cygwin.com/)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Install Perl and ensure it is in the path. Both Cygwin perl
 | 
					 | 
				
			||||||
   (5.6.1-2 or newer) and ActivePerl work.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * Run the Cygwin bash shell
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 * $ tar zxvf openssl-x.x.x.tar.gz
 | 
					 | 
				
			||||||
   $ cd openssl-x.x.x
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   To build the Cygwin version of OpenSSL:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   $ ./config
 | 
					 | 
				
			||||||
   [...]
 | 
					 | 
				
			||||||
   $ make
 | 
					 | 
				
			||||||
   [...]
 | 
					 | 
				
			||||||
   $ make test
 | 
					 | 
				
			||||||
   $ make install
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   This will create a default install in /usr/local/ssl.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   To build the MinGW version (native Windows) in Cygwin:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   $ ./Configure mingw
 | 
					 | 
				
			||||||
   [...]
 | 
					 | 
				
			||||||
   $ make
 | 
					 | 
				
			||||||
   [...]
 | 
					 | 
				
			||||||
   $ make test
 | 
					 | 
				
			||||||
   $ make install
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Cygwin Notes:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 "make test" and normal file operations may fail in directories
 | 
					 | 
				
			||||||
 mounted as text (i.e. mount -t c:\somewhere /home) due to Cygwin
 | 
					 | 
				
			||||||
 stripping of carriage returns. To avoid this ensure that a binary
 | 
					 | 
				
			||||||
 mount is used, e.g. mount -b c:\somewhere /home.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 "bc" is not provided in older Cygwin distribution.  This causes a
 | 
					 | 
				
			||||||
 non-fatal error in "make test" but is otherwise harmless.  If
 | 
					 | 
				
			||||||
 desired and needed, GNU bc can be built with Cygwin without change.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 GNU C (MinGW)
 | 
					 | 
				
			||||||
 -------------
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 * Compiler installation:
 | 
					 * Compiler installation:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
   MinGW is available from http://www.mingw.org. Run the installer and
 | 
					   Mingw32 is available from <ftp://ftp.xraylith.wisc.edu/pub/khan/
 | 
				
			||||||
   set the MinGW bin directory to the PATH in "System Properties" or
 | 
					   gnu-win32/mingw32/gcc-2.95.2/gcc-2.95.2-msvcrt.exe>. Extract it
 | 
				
			||||||
   autoexec.bat.
 | 
					   to a directory such as C:\gcc-2.95.2 and add c:\gcc-2.95.2\bin to
 | 
				
			||||||
 | 
					   the PATH environment variable in "System Properties"; or edit and
 | 
				
			||||||
 | 
					   run C:\gcc-2.95.2\mingw32.bat to set the PATH.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 * Compile OpenSSL:
 | 
					 * Compile OpenSSL:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -197,8 +125,6 @@
 | 
				
			|||||||
   occur, try
 | 
					   occur, try
 | 
				
			||||||
   > ms\mingw32 no-asm
 | 
					   > ms\mingw32 no-asm
 | 
				
			||||||
   instead.
 | 
					   instead.
 | 
				
			||||||
   If you want to build a FIPS-certified variant of OpenSSL, add the argument
 | 
					 | 
				
			||||||
   "fips"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
   libcrypto.a and libssl.a are the static libraries. To use the DLLs,
 | 
					   libcrypto.a and libssl.a are the static libraries. To use the DLLs,
 | 
				
			||||||
   link with libeay32.a and libssl32.a instead.
 | 
					   link with libeay32.a and libssl32.a instead.
 | 
				
			||||||
@@ -211,6 +137,53 @@
 | 
				
			|||||||
   > cd out
 | 
					   > cd out
 | 
				
			||||||
   > ..\ms\test
 | 
					   > ..\ms\test
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 GNU C (Cygwin)
 | 
				
			||||||
 | 
					 --------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Cygwin provides a bash shell and GNU tools environment running on
 | 
				
			||||||
 | 
					 NT 4.0, Windows 9x and Windows 2000. Consequently, a make of OpenSSL
 | 
				
			||||||
 | 
					 with Cygwin is closer to a GNU bash environment such as Linux rather
 | 
				
			||||||
 | 
					 than other W32 makes that are based on a single makefile approach.
 | 
				
			||||||
 | 
					 Cygwin implements Posix/Unix calls through cygwin1.dll, and is
 | 
				
			||||||
 | 
					 contrasted to Mingw32 which links dynamically to msvcrt.dll or
 | 
				
			||||||
 | 
					 crtdll.dll.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 To build OpenSSL using Cygwin:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 * Install Cygwin (see http://sourceware.cygnus.com/cygwin)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 * Install Perl and ensure it is in the path (recent Cygwin perl 
 | 
				
			||||||
 | 
					   (version 5.6.1-2 of the latter has been reported to work) or
 | 
				
			||||||
 | 
					   ActivePerl)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 * Run the Cygwin bash shell
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 * $ tar zxvf openssl-x.x.x.tar.gz
 | 
				
			||||||
 | 
					   $ cd openssl-x.x.x
 | 
				
			||||||
 | 
					   $ ./config
 | 
				
			||||||
 | 
					   [...]
 | 
				
			||||||
 | 
					   $ make
 | 
				
			||||||
 | 
					   [...]
 | 
				
			||||||
 | 
					   $ make test
 | 
				
			||||||
 | 
					   $ make install
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This will create a default install in /usr/local/ssl.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Cygwin Notes:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 "make test" and normal file operations may fail in directories
 | 
				
			||||||
 | 
					 mounted as text (i.e. mount -t c:\somewhere /home) due to Cygwin
 | 
				
			||||||
 | 
					 stripping of carriage returns. To avoid this ensure that a binary
 | 
				
			||||||
 | 
					 mount is used, e.g. mount -b c:\somewhere /home.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 As of version 1.1.1 Cygwin is relatively unstable in its handling
 | 
				
			||||||
 | 
					 of cr/lf issues. These make procedures succeeded with versions 1.1 and
 | 
				
			||||||
 | 
					 the snapshot 20000524 (Slow!).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 "bc" is not provided in the Cygwin distribution.  This causes a
 | 
				
			||||||
 | 
					 non-fatal error in "make test" but is otherwise harmless.  If
 | 
				
			||||||
 | 
					 desired, GNU bc can be built with Cygwin without change.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Installation
 | 
					 Installation
 | 
				
			||||||
 ------------
 | 
					 ------------
 | 
				
			||||||
@@ -230,7 +203,7 @@
 | 
				
			|||||||
	$ md c:\openssl\lib
 | 
						$ md c:\openssl\lib
 | 
				
			||||||
	$ md c:\openssl\include
 | 
						$ md c:\openssl\include
 | 
				
			||||||
	$ md c:\openssl\include\openssl
 | 
						$ md c:\openssl\include\openssl
 | 
				
			||||||
	$ copy /b inc32\openssl\*       c:\openssl\include\openssl
 | 
						$ copy /b inc32\*               c:\openssl\include\openssl
 | 
				
			||||||
	$ copy /b out32dll\ssleay32.lib c:\openssl\lib
 | 
						$ copy /b out32dll\ssleay32.lib c:\openssl\lib
 | 
				
			||||||
	$ copy /b out32dll\libeay32.lib c:\openssl\lib
 | 
						$ copy /b out32dll\libeay32.lib c:\openssl\lib
 | 
				
			||||||
	$ copy /b out32dll\ssleay32.dll c:\openssl\bin
 | 
						$ copy /b out32dll\ssleay32.dll c:\openssl\bin
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										71
									
								
								INSTALL.WCE
									
									
									
									
									
								
							
							
						
						
									
										71
									
								
								INSTALL.WCE
									
									
									
									
									
								
							@@ -1,71 +0,0 @@
 | 
				
			|||||||
 
 | 
					 | 
				
			||||||
 INSTALLATION FOR THE WINDOWS CE PLATFORM
 | 
					 | 
				
			||||||
 ----------------------------------------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Building OpenSSL for Windows CE requires the following external tools:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  * Microsoft eMbedded Visual C++ 3.0
 | 
					 | 
				
			||||||
  * wcecompat compatibility library (www.essemer.com.au)
 | 
					 | 
				
			||||||
  * Optionally ceutils for running automated tests (www.essemer.com.au)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 You also need Perl for Win32.  You will need ActiveState Perl, available
 | 
					 | 
				
			||||||
 from http://www.activestate.com/ActivePerl.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Windows CE support in OpenSSL relies on wcecompat.  All Windows CE specific
 | 
					 | 
				
			||||||
 issues should be directed to www.essemer.com.au.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 The C Runtime Library implementation for Windows CE that is included with
 | 
					 | 
				
			||||||
 Microsoft eMbedded Visual C++ 3.0 is incomplete and in some places
 | 
					 | 
				
			||||||
 incorrect.  wcecompat plugs the holes and tries to bring the Windows CE
 | 
					 | 
				
			||||||
 CRT to a level that is more compatible with ANSI C.  wcecompat goes further
 | 
					 | 
				
			||||||
 and provides low-level IO and stream IO support for stdin/stdout/stderr
 | 
					 | 
				
			||||||
 (which Windows CE does not provide).  This IO functionality is not needed
 | 
					 | 
				
			||||||
 by the OpenSSL library itself but is used for the tests and openssl.exe.
 | 
					 | 
				
			||||||
 More information is available at www.essemer.com.au.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Building
 | 
					 | 
				
			||||||
 --------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Setup the eMbedded Visual C++ environment.  There are batch files for doing
 | 
					 | 
				
			||||||
 this installed with eVC++.  For an ARM processor, for example, execute:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 > "C:\Program Files\Microsoft eMbedded Tools\EVC\WCE300\BIN\WCEARM.BAT"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Next indicate where wcecompat is located:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 > set WCECOMPAT=C:\wcecompat
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Next you should run Configure:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 > perl Configure VC-CE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Next you need to build the Makefiles:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 > ms\do_ms
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 If you get errors about things not having numbers assigned then check the
 | 
					 | 
				
			||||||
 troubleshooting section in INSTALL.W32: you probably won't be able to compile
 | 
					 | 
				
			||||||
 it as it stands.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 Then from the VC++ environment at a prompt do:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 - to build static libraries:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   > nmake -f ms\ce.mak
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 - or to build DLLs:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   > nmake -f ms\cedll.mak
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 If all is well it should compile and you will have some static libraries and
 | 
					 | 
				
			||||||
 executables in out32, or some DLLs and executables in out32dll.  If you want
 | 
					 | 
				
			||||||
 to try the tests then make sure the ceutils are in the path and do:
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 > cd out32
 | 
					 | 
				
			||||||
 > ..\ms\testce
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 This will copy each of the test programs to the Windows CE device and execute
 | 
					 | 
				
			||||||
 them, displaying the output of the tests on this computer.  The output should
 | 
					 | 
				
			||||||
 look similar to the output produced by running the tests for a regular Windows
 | 
					 | 
				
			||||||
 build.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							@@ -12,7 +12,7 @@
 | 
				
			|||||||
  ---------------
 | 
					  ---------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 1998-2007 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Redistribution and use in source and binary forms, with or without
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 * modification, are permitted provided that the following conditions
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2750,4 +2750,4 @@ void SkipWhiteSpace(char **ioSrcCharPtr,const Boolean inStopAtEOL)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -167,4 +167,4 @@ void ThrowErrorMessageException(void)
 | 
				
			|||||||
	ThrowDescriptiveException(gErrorMessage);
 | 
						ThrowDescriptiveException(gErrorMessage);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -1287,7 +1287,7 @@ EXITPOINT:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
//	Send some bytes
 | 
					//	Send some bytes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MacSocket_send(const int inSocketNum,const void *inBuff,int inBuffLength)
 | 
					int MacSocket_send(const int inSocketNum,void *inBuff,int inBuffLength)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
OSErr			errCode = noErr;
 | 
					OSErr			errCode = noErr;
 | 
				
			||||||
int				bytesSent = 0;
 | 
					int				bytesSent = 0;
 | 
				
			||||||
@@ -1604,4 +1604,4 @@ EPInfo* epi = (EPInfo*) context;
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
*/
 | 
					*/
 | 
				
			||||||
@@ -62,7 +62,7 @@ int MacSocket_recv(const int inSocketNum,void *outBuff,int outBuffLength,const B
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
//	Call this to send data on a socket
 | 
					//	Call this to send data on a socket
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MacSocket_send(const int inSocketNum,const void *inBuff,int inBuffLength);
 | 
					int MacSocket_send(const int inSocketNum,void *inBuff,int inBuffLength);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
//	If zero bytes were read in a call to MacSocket_recv(), it may be that the remote end has done a half-close
 | 
					//	If zero bytes were read in a call to MacSocket_recv(), it may be that the remote end has done a half-close
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										441
									
								
								Makefile.org
									
									
									
									
									
								
							
							
						
						
									
										441
									
								
								Makefile.org
									
									
									
									
									
								
							@@ -15,11 +15,6 @@ OPTIONS=
 | 
				
			|||||||
CONFIGURE_ARGS=
 | 
					CONFIGURE_ARGS=
 | 
				
			||||||
SHLIB_TARGET=
 | 
					SHLIB_TARGET=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# HERE indicates where this Makefile lives.  This can be used to indicate
 | 
					 | 
				
			||||||
# where sub-Makefiles are expected to be.  Currently has very limited usage,
 | 
					 | 
				
			||||||
# and should probably not be bothered with at all.
 | 
					 | 
				
			||||||
HERE=.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# INSTALL_PREFIX is for package builders so that they can configure
 | 
					# INSTALL_PREFIX is for package builders so that they can configure
 | 
				
			||||||
# for, say, /usr/ and yet have everything installed to /tmp/somedir/usr/.
 | 
					# for, say, /usr/ and yet have everything installed to /tmp/somedir/usr/.
 | 
				
			||||||
# Normally it is left empty.
 | 
					# Normally it is left empty.
 | 
				
			||||||
@@ -64,22 +59,13 @@ DEPFLAG=
 | 
				
			|||||||
PEX_LIBS= 
 | 
					PEX_LIBS= 
 | 
				
			||||||
EX_LIBS= 
 | 
					EX_LIBS= 
 | 
				
			||||||
EXE_EXT= 
 | 
					EXE_EXT= 
 | 
				
			||||||
ARFLAGS=
 | 
					AR=ar r
 | 
				
			||||||
AR=ar $(ARFLAGS) r
 | 
					 | 
				
			||||||
RANLIB= ranlib
 | 
					RANLIB= ranlib
 | 
				
			||||||
PERL= perl
 | 
					PERL= perl
 | 
				
			||||||
TAR= tar
 | 
					TAR= tar
 | 
				
			||||||
TARFLAGS= --no-recursion
 | 
					TARFLAGS= --no-recursion
 | 
				
			||||||
MAKEDEPPROG=makedepend
 | 
					MAKEDEPPROG=makedepend
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# We let the C compiler driver to take care of .s files. This is done in
 | 
					 | 
				
			||||||
# order to be excused from maintaining a separate set of architecture
 | 
					 | 
				
			||||||
# dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC
 | 
					 | 
				
			||||||
# gcc, then the driver will automatically translate it to -xarch=v8plus
 | 
					 | 
				
			||||||
# and pass it down to assembler.
 | 
					 | 
				
			||||||
AS=$(CC) -c
 | 
					 | 
				
			||||||
ASFLAG=$(CFLAG)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Set BN_ASM to bn_asm.o if you want to use the C version
 | 
					# Set BN_ASM to bn_asm.o if you want to use the C version
 | 
				
			||||||
BN_ASM= bn_asm.o
 | 
					BN_ASM= bn_asm.o
 | 
				
			||||||
#BN_ASM= bn_asm.o
 | 
					#BN_ASM= bn_asm.o
 | 
				
			||||||
@@ -101,8 +87,6 @@ PROCESSOR=
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Set DES_ENC to des_enc.o if you want to use the C version
 | 
					# Set DES_ENC to des_enc.o if you want to use the C version
 | 
				
			||||||
#There are 4 x86 assember options.
 | 
					#There are 4 x86 assember options.
 | 
				
			||||||
FIPS_DES_ENC= des_enc.o fcrypt_b.o
 | 
					 | 
				
			||||||
FIPS_AES_ENC= fips_aes_core.o
 | 
					 | 
				
			||||||
DES_ENC= asm/dx86-out.o asm/yx86-out.o
 | 
					DES_ENC= asm/dx86-out.o asm/yx86-out.o
 | 
				
			||||||
#DES_ENC= des_enc.o fcrypt_b.o          # C
 | 
					#DES_ENC= des_enc.o fcrypt_b.o          # C
 | 
				
			||||||
#DES_ENC= asm/dx86-elf.o asm/yx86-elf.o # elf
 | 
					#DES_ENC= asm/dx86-elf.o asm/yx86-elf.o # elf
 | 
				
			||||||
@@ -155,7 +139,6 @@ MD5_ASM_OBJ= asm/mx86-out.o
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Also need SHA1_ASM defined
 | 
					# Also need SHA1_ASM defined
 | 
				
			||||||
SHA1_ASM_OBJ= asm/sx86-out.o
 | 
					SHA1_ASM_OBJ= asm/sx86-out.o
 | 
				
			||||||
FIPS_SHA1_ASM_OBJ= asm/sx86-out.o
 | 
					 | 
				
			||||||
#SHA1_ASM_OBJ= asm/sx86-elf.o       # elf
 | 
					#SHA1_ASM_OBJ= asm/sx86-elf.o       # elf
 | 
				
			||||||
#SHA1_ASM_OBJ= asm/sx86-sol.o       # solaris
 | 
					#SHA1_ASM_OBJ= asm/sx86-sol.o       # solaris
 | 
				
			||||||
#SHA1_ASM_OBJ= asm/sx86-out.o       # a.out, FreeBSD
 | 
					#SHA1_ASM_OBJ= asm/sx86-out.o       # a.out, FreeBSD
 | 
				
			||||||
@@ -172,52 +155,31 @@ RMD160_ASM_OBJ= asm/rm86-out.o
 | 
				
			|||||||
KRB5_INCLUDES=
 | 
					KRB5_INCLUDES=
 | 
				
			||||||
LIBKRB5=
 | 
					LIBKRB5=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Zlib stuff
 | 
					 | 
				
			||||||
ZLIB_INCLUDE=
 | 
					 | 
				
			||||||
LIBZLIB=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is the location of fipscanister.o and friends.
 | 
					 | 
				
			||||||
# The FIPS module build will place it $(INSTALLTOP)/lib
 | 
					 | 
				
			||||||
# but since $(INSTALLTOP) can only take the default value
 | 
					 | 
				
			||||||
# when the module is built it will be in /usr/local/ssl/lib
 | 
					 | 
				
			||||||
# $(INSTALLTOP) for this build make be different so hard
 | 
					 | 
				
			||||||
# code the path.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FIPSLIBDIR=/usr/local/ssl/lib/
 | 
					 | 
				
			||||||
FIPSCANISTERINTERNAL=n
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Shared library base address. Currently only used on Windows.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
BASEADDR=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# When we're prepared to use shared libraries in the programs we link here
 | 
					# When we're prepared to use shared libraries in the programs we link here
 | 
				
			||||||
# we might set SHLIB_MARK to '$(SHARED_LIBS)'.
 | 
					# we might set SHLIB_MARK to '$(SHARED_LIBS)'.
 | 
				
			||||||
SHLIB_MARK=
 | 
					SHLIB_MARK=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DIRS=   crypto fips-1.0 ssl $(SHLIB_MARK) apps test tools
 | 
					DIRS=   crypto ssl $(SHLIB_MARK) apps test tools
 | 
				
			||||||
SHLIBDIRS= crypto ssl
 | 
					SHLIBDIRS= crypto ssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# dirs in crypto to build
 | 
					# dirs in crypto to build
 | 
				
			||||||
SDIRS=  objects \
 | 
					SDIRS=  \
 | 
				
			||||||
	md2 md4 md5 sha mdc2 hmac ripemd \
 | 
						md2 md4 md5 sha mdc2 hmac ripemd \
 | 
				
			||||||
	des rc2 rc4 rc5 idea bf cast \
 | 
						des rc2 rc4 rc5 idea bf cast \
 | 
				
			||||||
	bn ec rsa dsa dh dso engine aes \
 | 
						bn ec rsa dsa ecdsa dh dso engine aes \
 | 
				
			||||||
	buffer bio stack lhash rand err \
 | 
						buffer bio stack lhash rand err objects \
 | 
				
			||||||
	evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5
 | 
						evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5
 | 
				
			||||||
 | 
					
 | 
				
			||||||
FDIRS=	sha rand des aes dsa rsa dh hmac
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# tests to perform.  "alltests" is a special word indicating that all tests
 | 
					# tests to perform.  "alltests" is a special word indicating that all tests
 | 
				
			||||||
# should be performed.
 | 
					# should be performed.
 | 
				
			||||||
TESTS = alltests
 | 
					TESTS = alltests
 | 
				
			||||||
 | 
					
 | 
				
			||||||
MAKEFILE= Makefile
 | 
					MAKEFILE= Makefile.ssl
 | 
				
			||||||
 | 
					MAKE=     make -f Makefile.ssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
MANDIR=$(OPENSSLDIR)/man
 | 
					MANDIR=$(OPENSSLDIR)/man
 | 
				
			||||||
MAN1=1
 | 
					MAN1=1
 | 
				
			||||||
MAN3=3
 | 
					MAN3=3
 | 
				
			||||||
MANSUFFIX=
 | 
					 | 
				
			||||||
SHELL=/bin/sh
 | 
					SHELL=/bin/sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
TOP=    .
 | 
					TOP=    .
 | 
				
			||||||
@@ -242,25 +204,14 @@ HEADER=         e_os.h
 | 
				
			|||||||
# When we're prepared to use shared libraries in the programs we link here
 | 
					# When we're prepared to use shared libraries in the programs we link here
 | 
				
			||||||
# we might remove 'clean-shared' from the targets to perform at this stage
 | 
					# we might remove 'clean-shared' from the targets to perform at this stage
 | 
				
			||||||
 | 
					
 | 
				
			||||||
all: Makefile sub_all openssl.pc
 | 
					all: Makefile.ssl sub_all
 | 
				
			||||||
 | 
					
 | 
				
			||||||
sub_all:
 | 
					sub_all:
 | 
				
			||||||
	@for i in $(DIRS); \
 | 
						@for i in $(DIRS); \
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making all in $$i..." && \
 | 
							(cd $$i && echo "making all in $$i..." && \
 | 
				
			||||||
		$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAG='${ASFLAG}' SDIRS='$(SDIRS)' FDIRS='$(FDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' FIPS_AES_ENC='${FIPS_AES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' FIPSCANISTERINTERNAL='${FIPSCANISTERINTERNAL}' FIPSLIBDIR='${FIPSLIBDIR}' all ) || exit 1; \
 | 
							$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' all ) || exit 1; \
 | 
				
			||||||
	else \
 | 
					 | 
				
			||||||
		$(MAKE) $$i; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	done;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub_target:
 | 
					 | 
				
			||||||
	@for i in $(DIRS); \
 | 
					 | 
				
			||||||
	do \
 | 
					 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
					 | 
				
			||||||
		(cd $$i && echo "making $(TARGET) in $$i..." && \
 | 
					 | 
				
			||||||
		$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAG='${ASFLAG}' SDIRS='$(SDIRS)' FDIRS='$(FDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' FIPS_AES_ENC='${FIPS_AES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TARGET='$(TARGET)' sub_target ) || exit 1; \
 | 
					 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		$(MAKE) $$i; \
 | 
							$(MAKE) $$i; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
@@ -290,7 +241,7 @@ clean-shared:
 | 
				
			|||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
		( set -x; rm -f lib$$i$(SHLIB_EXT) ); \
 | 
							( set -x; rm -f lib$$i$(SHLIB_EXT) ); \
 | 
				
			||||||
		if [ "$(PLATFORM)" = "Cygwin" ]; then \
 | 
							if [ "$(PLATFORM)" = "Cygwin" ]; then \
 | 
				
			||||||
			( set -x; rm -f cyg$$i-$(SHLIB_VERSION_NUMBER)$(SHLIB_EXT) lib$$i$(SHLIB_EXT).a ); \
 | 
								( set -x; rm -f cyg$$i$(SHLIB_EXT) lib$$i$(SHLIB_EXT).a ); \
 | 
				
			||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -300,8 +251,7 @@ link-shared:
 | 
				
			|||||||
		for i in $(SHLIBDIRS); do \
 | 
							for i in $(SHLIBDIRS); do \
 | 
				
			||||||
			prev=lib$$i$(SHLIB_EXT); \
 | 
								prev=lib$$i$(SHLIB_EXT); \
 | 
				
			||||||
			for j in $${tmp:-x}; do \
 | 
								for j in $${tmp:-x}; do \
 | 
				
			||||||
				( set -x; \
 | 
									( set -x; ln -f -s $$prev lib$$i$$j ); \
 | 
				
			||||||
				rm -f lib$$i$$j; ln -s $$prev lib$$i$$j ); \
 | 
					 | 
				
			||||||
				prev=lib$$i$$j; \
 | 
									prev=lib$$i$$j; \
 | 
				
			||||||
			done; \
 | 
								done; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
@@ -313,54 +263,41 @@ do_bsd-gcc-shared: do_gnu-shared
 | 
				
			|||||||
do_linux-shared: do_gnu-shared
 | 
					do_linux-shared: do_gnu-shared
 | 
				
			||||||
do_gnu-shared:
 | 
					do_gnu-shared:
 | 
				
			||||||
	libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
						libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
		-shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
							-shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		-Wl,-soname=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
							-Wl,-soname=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		-Wl,-Bsymbolic \
 | 
							-Wl,-Bsymbolic \
 | 
				
			||||||
		-Wl,--whole-archive lib$$i.a \
 | 
							-Wl,--whole-archive lib$$i.a \
 | 
				
			||||||
		-Wl,--no-whole-archive $$libs ${EX_LIBS} ) || exit 1; \
 | 
							-Wl,--no-whole-archive $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
				
			||||||
	libs="-l$$i $$libs"; \
 | 
						libs="$$libs -l$$i"; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DETECT_GNU_LD=(${CC} -Wl,-V /dev/null 2>&1 | grep '^GNU ld' )>/dev/null
 | 
					DETECT_GNU_LD=${CC} -v 2>&1 | grep '^gcc' >/dev/null 2>&1 && \
 | 
				
			||||||
 | 
						collect2=`gcc -print-prog-name=collect2 2>&1` && \
 | 
				
			||||||
 | 
						[ -n "$$collect2" ] && \
 | 
				
			||||||
 | 
						my_ld=`$$collect2 --help 2>&1 | grep Usage: | sed 's/^Usage: *\([^ ][^ ]*\).*/\1/'` && \
 | 
				
			||||||
 | 
						[ -n "$$my_ld" ] && \
 | 
				
			||||||
 | 
						$$my_ld -v 2>&1 | grep 'GNU ld' >/dev/null 2>&1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# For Darwin AKA Mac OS/X (dyld)
 | 
					# For Darwin AKA Mac OS/X (dyld)
 | 
				
			||||||
do_darwin-shared: 
 | 
					do_darwin-shared: 
 | 
				
			||||||
	libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
						libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						( set -x ; ${CC} --verbose -dynamiclib -o lib$$i${SHLIB_EXT} \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
		--verbose -dynamiclib -o lib$$i${SHLIB_EXT} \
 | 
					 | 
				
			||||||
		lib$$i.a $$libs -all_load -current_version ${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
							lib$$i.a $$libs -all_load -current_version ${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		-compatibility_version ${SHLIB_MAJOR}.`echo ${SHLIB_MINOR} | cut -d. -f1` \
 | 
							-compatibility_version ${SHLIB_MAJOR}.`echo ${SHLIB_MINOR} | cut -d. -f1` \
 | 
				
			||||||
		-install_name ${INSTALLTOP}/lib/lib$$i${SHLIB_EXT} ) || exit 1; \
 | 
							-install_name ${INSTALLTOP}/lib/lib$$i${SHLIB_EXT} ) || exit 1; \
 | 
				
			||||||
	libs="-l`basename $$i${SHLIB_EXT} .dylib` $$libs"; \
 | 
						libs="$$libs -l`basename $$i${SHLIB_EXT} .dylib`"; \
 | 
				
			||||||
	echo "" ; \
 | 
						echo "" ; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
do_cygwin-shared:
 | 
					do_cygwin-shared:
 | 
				
			||||||
	libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
						libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						( set -x; ${CC}  -shared -o cyg$$i.dll \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	shlib=cyg$${i}-$(SHLIB_VERSION_NUMBER).dll; \
 | 
					 | 
				
			||||||
	[ "$(PLATFORM)" = "mingw" ] && shlib=$${i}eay32.dll; \
 | 
					 | 
				
			||||||
	[ -f apps/$$shlib ] && rm apps/$$shlib; \
 | 
					 | 
				
			||||||
	[ -f test/$$shlib ] && rm test/$$shlib; \
 | 
					 | 
				
			||||||
	base=;  [ $$i = "crypto" ] && base=-Wl,--image-base,0x63000000; \
 | 
					 | 
				
			||||||
	( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
		-shared $$base -o $$shlib \
 | 
					 | 
				
			||||||
		-Wl,-Bsymbolic \
 | 
							-Wl,-Bsymbolic \
 | 
				
			||||||
		-Wl,--whole-archive lib$$i.a \
 | 
							-Wl,--whole-archive lib$$i.a \
 | 
				
			||||||
		-Wl,--out-implib,lib$$i.dll.a \
 | 
							-Wl,--out-implib,lib$$i.dll.a \
 | 
				
			||||||
		-Wl,--no-whole-archive $$libs ${EX_LIBS} ) || exit 1; \
 | 
							-Wl,--no-whole-archive $$libs ) || exit 1; \
 | 
				
			||||||
	cp -p $$shlib apps/; cp -p $$shlib test/; \
 | 
						libs="$$libs -l$$i"; \
 | 
				
			||||||
	touch -c lib$$i.dll.a; \
 | 
					 | 
				
			||||||
	libs="-l$$i $$libs"; \
 | 
					 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This assumes that GNU utilities are *not* used
 | 
					# This assumes that GNU utilities are *not* used
 | 
				
			||||||
@@ -369,14 +306,11 @@ do_alpha-osf1-shared:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
							( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
			-shared -o lib$$i.so \
 | 
								-shared -o lib$$i.so \
 | 
				
			||||||
			-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
								-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
				
			||||||
			-all lib$$i.a -none $$libs ${EX_LIBS} ) || exit 1; \
 | 
								-all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -388,14 +322,11 @@ do_tru64-shared:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
							( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
			-shared -msym -o lib$$i.so \
 | 
								-shared -msym -o lib$$i.so \
 | 
				
			||||||
			-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
								-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
				
			||||||
			-all lib$$i.a -none $$libs ${EX_LIBS} ) || exit 1; \
 | 
								-all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -407,15 +338,12 @@ do_tru64-shared-rpath:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
							( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
			-shared -msym -o lib$$i.so \
 | 
								-shared -msym -o lib$$i.so \
 | 
				
			||||||
			-rpath  ${INSTALLTOP}/lib \
 | 
								-rpath  ${INSTALLTOP}/lib \
 | 
				
			||||||
			-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
								-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
				
			||||||
			-all lib$$i.a -none $$libs ${EX_LIBS} ) || exit 1; \
 | 
								-all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -426,19 +354,12 @@ do_solaris-shared:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
							( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
				
			||||||
		  MINUSZ='-z '; \
 | 
							  set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
		  (${CC} -v 2>&1 | grep gcc) > /dev/null && MINUSZ='-Wl,-z,'; \
 | 
								-G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		  set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
			-o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
					 | 
				
			||||||
			-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			-Wl,-Bsymbolic \
 | 
								-z allextract lib$$i.a $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
				
			||||||
			$${MINUSZ}allextract lib$$i.a $${MINUSZ}defaultextract \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
			$$libs ${EX_LIBS} ) || exit 1; \
 | 
					 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
					 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -448,20 +369,16 @@ do_svr3-shared:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
							( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
				
			||||||
		  find . -name "*.o" -print > allobjs ; \
 | 
							  find . -name "*.o" -print > allobjs ; \
 | 
				
			||||||
		  OBJS= ; export OBJS ; \
 | 
							  OBJS= ; export OBJS ; \
 | 
				
			||||||
		  for obj in `ar t lib$$i.a` ; do \
 | 
							  for obj in `ar t lib$$i.a` ; do \
 | 
				
			||||||
		    OBJS="$${OBJS} `grep /$$obj allobjs`" ; \
 | 
							    OBJS="$${OBJS} `grep $$obj allobjs`" ; \
 | 
				
			||||||
		  done ; \
 | 
							  done ; \
 | 
				
			||||||
		  set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
							  set -x; ${CC}  -G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			-G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
					 | 
				
			||||||
			-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			$${OBJS} $$libs ${EX_LIBS} ) || exit 1; \
 | 
								$${OBJS} $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -471,23 +388,17 @@ do_svr5-shared:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
							( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
				
			||||||
		  SHARE_FLAG='-G'; \
 | 
					 | 
				
			||||||
		  (${CC} -v 2>&1 | grep gcc) > /dev/null && SHARE_FLAG='-shared'; \
 | 
					 | 
				
			||||||
		  find . -name "*.o" -print > allobjs ; \
 | 
							  find . -name "*.o" -print > allobjs ; \
 | 
				
			||||||
		  OBJS= ; export OBJS ; \
 | 
							  OBJS= ; export OBJS ; \
 | 
				
			||||||
		  for obj in `ar t lib$$i.a` ; do \
 | 
							  for obj in `ar t lib$$i.a` ; do \
 | 
				
			||||||
		    OBJS="$${OBJS} `grep /$$obj allobjs`" ; \
 | 
							    OBJS="$${OBJS} `grep $$obj allobjs`" ; \
 | 
				
			||||||
		  done ; \
 | 
							  done ; \
 | 
				
			||||||
		  set -x; LD_LIBRARY_PATH=.:$$LD_LIBRARY_PATH \
 | 
							  set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			$${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
								-G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			$${SHARE_FLAG} -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
					 | 
				
			||||||
			-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			$${OBJS} $$libs ${EX_LIBS} ) || exit 1; \
 | 
								$${OBJS} $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -497,38 +408,51 @@ do_irix-shared:
 | 
				
			|||||||
		$(MAKE) do_gnu-shared; \
 | 
							$(MAKE) do_gnu-shared; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
							libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
							( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
		( WHOLELIB="-all lib$$i.a -none"; \
 | 
					 | 
				
			||||||
		  (${CC} -v 2>&1 | grep gcc) > /dev/null && WHOLELIB="-Wl,-all,lib$$i.a,-none"; \
 | 
					 | 
				
			||||||
		  set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					 | 
				
			||||||
			-shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			-Wl,-soname,lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-Wl,-soname,lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			$${WHOLELIB} $$libs ${EX_LIBS}) || exit 1; \
 | 
								-all lib$$i.a $$libs ${EX_LIBS} -lc) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="$$libs -l$$i"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This assumes that GNU utilities are *not* used
 | 
					# This assumes that GNU utilities are *not* used
 | 
				
			||||||
 | 
					# HP-UX includes the full pathname of libs we depend on, so we would get
 | 
				
			||||||
 | 
					# ./libcrypto (with ./ as path information) compiled into libssl, hence
 | 
				
			||||||
 | 
					# we omit the SHLIBDEPS. Applications must be linked with -lssl -lcrypto
 | 
				
			||||||
 | 
					# anyway.
 | 
				
			||||||
 | 
					# The object modules are loaded from lib$i.a using the undocumented -Fl
 | 
				
			||||||
 | 
					# option.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# WARNING: Until DSO is fixed to support a search path, we support SHLIB_PATH
 | 
				
			||||||
 | 
					#          by temporarily specifying "+s"!
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
do_hpux-shared:
 | 
					do_hpux-shared:
 | 
				
			||||||
	for i in ${SHLIBDIRS}; do \
 | 
						for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						( set -x; /usr/ccs/bin/ld ${SHARED_LDFLAGS} \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 		+vnocompatwarnings \
 | 
				
			||||||
	fi; \
 | 
							-b -z +s \
 | 
				
			||||||
	if expr $(PLATFORM) : '.*ia64' > /dev/null; then \
 | 
							-o lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		shlib=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR}; \
 | 
							+h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
	else \
 | 
							-Fl lib$$i.a -ldld -lc ) || exit 1; \
 | 
				
			||||||
		shlib=lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR}; \
 | 
						done
 | 
				
			||||||
	fi; \
 | 
					
 | 
				
			||||||
	[ -f $$shlib ] && rm -f $$shlib; \
 | 
					# This assumes that GNU utilities are *not* used
 | 
				
			||||||
	ALLSYMSFLAGS='-Wl,-Fl'; \
 | 
					# HP-UX includes the full pathname of libs we depend on, so we would get
 | 
				
			||||||
	expr $(PLATFORM) : 'hpux64' > /dev/null && ALLSYMSFLAGS='-Wl,+forceload'; \
 | 
					# ./libcrypto (with ./ as path information) compiled into libssl, hence
 | 
				
			||||||
	( set -x; $${FIPSLD:-${CC}} ${SHARED_LDFLAGS} \
 | 
					# we omit the SHLIBDEPS. Applications must be linked with -lssl -lcrypto
 | 
				
			||||||
		-Wl,-B,symbolic,+vnocompatwarnings,-z,+h,$$shlib \
 | 
					# anyway.
 | 
				
			||||||
		-o $$shlib $$ALLSYMSFLAGS,lib$$i.a -ldld ) || exit 1; \
 | 
					#
 | 
				
			||||||
	chmod a=rx $$shlib; \
 | 
					# HP-UX in 64bit mode has "+s" enabled by default; it will search for
 | 
				
			||||||
 | 
					# shared libraries along LD_LIBRARY_PATH _and_ SHLIB_PATH.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					do_hpux64-shared:
 | 
				
			||||||
 | 
						for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
 | 
						( set -x; /usr/ccs/bin/ld ${SHARED_LDFLAGS} \
 | 
				
			||||||
 | 
					 		-b -z \
 | 
				
			||||||
 | 
							-o lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
 | 
							+h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
 | 
							+forceload lib$$i.a -ldl -lc ) || exit 1; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# The following method is said to work on all platforms.  Tests will
 | 
					# The following method is said to work on all platforms.  Tests will
 | 
				
			||||||
@@ -565,71 +489,48 @@ SHAREDFLAGS=${SHARED_LDFLAGS} -G -bE:lib$$i.exp -bM:SRE
 | 
				
			|||||||
SHAREDCMD=$(CC)
 | 
					SHAREDCMD=$(CC)
 | 
				
			||||||
do_aix-shared:
 | 
					do_aix-shared:
 | 
				
			||||||
	libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
						libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	( set -x; \
 | 
						( set -x; \
 | 
				
			||||||
	  OBJECT_MODE=`expr x${SHARED_LDFLAGS} : 'x\-[a-z]\([0-9]*\)'`; \
 | 
						  ld -r -o $$i.o $(ALLSYMSFLAG) lib$$i.a && \
 | 
				
			||||||
	  OBJECT_MODE=$${OBJECT_MODE:-32}; export OBJECT_MODE; \
 | 
					 | 
				
			||||||
	  ld -r -o lib$$i.o $(ALLSYMSFLAG) lib$$i.a && \
 | 
					 | 
				
			||||||
	  ( nm -Pg lib$$i.o | grep ' [BD] ' | cut -f1 -d' ' > lib$$i.exp; \
 | 
						  ( nm -Pg lib$$i.o | grep ' [BD] ' | cut -f1 -d' ' > lib$$i.exp; \
 | 
				
			||||||
	    $${FIPSLD:-${CC}} $(SHAREDFLAGS) \
 | 
						    $(SHAREDCMD) $(SHAREDFLAG) -o lib$$i.so lib$$i.o \
 | 
				
			||||||
		-o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} lib$$i.o \
 | 
					 | 
				
			||||||
		$$libs ${EX_LIBS} ) ) \
 | 
							$$libs ${EX_LIBS} ) ) \
 | 
				
			||||||
	|| exit 1; \
 | 
						|| exit 1; \
 | 
				
			||||||
	libs="-l$$i $$libs"; \
 | 
						libs="$$libs -l$$i"; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
do_reliantunix-shared:
 | 
					do_reliantunix-shared:
 | 
				
			||||||
	libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
						libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	tmpdir=/tmp/openssl.$$$$ ; rm -rf $$tmpdir ; \
 | 
						tmpdir=/tmp/openssl.$$$$ ; rm -rf $$tmpdir ; \
 | 
				
			||||||
	( set -x; \
 | 
						( set -x; \
 | 
				
			||||||
	  ( Opwd=`pwd` ; mkdir $$tmpdir || exit 1; \
 | 
						  ( Opwd=`pwd` ; mkdir $$tmpdir || exit 1; \
 | 
				
			||||||
	    cd $$tmpdir || exit 1 ; ar x $$Opwd/lib$$i.a ; \
 | 
						    cd $$tmpdir || exit 1 ; ar x $$Opwd/lib$$i.a ; \
 | 
				
			||||||
	    $${FIPSLD:-${CC}} -G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} *.o \
 | 
						    ${CC} -G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} *.o \
 | 
				
			||||||
	  ) || exit 1; \
 | 
						  ) || exit 1; \
 | 
				
			||||||
	  cp $$tmpdir/lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} . ; \
 | 
						  cp $$tmpdir/lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} . ; \
 | 
				
			||||||
	) || exit 1; \
 | 
						) || exit 1; \
 | 
				
			||||||
	rm -rf $$tmpdir ; \
 | 
						rm -rf $$tmpdir ; \
 | 
				
			||||||
	libs="-l$$i $$libs"; \
 | 
						libs="$$libs -l$$i"; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
openssl.pc: Makefile
 | 
					Makefile.ssl: Makefile.org
 | 
				
			||||||
	@ ( echo 'prefix=$(INSTALLTOP)'; \
 | 
						@echo "Makefile.ssl is older than Makefile.org."
 | 
				
			||||||
	    echo 'exec_prefix=$${prefix}'; \
 | 
					 | 
				
			||||||
	    echo 'libdir=$${exec_prefix}/lib'; \
 | 
					 | 
				
			||||||
	    echo 'includedir=$${prefix}/include'; \
 | 
					 | 
				
			||||||
	    echo ''; \
 | 
					 | 
				
			||||||
	    echo 'Name: OpenSSL'; \
 | 
					 | 
				
			||||||
	    echo 'Description: Secure Sockets Layer and cryptography libraries and tools'; \
 | 
					 | 
				
			||||||
	    echo 'Version: '$(VERSION); \
 | 
					 | 
				
			||||||
	    echo 'Requires: '; \
 | 
					 | 
				
			||||||
	    echo 'Libs: -L$${libdir} -lssl -lcrypto $(LIBKRB5) $(EX_LIBS)'; \
 | 
					 | 
				
			||||||
	    echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > openssl.pc
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Makefile: Makefile.org
 | 
					 | 
				
			||||||
	@echo "Makefile is older than Makefile.org."
 | 
					 | 
				
			||||||
	@echo "Reconfigure the source tree (via './config' or 'perl Configure'), please."
 | 
						@echo "Reconfigure the source tree (via './config' or 'perl Configure'), please."
 | 
				
			||||||
	@false
 | 
						@false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
libclean:
 | 
					libclean:
 | 
				
			||||||
	rm -f *.map *.so *.so.* engines/*.so *.a */lib */*/lib
 | 
						rm -f *.a */lib */*/lib
 | 
				
			||||||
 | 
					
 | 
				
			||||||
clean:	libclean
 | 
					clean:
 | 
				
			||||||
	rm -f shlib/*.o *.o core a.out fluff rehash.time testlog make.log cctest cctest.c
 | 
						rm -f shlib/*.o *.o core a.out fluff *.map rehash.time testlog make.log cctest cctest.c
 | 
				
			||||||
	@for i in $(DIRS) ;\
 | 
						@for i in $(DIRS) ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making clean in $$i..." && \
 | 
							(cd $$i && echo "making clean in $$i..." && \
 | 
				
			||||||
		$(MAKE) EXE_EXT='${EXE_EXT}' SDIRS='${SDIRS}' clean ) || exit 1; \
 | 
							$(MAKE) SDIRS='${SDIRS}' clean ) || exit 1; \
 | 
				
			||||||
		rm -f $(LIBS); \
 | 
							rm -f $(LIBS); \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
	rm -f openssl.pc
 | 
						rm -f *.a *.o speed.* *.map *.so .pure core
 | 
				
			||||||
	rm -f speed.* .pure
 | 
					 | 
				
			||||||
	rm -f $(TARFILE)
 | 
						rm -f $(TARFILE)
 | 
				
			||||||
	@for i in $(ONEDIRS) ;\
 | 
						@for i in $(ONEDIRS) ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
@@ -641,7 +542,7 @@ makefile.one: files
 | 
				
			|||||||
	sh util/do_ms.sh
 | 
						sh util/do_ms.sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
files:
 | 
					files:
 | 
				
			||||||
	$(PERL) $(TOP)/util/files.pl Makefile > $(TOP)/MINFO
 | 
						$(PERL) $(TOP)/util/files.pl Makefile.ssl > $(TOP)/MINFO
 | 
				
			||||||
	@for i in $(DIRS) ;\
 | 
						@for i in $(DIRS) ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
@@ -651,19 +552,16 @@ files:
 | 
				
			|||||||
	done;
 | 
						done;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
links:
 | 
					links:
 | 
				
			||||||
 | 
						@$(TOP)/util/point.sh Makefile.ssl Makefile
 | 
				
			||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl include/openssl
 | 
						@$(PERL) $(TOP)/util/mkdir-p.pl include/openssl
 | 
				
			||||||
	@$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER)
 | 
						@$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER)
 | 
				
			||||||
	@for i in $(DIRS); do \
 | 
						@for i in $(DIRS); do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making links in $$i..." && \
 | 
							(cd $$i && echo "making links in $$i..." && \
 | 
				
			||||||
		$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PERL='${PERL}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' links ) || exit 1; \
 | 
							$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PERL='${PERL}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' links ) || exit 1; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
gentests:
 | 
					 | 
				
			||||||
	@(cd test && echo "generating dummy tests (if needed)..." && \
 | 
					 | 
				
			||||||
	$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TESTS='${TESTS}' OPENSSL_DEBUG_MEMORY=on generate );
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
dclean:
 | 
					dclean:
 | 
				
			||||||
	rm -f *.bak
 | 
						rm -f *.bak
 | 
				
			||||||
	@for i in $(DIRS) ;\
 | 
						@for i in $(DIRS) ;\
 | 
				
			||||||
@@ -676,18 +574,21 @@ dclean:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
rehash: rehash.time
 | 
					rehash: rehash.time
 | 
				
			||||||
rehash.time: certs
 | 
					rehash.time: certs
 | 
				
			||||||
	@(OPENSSL="`pwd`/util/opensslwrap.sh"; \
 | 
						@(OPENSSL="`pwd`/apps/openssl"; OPENSSL_DEBUG_MEMORY=on; \
 | 
				
			||||||
	  OPENSSL_DEBUG_MEMORY=on; \
 | 
							export OPENSSL OPENSSL_DEBUG_MEMORY; \
 | 
				
			||||||
	  export OPENSSL OPENSSL_DEBUG_MEMORY; \
 | 
							LD_LIBRARY_PATH="`pwd`"; SHLIB_PATH="`pwd`"; LIBPATH="`pwd`"; \
 | 
				
			||||||
	  $(PERL) tools/c_rehash certs)
 | 
							export LD_LIBRARY_PATH SHLIB_PATH LIBPATH; \
 | 
				
			||||||
 | 
							$(PERL) tools/c_rehash certs)
 | 
				
			||||||
	touch rehash.time
 | 
						touch rehash.time
 | 
				
			||||||
 | 
					
 | 
				
			||||||
test:   tests
 | 
					test:   tests
 | 
				
			||||||
 | 
					
 | 
				
			||||||
tests: rehash
 | 
					tests: rehash
 | 
				
			||||||
	@(cd test && echo "testing..." && \
 | 
						@(cd test && echo "testing..." && \
 | 
				
			||||||
	$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TESTS='${TESTS}' OPENSSL_DEBUG_MEMORY=on tests );
 | 
						$(MAKE) CC='${CC}' CFLAG='${CFLAG}' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SDIRS='${SDIRS}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PERL='${PERL}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' OPENSSL_DEBUG_MEMORY=on tests );
 | 
				
			||||||
	util/shlib_wrap.sh apps/openssl version -a
 | 
						@LD_LIBRARY_PATH="`pwd`"; SHLIB_PATH="`pwd`"; LIBPATH="`pwd`"; \
 | 
				
			||||||
 | 
							export LD_LIBRARY_PATH SHLIB_PATH LIBPATH; \
 | 
				
			||||||
 | 
							apps/openssl version -a
 | 
				
			||||||
 | 
					
 | 
				
			||||||
report:
 | 
					report:
 | 
				
			||||||
	@$(PERL) util/selftest.pl
 | 
						@$(PERL) util/selftest.pl
 | 
				
			||||||
@@ -697,7 +598,7 @@ depend:
 | 
				
			|||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making dependencies $$i..." && \
 | 
							(cd $$i && echo "making dependencies $$i..." && \
 | 
				
			||||||
		$(MAKE) SDIRS='${SDIRS}' CFLAG='${CFLAG}' DEPFLAG='${DEPFLAG}' MAKEDEPPROG='${MAKEDEPPROG}' KRB5_INCLUDES='${KRB5_INCLUDES}' PERL='${PERL}' depend ) || exit 1; \
 | 
							$(MAKE) SDIRS='${SDIRS}' DEPFLAG='${DEPFLAG}' MAKEDEPPROG='${MAKEDEPPROG}' KRB5_INCLUDES='${KRB5_INCLUDES}' depend ) || exit 1; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -711,8 +612,13 @@ lint:
 | 
				
			|||||||
	done;
 | 
						done;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
tags:
 | 
					tags:
 | 
				
			||||||
	rm -f TAGS
 | 
						@for i in $(DIRS) ;\
 | 
				
			||||||
	find . -name '[^.]*.[ch]' | xargs etags -a
 | 
						do \
 | 
				
			||||||
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
 | 
							(cd $$i && echo "making tags $$i..." && \
 | 
				
			||||||
 | 
							$(MAKE) SDIRS='${SDIRS}' tags ) || exit 1; \
 | 
				
			||||||
 | 
						fi; \
 | 
				
			||||||
 | 
						done;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
errors:
 | 
					errors:
 | 
				
			||||||
	$(PERL) util/mkerr.pl -recurse -write
 | 
						$(PERL) util/mkerr.pl -recurse -write
 | 
				
			||||||
@@ -732,35 +638,19 @@ crypto/objects/obj_dat.h: crypto/objects/obj_dat.pl crypto/objects/obj_mac.h
 | 
				
			|||||||
crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num
 | 
					crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num
 | 
				
			||||||
	$(PERL) crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num crypto/objects/obj_mac.h
 | 
						$(PERL) crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num crypto/objects/obj_mac.h
 | 
				
			||||||
 | 
					
 | 
				
			||||||
apps/openssl-vms.cnf: apps/openssl.cnf
 | 
					 | 
				
			||||||
	$(PERL) VMS/VMSify-conf.pl < apps/openssl.cnf > apps/openssl-vms.cnf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
crypto/bn/bn_prime.h: crypto/bn/bn_prime.pl
 | 
					 | 
				
			||||||
	$(PERL) crypto/bn/bn_prime.pl >crypto/bn/bn_prime.h
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
TABLE: Configure
 | 
					TABLE: Configure
 | 
				
			||||||
	(echo 'Output of `Configure TABLE'"':"; \
 | 
						(echo 'Output of `Configure TABLE'"':"; \
 | 
				
			||||||
	$(PERL) Configure TABLE) > TABLE
 | 
						$(PERL) Configure TABLE) > TABLE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
update: errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h apps/openssl-vms.cnf crypto/bn/bn_prime.h TABLE depend
 | 
					update: depend errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h TABLE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Build distribution tar-file. As the list of files returned by "find" is
 | 
					 | 
				
			||||||
# pretty long, on several platforms a "too many arguments" error or similar
 | 
					 | 
				
			||||||
# would occur. Therefore the list of files is temporarily stored into a file
 | 
					 | 
				
			||||||
# and read directly, requiring GNU-Tar. Call "make TAR=gtar dist" if the normal
 | 
					 | 
				
			||||||
# tar does not support the --files-from option.
 | 
					 | 
				
			||||||
tar:
 | 
					tar:
 | 
				
			||||||
	find . -type d -print | xargs chmod 755
 | 
						@$(TAR) $(TARFLAGS) -cvf - \
 | 
				
			||||||
	find . -type f -print | xargs chmod a+r
 | 
							`find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE | sort` |\
 | 
				
			||||||
	find . -type f -perm -0100 -print | xargs chmod a+x
 | 
					 | 
				
			||||||
	find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE | sort > ../$(TARFILE).list; \
 | 
					 | 
				
			||||||
	$(TAR) $(TARFLAGS) --files-from ../$(TARFILE).list -cvf - | \
 | 
					 | 
				
			||||||
	tardy --user_number=0  --user_name=openssl \
 | 
						tardy --user_number=0  --user_name=openssl \
 | 
				
			||||||
	      --group_number=0 --group_name=openssl \
 | 
						      --group_number=0 --group_name=openssl \
 | 
				
			||||||
	      --prefix=openssl-$(VERSION) - |\
 | 
						      --prefix=openssl-$(VERSION) - |\
 | 
				
			||||||
	gzip --best >../$(TARFILE).gz; \
 | 
						gzip --best >../$(TARFILE).gz; \
 | 
				
			||||||
	rm -f ../$(TARFILE).list; \
 | 
					 | 
				
			||||||
	ls -l ../$(TARFILE).gz
 | 
						ls -l ../$(TARFILE).gz
 | 
				
			||||||
 | 
					
 | 
				
			||||||
tar-snap:
 | 
					tar-snap:
 | 
				
			||||||
@@ -775,22 +665,20 @@ dist:
 | 
				
			|||||||
	$(PERL) Configure dist
 | 
						$(PERL) Configure dist
 | 
				
			||||||
	@$(MAKE) dist_pem_h
 | 
						@$(MAKE) dist_pem_h
 | 
				
			||||||
	@$(MAKE) SDIRS='${SDIRS}' clean
 | 
						@$(MAKE) SDIRS='${SDIRS}' clean
 | 
				
			||||||
	@$(MAKE) TAR='${TAR}' TARFLAGS='${TARFLAGS}' tar
 | 
						@$(MAKE) tar
 | 
				
			||||||
 | 
					
 | 
				
			||||||
dist_pem_h:
 | 
					dist_pem_h:
 | 
				
			||||||
	(cd crypto/pem; $(MAKE) CC='${CC}' SDIRS='${SDIRS}' CFLAG='${CFLAG}' pem.h; $(MAKE) clean)
 | 
						(cd crypto/pem; $(MAKE) CC='${CC}' SDIRS='${SDIRS}' CFLAG='${CFLAG}' pem.h; $(MAKE) clean)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install: all install_docs install_sw
 | 
					install: all install_docs
 | 
				
			||||||
 | 
					 | 
				
			||||||
install_sw:
 | 
					 | 
				
			||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \
 | 
						@$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/lib \
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/lib \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig \
 | 
					 | 
				
			||||||
		$(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/misc \
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/misc \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/certs \
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/certs \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/private
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/private \
 | 
				
			||||||
	@headerlist="$(EXHEADER)"; for i in $$headerlist ;\
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/lib
 | 
				
			||||||
 | 
						@for i in $(EXHEADER) ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
@@ -806,14 +694,9 @@ install_sw:
 | 
				
			|||||||
	do \
 | 
						do \
 | 
				
			||||||
		if [ -f "$$i" ]; then \
 | 
							if [ -f "$$i" ]; then \
 | 
				
			||||||
		(       echo installing $$i; \
 | 
							(       echo installing $$i; \
 | 
				
			||||||
			cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
								cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib; \
 | 
				
			||||||
			if egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null; then \
 | 
								$(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
				
			||||||
				: ; \
 | 
								chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i ); \
 | 
				
			||||||
			else \
 | 
					 | 
				
			||||||
				$(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
					 | 
				
			||||||
			fi; \
 | 
					 | 
				
			||||||
			chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
					 | 
				
			||||||
			mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i ); \
 | 
					 | 
				
			||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
	@if [ -n "$(SHARED_LIBS)" ]; then \
 | 
						@if [ -n "$(SHARED_LIBS)" ]; then \
 | 
				
			||||||
@@ -823,33 +706,21 @@ install_sw:
 | 
				
			|||||||
			if [ -f "$$i" -o -f "$$i.a" ]; then \
 | 
								if [ -f "$$i" -o -f "$$i.a" ]; then \
 | 
				
			||||||
			(       echo installing $$i; \
 | 
								(       echo installing $$i; \
 | 
				
			||||||
				if [ "$(PLATFORM)" != "Cygwin" ]; then \
 | 
									if [ "$(PLATFORM)" != "Cygwin" ]; then \
 | 
				
			||||||
					cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
										cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib; \
 | 
				
			||||||
					chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
										chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
					 | 
				
			||||||
				else \
 | 
									else \
 | 
				
			||||||
					c=`echo $$i | sed 's/^lib\(.*\)\.dll/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \
 | 
										c=`echo $$i | sed 's/^lib/cyg/'`; \
 | 
				
			||||||
					cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
										cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \
 | 
				
			||||||
					chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
										chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \
 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \
 | 
										cp $$i.a $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a; \
 | 
				
			||||||
					cp $$i.a $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a.new; \
 | 
										chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a; \
 | 
				
			||||||
					chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a.new; \
 | 
					 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a; \
 | 
					 | 
				
			||||||
				fi ); \
 | 
									fi ); \
 | 
				
			||||||
			fi; \
 | 
								fi; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
		(	here="`pwd`"; \
 | 
							(	here="`pwd`"; \
 | 
				
			||||||
			cd $(INSTALL_PREFIX)$(INSTALLTOP)/lib; \
 | 
								cd $(INSTALL_PREFIX)$(INSTALLTOP)/lib; \
 | 
				
			||||||
			set $(MAKE); \
 | 
								make -f $$here/Makefile link-shared ); \
 | 
				
			||||||
			$$1 -f $$here/Makefile link-shared ); \
 | 
					 | 
				
			||||||
		if [ "$(INSTALLTOP)" != "/usr" ]; then \
 | 
					 | 
				
			||||||
			echo 'OpenSSL shared libraries have been installed in:'; \
 | 
					 | 
				
			||||||
			echo '  $(INSTALLTOP)'; \
 | 
					 | 
				
			||||||
			echo ''; \
 | 
					 | 
				
			||||||
			sed -e '1,/^$$/d' doc/openssl-shared.txt; \
 | 
					 | 
				
			||||||
		fi; \
 | 
					 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig
 | 
					 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig/openssl.pc
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
install_docs:
 | 
					install_docs:
 | 
				
			||||||
	@$(PERL) $(TOP)/util/mkdir-p.pl \
 | 
						@$(PERL) $(TOP)/util/mkdir-p.pl \
 | 
				
			||||||
@@ -857,45 +728,23 @@ install_docs:
 | 
				
			|||||||
		$(INSTALL_PREFIX)$(MANDIR)/man3 \
 | 
							$(INSTALL_PREFIX)$(MANDIR)/man3 \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(MANDIR)/man5 \
 | 
							$(INSTALL_PREFIX)$(MANDIR)/man5 \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(MANDIR)/man7
 | 
							$(INSTALL_PREFIX)$(MANDIR)/man7
 | 
				
			||||||
	@pod2man="`cd util; ./pod2mantest $(PERL)`"; \
 | 
						@for i in doc/apps/*.pod; do \
 | 
				
			||||||
	here="`pwd`"; \
 | 
					 | 
				
			||||||
	filecase=; \
 | 
					 | 
				
			||||||
	if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" -o "$(PLATFORM)" = "mingw" ]; then \
 | 
					 | 
				
			||||||
		filecase=-i; \
 | 
					 | 
				
			||||||
	fi; \
 | 
					 | 
				
			||||||
	for i in doc/apps/*.pod; do \
 | 
					 | 
				
			||||||
		fn=`basename $$i .pod`; \
 | 
							fn=`basename $$i .pod`; \
 | 
				
			||||||
		if [ "$$fn" = "config" ]; then sec=5; else sec=1; fi; \
 | 
							if [ "$$fn" = "config" ]; then sec=5; else sec=1; fi; \
 | 
				
			||||||
		echo "installing man$$sec/$$fn.$${sec}$(MANSUFFIX)"; \
 | 
							echo "installing man$$sec/`basename $$i .pod`.$$sec"; \
 | 
				
			||||||
		(cd `$(PERL) util/dirname.pl $$i`; \
 | 
							(cd `dirname $$i`; \
 | 
				
			||||||
		sh -c "$$pod2man \
 | 
							$(PERL) ../../util/pod2man.pl --section=$$sec --center=OpenSSL \
 | 
				
			||||||
			--section=$$sec --center=OpenSSL \
 | 
								 --release=$(VERSION) `basename $$i`) \
 | 
				
			||||||
			--release=$(VERSION) `basename $$i`") \
 | 
								>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/`basename $$i .pod`.$$sec; \
 | 
				
			||||||
			>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \
 | 
						done
 | 
				
			||||||
		$(PERL) util/extract-names.pl < $$i | \
 | 
						@for i in doc/crypto/*.pod doc/ssl/*.pod; do \
 | 
				
			||||||
			(grep -v $$filecase "^$$fn\$$"; true) | \
 | 
					 | 
				
			||||||
			(grep -v "[	]"; true) | \
 | 
					 | 
				
			||||||
			(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
					 | 
				
			||||||
			 while read n; do \
 | 
					 | 
				
			||||||
				$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
					 | 
				
			||||||
			 done); \
 | 
					 | 
				
			||||||
	done; \
 | 
					 | 
				
			||||||
	for i in doc/crypto/*.pod doc/ssl/*.pod; do \
 | 
					 | 
				
			||||||
		fn=`basename $$i .pod`; \
 | 
							fn=`basename $$i .pod`; \
 | 
				
			||||||
		if [ "$$fn" = "des_modes" ]; then sec=7; else sec=3; fi; \
 | 
							if [ "$$fn" = "des_modes" ]; then sec=7; else sec=3; fi; \
 | 
				
			||||||
		echo "installing man$$sec/$$fn.$${sec}$(MANSUFFIX)"; \
 | 
							echo "installing man$$sec/`basename $$i .pod`.$$sec"; \
 | 
				
			||||||
		(cd `$(PERL) util/dirname.pl $$i`; \
 | 
							(cd `dirname $$i`; \
 | 
				
			||||||
		sh -c "$$pod2man \
 | 
							$(PERL) ../../util/pod2man.pl --section=$$sec --center=OpenSSL \
 | 
				
			||||||
			--section=$$sec --center=OpenSSL \
 | 
								--release=$(VERSION) `basename $$i`) \
 | 
				
			||||||
			--release=$(VERSION) `basename $$i`") \
 | 
								>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/`basename $$i .pod`.$$sec; \
 | 
				
			||||||
			>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \
 | 
					 | 
				
			||||||
		$(PERL) util/extract-names.pl < $$i | \
 | 
					 | 
				
			||||||
			(grep -v $$filecase "^$$fn\$$"; true) | \
 | 
					 | 
				
			||||||
			(grep -v "[	]"; true) | \
 | 
					 | 
				
			||||||
			(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
					 | 
				
			||||||
			 while read n; do \
 | 
					 | 
				
			||||||
				$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
					 | 
				
			||||||
			 done); \
 | 
					 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# DO NOT DELETE THIS LINE -- make depend depends on it.
 | 
					# DO NOT DELETE THIS LINE -- make depend depends on it.
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										152
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										152
									
								
								NEWS
									
									
									
									
									
								
							@@ -5,94 +5,6 @@
 | 
				
			|||||||
  This file gives a brief overview of the major changes between each OpenSSL
 | 
					  This file gives a brief overview of the major changes between each OpenSSL
 | 
				
			||||||
  release. For more details please read the CHANGES file.
 | 
					  release. For more details please read the CHANGES file.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Major changes between OpenSSL 0.9.7l and OpenSSL 0.9.7m:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o FIPS 1.1.1 module linking.
 | 
					 | 
				
			||||||
      o Various ciphersuite selection fixes.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7k and OpenSSL 0.9.7l:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Introduce limits to prevent malicious key DoS  (CVE-2006-2940)
 | 
					 | 
				
			||||||
      o Fix security issues (CVE-2006-2937, CVE-2006-3737, CVE-2006-4343)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7j and OpenSSL 0.9.7k:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix Daniel Bleichenbacher forged signature attack, CVE-2006-4339
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7i and OpenSSL 0.9.7j:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Visual C++ 2005 fixes.
 | 
					 | 
				
			||||||
      o Update Windows build system for FIPS.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7h and OpenSSL 0.9.7i:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Give EVP_MAX_MD_SIZE it's old value, except for a FIPS build.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7g and OpenSSL 0.9.7h:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix SSL 2.0 Rollback, CVE-2005-2969
 | 
					 | 
				
			||||||
      o Allow use of fixed-length exponent on DSA signing
 | 
					 | 
				
			||||||
      o Default fixed-window RSA, DSA, DH private-key operations
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7f and OpenSSL 0.9.7g:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o More compilation issues fixed.
 | 
					 | 
				
			||||||
      o Adaptation to more modern Kerberos API.
 | 
					 | 
				
			||||||
      o Enhanced or corrected configuration for Solaris64, Mingw and Cygwin.
 | 
					 | 
				
			||||||
      o Enhanced x86_64 assembler BIGNUM module.
 | 
					 | 
				
			||||||
      o More constification.
 | 
					 | 
				
			||||||
      o Added processing of proxy certificates (RFC 3820).
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7e and OpenSSL 0.9.7f:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Several compilation issues fixed.
 | 
					 | 
				
			||||||
      o Many memory allocation failure checks added.
 | 
					 | 
				
			||||||
      o Improved comparison of X509 Name type.
 | 
					 | 
				
			||||||
      o Mandatory basic checks on certificates.
 | 
					 | 
				
			||||||
      o Performance improvements.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7d and OpenSSL 0.9.7e:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Fix race condition in CRL checking code.
 | 
					 | 
				
			||||||
      o Fixes to PKCS#7 (S/MIME) code.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7c and OpenSSL 0.9.7d:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Security: Fix Kerberos ciphersuite SSL/TLS handshaking bug
 | 
					 | 
				
			||||||
      o Security: Fix null-pointer assignment in do_change_cipher_spec()
 | 
					 | 
				
			||||||
      o Allow multiple active certificates with same subject in CA index
 | 
					 | 
				
			||||||
      o Multiple X509 verification fixes
 | 
					 | 
				
			||||||
      o Speed up HMAC and other operations
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7b and OpenSSL 0.9.7c:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Security: fix various ASN1 parsing bugs.
 | 
					 | 
				
			||||||
      o New -ignore_err option to OCSP utility.
 | 
					 | 
				
			||||||
      o Various interop and bug fixes in S/MIME code.
 | 
					 | 
				
			||||||
      o SSL/TLS protocol fix for unrequested client certificates.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7a and OpenSSL 0.9.7b:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Security: counter the Klima-Pokorny-Rosa extension of
 | 
					 | 
				
			||||||
        Bleichbacher's attack 
 | 
					 | 
				
			||||||
      o Security: make RSA blinding default.
 | 
					 | 
				
			||||||
      o Configuration: Irix fixes, AIX fixes, better mingw support.
 | 
					 | 
				
			||||||
      o Support for new platforms: linux-ia64-ecc.
 | 
					 | 
				
			||||||
      o Build: shared library support fixes.
 | 
					 | 
				
			||||||
      o ASN.1: treat domainComponent correctly.
 | 
					 | 
				
			||||||
      o Documentation: fixes and additions.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.7 and OpenSSL 0.9.7a:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Security: Important security related bugfixes.
 | 
					 | 
				
			||||||
      o Enhanced compatibility with MIT Kerberos.
 | 
					 | 
				
			||||||
      o Can be built without the ENGINE framework.
 | 
					 | 
				
			||||||
      o IA32 assembler enhancements.
 | 
					 | 
				
			||||||
      o Support for new platforms: FreeBSD/IA64 and FreeBSD/Sparc64.
 | 
					 | 
				
			||||||
      o Configuration: the no-err option now works properly.
 | 
					 | 
				
			||||||
      o SSL/TLS: now handles manual certificate chain building.
 | 
					 | 
				
			||||||
      o SSL/TLS: certain session ID malfunctions corrected.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6 and OpenSSL 0.9.7:
 | 
					  Major changes between OpenSSL 0.9.6 and OpenSSL 0.9.7:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      o New library section OCSP.
 | 
					      o New library section OCSP.
 | 
				
			||||||
@@ -105,21 +17,13 @@
 | 
				
			|||||||
        a separate distribution.
 | 
					        a separate distribution.
 | 
				
			||||||
      o New elliptic curve library section.
 | 
					      o New elliptic curve library section.
 | 
				
			||||||
      o New AES (Rijndael) library section.
 | 
					      o New AES (Rijndael) library section.
 | 
				
			||||||
      o Support for new platforms: Windows CE, Tandem OSS, A/UX, AIX 64-bit,
 | 
					 | 
				
			||||||
        Linux x86_64, Linux 64-bit on Sparc v9
 | 
					 | 
				
			||||||
      o Extended support for some platforms: VxWorks
 | 
					 | 
				
			||||||
      o Enhanced support for shared libraries.
 | 
					 | 
				
			||||||
      o Now only builds PIC code when shared library support is requested.
 | 
					 | 
				
			||||||
      o Support for pkg-config.
 | 
					 | 
				
			||||||
      o Lots of new manuals.
 | 
					 | 
				
			||||||
      o Makes symbolic links to or copies of manuals to cover all described
 | 
					 | 
				
			||||||
        functions.
 | 
					 | 
				
			||||||
      o Change DES API to clean up the namespace (some applications link also
 | 
					      o Change DES API to clean up the namespace (some applications link also
 | 
				
			||||||
        against libdes providing similar functions having the same name).
 | 
					        against libdes providing similar functions having the same name).
 | 
				
			||||||
        Provide macros for backward compatibility (will be removed in the
 | 
					        Provide macros for backward compatibility (will be removed in the
 | 
				
			||||||
        future).
 | 
					        future).
 | 
				
			||||||
      o Unify handling of cryptographic algorithms (software and engine)
 | 
					      o Unifiy handling of cryptographic algorithms (software and
 | 
				
			||||||
        to be available via EVP routines for asymmetric and symmetric ciphers.
 | 
					        engine) to be available via EVP routines for asymmetric and
 | 
				
			||||||
 | 
					        symmetric ciphers.
 | 
				
			||||||
      o NCONF: new configuration handling routines.
 | 
					      o NCONF: new configuration handling routines.
 | 
				
			||||||
      o Change API to use more 'const' modifiers to improve error checking
 | 
					      o Change API to use more 'const' modifiers to improve error checking
 | 
				
			||||||
        and help optimizers.
 | 
					        and help optimizers.
 | 
				
			||||||
@@ -127,60 +31,14 @@
 | 
				
			|||||||
      o Reworked parts of the BIGNUM code.
 | 
					      o Reworked parts of the BIGNUM code.
 | 
				
			||||||
      o Support for new engines: Broadcom ubsec, Accelerated Encryption
 | 
					      o Support for new engines: Broadcom ubsec, Accelerated Encryption
 | 
				
			||||||
        Processing, IBM 4758.
 | 
					        Processing, IBM 4758.
 | 
				
			||||||
      o A few new engines added in the demos area.
 | 
					 | 
				
			||||||
      o Extended and corrected OID (object identifier) table.
 | 
					 | 
				
			||||||
      o PRNG: query at more locations for a random device, automatic query for
 | 
					      o PRNG: query at more locations for a random device, automatic query for
 | 
				
			||||||
        EGD style random sources at several locations.
 | 
					        EGD style random sources at several locations.
 | 
				
			||||||
      o SSL/TLS: allow optional cipher choice according to server's preference.
 | 
					      o SSL/TLS: allow optional cipher choice according to server's preference.
 | 
				
			||||||
      o SSL/TLS: allow server to explicitly set new session ids.
 | 
					      o SSL/TLS: allow server to explicitly set new session ids.
 | 
				
			||||||
      o SSL/TLS: support Kerberos cipher suites (RFC2712).
 | 
					      o SSL/TLS: support Kerberos cipher suites (RFC2712).
 | 
				
			||||||
	Only supports MIT Kerberos for now.
 | 
					 | 
				
			||||||
      o SSL/TLS: allow more precise control of renegotiations and sessions.
 | 
					      o SSL/TLS: allow more precise control of renegotiations and sessions.
 | 
				
			||||||
      o SSL/TLS: add callback to retrieve SSL/TLS messages.
 | 
					      o SSL/TLS: add callback to retrieve SSL/TLS messages.
 | 
				
			||||||
      o SSL/TLS: support AES cipher suites (RFC3268).
 | 
					      o SSL/TLS: add draft AES ciphersuites (disabled unless explicitly requested).
 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6j and OpenSSL 0.9.6k:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Security: fix various ASN1 parsing bugs.
 | 
					 | 
				
			||||||
      o SSL/TLS protocol fix for unrequested client certificates.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6i and OpenSSL 0.9.6j:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Security: counter the Klima-Pokorny-Rosa extension of
 | 
					 | 
				
			||||||
        Bleichbacher's attack 
 | 
					 | 
				
			||||||
      o Security: make RSA blinding default.
 | 
					 | 
				
			||||||
      o Build: shared library support fixes.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6h and OpenSSL 0.9.6i:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Important security related bugfixes.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6g and OpenSSL 0.9.6h:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o New configuration targets for Tandem OSS and A/UX.
 | 
					 | 
				
			||||||
      o New OIDs for Microsoft attributes.
 | 
					 | 
				
			||||||
      o Better handling of SSL session caching.
 | 
					 | 
				
			||||||
      o Better comparison of distinguished names.
 | 
					 | 
				
			||||||
      o Better handling of shared libraries in a mixed GNU/non-GNU environment.
 | 
					 | 
				
			||||||
      o Support assembler code with Borland C.
 | 
					 | 
				
			||||||
      o Fixes for length problems.
 | 
					 | 
				
			||||||
      o Fixes for uninitialised variables.
 | 
					 | 
				
			||||||
      o Fixes for memory leaks, some unusual crashes and some race conditions.
 | 
					 | 
				
			||||||
      o Fixes for smaller building problems.
 | 
					 | 
				
			||||||
      o Updates of manuals, FAQ and other instructive documents.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6f and OpenSSL 0.9.6g:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Important building fixes on Unix.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6e and OpenSSL 0.9.6f:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Various important bugfixes.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  Major changes between OpenSSL 0.9.6d and OpenSSL 0.9.6e:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      o Important security related bugfixes.
 | 
					 | 
				
			||||||
      o Various SSL/TLS library bugfixes.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Major changes between OpenSSL 0.9.6c and OpenSSL 0.9.6d:
 | 
					  Major changes between OpenSSL 0.9.6c and OpenSSL 0.9.6d:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -233,7 +91,7 @@
 | 
				
			|||||||
      o Bug fixes for Win32, HP/UX and Irix.
 | 
					      o Bug fixes for Win32, HP/UX and Irix.
 | 
				
			||||||
      o Bug fixes in BIGNUM, SSL, PKCS#7, PKCS#12, X.509, CONF and
 | 
					      o Bug fixes in BIGNUM, SSL, PKCS#7, PKCS#12, X.509, CONF and
 | 
				
			||||||
        memory checking routines.
 | 
					        memory checking routines.
 | 
				
			||||||
      o Bug fixes for RSA operations in threaded environments.
 | 
					      o Bug fixes for RSA operations in threaded enviroments.
 | 
				
			||||||
      o Bug fixes in misc. openssl applications.
 | 
					      o Bug fixes in misc. openssl applications.
 | 
				
			||||||
      o Remove a few potential memory leaks.
 | 
					      o Remove a few potential memory leaks.
 | 
				
			||||||
      o Add tighter checks of BIGNUM routines.
 | 
					      o Add tighter checks of BIGNUM routines.
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										164
									
								
								PROBLEMS
									
									
									
									
									
								
							
							
						
						
									
										164
									
								
								PROBLEMS
									
									
									
									
									
								
							@@ -1,164 +0,0 @@
 | 
				
			|||||||
* System libcrypto.dylib and libssl.dylib are used by system ld on MacOS X.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    NOTE: The problem described here only applies when OpenSSL isn't built
 | 
					 | 
				
			||||||
    with shared library support (i.e. without the "shared" configuration
 | 
					 | 
				
			||||||
    option).  If you build with shared library support, you will have no
 | 
					 | 
				
			||||||
    problems as long as you set up DYLD_LIBRARY_PATH properly at all times.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
This is really a misfeature in ld, which seems to look for .dylib libraries
 | 
					 | 
				
			||||||
along the whole library path before it bothers looking for .a libraries.  This
 | 
					 | 
				
			||||||
means that -L switches won't matter unless OpenSSL is built with shared
 | 
					 | 
				
			||||||
library support.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The workaround may be to change the following lines in apps/Makefile and
 | 
					 | 
				
			||||||
test/Makefile:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  LIBCRYPTO=-L.. -lcrypto
 | 
					 | 
				
			||||||
  LIBSSL=-L.. -lssl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
to:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  LIBCRYPTO=../libcrypto.a
 | 
					 | 
				
			||||||
  LIBSSL=../libssl.a
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
It's possible that something similar is needed for shared library support
 | 
					 | 
				
			||||||
as well.  That hasn't been well tested yet.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Another solution that many seem to recommend is to move the libraries
 | 
					 | 
				
			||||||
/usr/lib/libcrypto.0.9.dylib, /usr/lib/libssl.0.9.dylib to a different
 | 
					 | 
				
			||||||
directory, build and install OpenSSL and anything that depends on your
 | 
					 | 
				
			||||||
build, then move libcrypto.0.9.dylib and libssl.0.9.dylib back to their
 | 
					 | 
				
			||||||
original places.  Note that the version numbers on those two libraries
 | 
					 | 
				
			||||||
may differ on your machine.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
As long as Apple doesn't fix the problem with ld, this problem building
 | 
					 | 
				
			||||||
OpenSSL will remain as is.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Parallell make leads to errors
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
While running tests, running a parallell make is a bad idea.  Many test
 | 
					 | 
				
			||||||
scripts use the same name for output and input files, which means different
 | 
					 | 
				
			||||||
will interfere with each other and lead to test failure.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The solution is simple for now: don't run parallell make when testing.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Bugs in gcc triggered
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
- According to a problem report, there are bugs in gcc 3.0 that are
 | 
					 | 
				
			||||||
  triggered by some of the code in OpenSSL, more specifically in
 | 
					 | 
				
			||||||
  PEM_get_EVP_CIPHER_INFO().  The triggering code is the following:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	header+=11;
 | 
					 | 
				
			||||||
	if (*header != '4') return(0); header++;
 | 
					 | 
				
			||||||
	if (*header != ',') return(0); header++;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  What happens is that gcc might optimize a little too agressively, and
 | 
					 | 
				
			||||||
  you end up with an extra incrementation when *header != '4'.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  We recommend that you upgrade gcc to as high a 3.x version as you can.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
- According to multiple problem reports, some of our message digest
 | 
					 | 
				
			||||||
  implementations trigger bug[s] in code optimizer in gcc 3.3 for sparc64
 | 
					 | 
				
			||||||
  and gcc 2.96 for ppc. Former fails to complete RIPEMD160 test, while
 | 
					 | 
				
			||||||
  latter - SHA one.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  The recomendation is to upgrade your compiler. This naturally applies to
 | 
					 | 
				
			||||||
  other similar cases.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* solaris64-sparcv9-cc SHA-1 performance with WorkShop 6 compiler.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
As subject suggests SHA-1 might perform poorly (4 times slower)
 | 
					 | 
				
			||||||
if compiled with WorkShop 6 compiler and -xarch=v9. The cause for
 | 
					 | 
				
			||||||
this seems to be the fact that compiler emits multiplication to
 | 
					 | 
				
			||||||
perform shift operations:-( To work the problem around configure
 | 
					 | 
				
			||||||
with './Configure solaris64-sparcv9-cc -DMD32_REG_T=int'.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Problems with hp-parisc2-cc target when used with "no-asm" flag
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
When using the hp-parisc2-cc target, wrong bignum code is generated.
 | 
					 | 
				
			||||||
This is due to the SIXTY_FOUR_BIT build being compiled with the +O3
 | 
					 | 
				
			||||||
aggressive optimization.
 | 
					 | 
				
			||||||
The problem manifests itself by the BN_kronecker test hanging in an
 | 
					 | 
				
			||||||
endless loop. Reason: the BN_kronecker test calls BN_generate_prime()
 | 
					 | 
				
			||||||
which itself hangs. The reason could be tracked down to the bn_mul_comba8()
 | 
					 | 
				
			||||||
function in bn_asm.c. At some occasions the higher 32bit value of r[7]
 | 
					 | 
				
			||||||
is off by 1 (meaning: calculated=shouldbe+1). Further analysis failed,
 | 
					 | 
				
			||||||
as no debugger support possible at +O3 and additional fprintf()'s
 | 
					 | 
				
			||||||
introduced fixed the bug, therefore it is most likely a bug in the
 | 
					 | 
				
			||||||
optimizer.
 | 
					 | 
				
			||||||
The bug was found in the BN_kronecker test but may also lead to
 | 
					 | 
				
			||||||
failures in other parts of the code.
 | 
					 | 
				
			||||||
(See Ticket #426.)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Workaround: modify the target to +O2 when building with no-asm.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Problems building shared libraries on SCO OpenServer Release 5.0.6
 | 
					 | 
				
			||||||
  with gcc 2.95.3
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The symptoms appear when running the test suite, more specifically
 | 
					 | 
				
			||||||
test/ectest, with the following result:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
OSSL_LIBPATH="`cd ..; pwd`"; LD_LIBRARY_PATH="$OSSL_LIBPATH:$LD_LIBRARY_PATH"; DYLD_LIBRARY_PATH="$OSSL_LIBPATH:$DYLD_LIBRARY_PATH"; SHLIB_PATH="$OSSL_LIBPATH:$SHLIB_PATH"; LIBPATH="$OSSL_LIBPATH:$LIBPATH"; if [ "debug-sco5-gcc" = "Cygwin" ]; then PATH="${LIBPATH}:$PATH"; fi; export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; ./ectest
 | 
					 | 
				
			||||||
ectest.c:186: ABORT
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The cause of the problem seems to be that isxdigit(), called from
 | 
					 | 
				
			||||||
BN_hex2bn(), returns 0 on a perfectly legitimate hex digit.  Further
 | 
					 | 
				
			||||||
investigation shows that any of the isxxx() macros return 0 on any
 | 
					 | 
				
			||||||
input.  A direct look in the information array that the isxxx() use,
 | 
					 | 
				
			||||||
called __ctype, shows that it contains all zeroes...
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Taking a look at the newly created libcrypto.so with nm, one can see
 | 
					 | 
				
			||||||
that the variable __ctype is defined in libcrypto's .bss (which
 | 
					 | 
				
			||||||
explains why it is filled with zeroes):
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
$ nm -Pg libcrypto.so | grep __ctype
 | 
					 | 
				
			||||||
__ctype B 0011659c
 | 
					 | 
				
			||||||
__ctype2 U         
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Curiously, __ctype2 is undefined, in spite of being declared in
 | 
					 | 
				
			||||||
/usr/include/ctype.h in exactly the same way as __ctype.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
Any information helping to solve this issue would be deeply
 | 
					 | 
				
			||||||
appreciated.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
NOTE: building non-shared doesn't come with this problem.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* ULTRIX build fails with shell errors, such as "bad substitution"
 | 
					 | 
				
			||||||
  and "test: argument expected"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
The problem is caused by ULTRIX /bin/sh supporting only original
 | 
					 | 
				
			||||||
Bourne shell syntax/semantics, and the trouble is that the vast
 | 
					 | 
				
			||||||
majority is so accustomed to more modern syntax, that very few
 | 
					 | 
				
			||||||
people [if any] would recognize the ancient syntax even as valid.
 | 
					 | 
				
			||||||
This inevitably results in non-trivial scripts breaking on ULTRIX,
 | 
					 | 
				
			||||||
and OpenSSL isn't an exclusion. Fortunately there is workaround,
 | 
					 | 
				
			||||||
hire /bin/ksh to do the job /bin/sh fails to do.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
1. Trick make(1) to use /bin/ksh by setting up following environ-
 | 
					 | 
				
			||||||
   ment variables *prior* you execute ./Configure and make:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	PROG_ENV=POSIX
 | 
					 | 
				
			||||||
	MAKESHELL=/bin/ksh
 | 
					 | 
				
			||||||
	export PROG_ENV MAKESHELL
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   or if your shell is csh-compatible:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	setenv PROG_ENV POSIX
 | 
					 | 
				
			||||||
	setenv MAKESHELL /bin/ksh
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
2. Trick /bin/sh to use alternative expression evaluator. Create
 | 
					 | 
				
			||||||
   following 'test' script for example in /tmp:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	#!/bin/ksh
 | 
					 | 
				
			||||||
	${0##*/} "$@"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   Then 'chmod a+x /tmp/test; ln /tmp/test /tmp/[' and *prepend*
 | 
					 | 
				
			||||||
   your $PATH with chosen location, e.g. PATH=/tmp:$PATH. Alter-
 | 
					 | 
				
			||||||
   natively just replace system /bin/test and /bin/[ with the
 | 
					 | 
				
			||||||
   above script.
 | 
					 | 
				
			||||||
							
								
								
									
										67
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										67
									
								
								README
									
									
									
									
									
								
							@@ -1,7 +1,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 OpenSSL 0.9.7n-dev xx XXX xxxx
 | 
					 OpenSSL 0.9.8-dev XX xxx XXXX
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Copyright (c) 1998-2007 The OpenSSL Project
 | 
					 Copyright (c) 1998-2002 The OpenSSL Project
 | 
				
			||||||
 Copyright (c) 1995-1998 Eric A. Young, Tim J. Hudson
 | 
					 Copyright (c) 1995-1998 Eric A. Young, Tim J. Hudson
 | 
				
			||||||
 All rights reserved.
 | 
					 All rights reserved.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -14,13 +14,13 @@
 | 
				
			|||||||
 protocols as well as a full-strength general purpose cryptography library.
 | 
					 protocols as well as a full-strength general purpose cryptography library.
 | 
				
			||||||
 The project is managed by a worldwide community of volunteers that use the
 | 
					 The project is managed by a worldwide community of volunteers that use the
 | 
				
			||||||
 Internet to communicate, plan, and develop the OpenSSL toolkit and its
 | 
					 Internet to communicate, plan, and develop the OpenSSL toolkit and its
 | 
				
			||||||
 related documentation.
 | 
					 related documentation. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 OpenSSL is based on the excellent SSLeay library developed from Eric A. Young
 | 
					 OpenSSL is based on the excellent SSLeay library developed from Eric A. Young
 | 
				
			||||||
 and Tim J. Hudson.  The OpenSSL toolkit is licensed under a dual-license (the
 | 
					 and Tim J. Hudson.  The OpenSSL toolkit is licensed under a dual-license (the
 | 
				
			||||||
 OpenSSL license plus the SSLeay license) situation, which basically means
 | 
					 OpenSSL license plus the SSLeay license) situation, which basically means
 | 
				
			||||||
 that you are free to get and use it for commercial and non-commercial
 | 
					 that you are free to get and use it for commercial and non-commercial
 | 
				
			||||||
 purposes as long as you fulfill the conditions of both licenses.
 | 
					 purposes as long as you fulfill the conditions of both licenses. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 OVERVIEW
 | 
					 OVERVIEW
 | 
				
			||||||
 --------
 | 
					 --------
 | 
				
			||||||
@@ -36,13 +36,12 @@
 | 
				
			|||||||
     actually logically part of it. It includes routines for the following:
 | 
					     actually logically part of it. It includes routines for the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
     Ciphers
 | 
					     Ciphers
 | 
				
			||||||
        libdes - EAY's libdes DES encryption package which was floating
 | 
					        libdes - EAY's libdes DES encryption package which has been floating
 | 
				
			||||||
                 around the net for a few years, and was then relicensed by
 | 
					                 around the net for a few years.  It includes 15
 | 
				
			||||||
                 him as part of SSLeay.  It includes 15 'modes/variations'
 | 
					                 'modes/variations' of DES (1, 2 and 3 key versions of ecb,
 | 
				
			||||||
                 of DES (1, 2 and 3 key versions of ecb, cbc, cfb and ofb;
 | 
					                 cbc, cfb and ofb; pcbc and a more general form of cfb and
 | 
				
			||||||
                 pcbc and a more general form of cfb and ofb) including desx
 | 
					                 ofb) including desx in cbc mode, a fast crypt(3), and
 | 
				
			||||||
                 in cbc mode, a fast crypt(3), and routines to read
 | 
					                 routines to read passwords from the keyboard.
 | 
				
			||||||
                 passwords from the keyboard.
 | 
					 | 
				
			||||||
        RC4 encryption,
 | 
					        RC4 encryption,
 | 
				
			||||||
        RC2 encryption      - 4 different modes, ecb, cbc, cfb and ofb.
 | 
					        RC2 encryption      - 4 different modes, ecb, cbc, cfb and ofb.
 | 
				
			||||||
        Blowfish encryption - 4 different modes, ecb, cbc, cfb and ofb.
 | 
					        Blowfish encryption - 4 different modes, ecb, cbc, cfb and ofb.
 | 
				
			||||||
@@ -54,11 +53,11 @@
 | 
				
			|||||||
        MDC2 message digest. A DES based hash that is popular on smart cards.
 | 
					        MDC2 message digest. A DES based hash that is popular on smart cards.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
     Public Key
 | 
					     Public Key
 | 
				
			||||||
        RSA encryption/decryption/generation.
 | 
					        RSA encryption/decryption/generation.  
 | 
				
			||||||
            There is no limit on the number of bits.
 | 
					            There is no limit on the number of bits.
 | 
				
			||||||
        DSA encryption/decryption/generation.
 | 
					        DSA encryption/decryption/generation.   
 | 
				
			||||||
            There is no limit on the number of bits.
 | 
					            There is no limit on the number of bits.
 | 
				
			||||||
        Diffie-Hellman key-exchange/key generation.
 | 
					        Diffie-Hellman key-exchange/key generation.  
 | 
				
			||||||
            There is no limit on the number of bits.
 | 
					            There is no limit on the number of bits.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
     X.509v3 certificates
 | 
					     X.509v3 certificates
 | 
				
			||||||
@@ -81,16 +80,16 @@
 | 
				
			|||||||
        A simple stack.
 | 
					        A simple stack.
 | 
				
			||||||
        A Configuration loader that uses a format similar to MS .ini files.
 | 
					        A Configuration loader that uses a format similar to MS .ini files.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 openssl:
 | 
					 openssl: 
 | 
				
			||||||
     A command line tool that can be used for:
 | 
					     A command line tool that can be used for:
 | 
				
			||||||
        Creation of RSA, DH and DSA key parameters
 | 
					        Creation of RSA, DH and DSA key parameters
 | 
				
			||||||
        Creation of X.509 certificates, CSRs and CRLs
 | 
					        Creation of X.509 certificates, CSRs and CRLs 
 | 
				
			||||||
        Calculation of Message Digests
 | 
					        Calculation of Message Digests
 | 
				
			||||||
        Encryption and Decryption with Ciphers
 | 
					        Encryption and Decryption with Ciphers
 | 
				
			||||||
        SSL/TLS Client and Server Tests
 | 
					        SSL/TLS Client and Server Tests
 | 
				
			||||||
        Handling of S/MIME signed or encrypted mail
 | 
					        Handling of S/MIME signed or encrypted mail
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 PATENTS
 | 
					 PATENTS
 | 
				
			||||||
 -------
 | 
					 -------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -105,15 +104,13 @@
 | 
				
			|||||||
 licensing conditions. Their web page is http://www.rsasecurity.com/.
 | 
					 licensing conditions. Their web page is http://www.rsasecurity.com/.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 RC4 is a trademark of RSA Security, so use of this label should perhaps
 | 
					 RC4 is a trademark of RSA Security, so use of this label should perhaps
 | 
				
			||||||
 only be used with RSA Security's permission.
 | 
					 only be used with RSA Security's permission. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 The IDEA algorithm is patented by Ascom in Austria, France, Germany, Italy,
 | 
					 The IDEA algorithm is patented by Ascom in Austria, France, Germany, Italy,
 | 
				
			||||||
 Japan, the Netherlands, Spain, Sweden, Switzerland, UK and the USA.  They
 | 
					 Japan, the Netherlands, Spain, Sweden, Switzerland, UK and the USA.  They
 | 
				
			||||||
 should be contacted if that algorithm is to be used; their web page is
 | 
					 should be contacted if that algorithm is to be used; their web page is
 | 
				
			||||||
 http://www.ascom.ch/.
 | 
					 http://www.ascom.ch/.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 The MDC2 algorithm is patented by IBM.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 INSTALLATION
 | 
					 INSTALLATION
 | 
				
			||||||
 ------------
 | 
					 ------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -125,14 +122,7 @@
 | 
				
			|||||||
 lists the functions; you will probably have to look at the code to work out
 | 
					 lists the functions; you will probably have to look at the code to work out
 | 
				
			||||||
 how to use them. Look at the example programs.
 | 
					 how to use them. Look at the example programs.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 PROBLEMS
 | 
					 SUPPORT 
 | 
				
			||||||
 --------
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 For some platforms, there are some known problems that may affect the user
 | 
					 | 
				
			||||||
 or application author.  We try to collect those in doc/PROBLEMS, with current
 | 
					 | 
				
			||||||
 thoughts on how they should be solved in a future of OpenSSL.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 SUPPORT
 | 
					 | 
				
			||||||
 -------
 | 
					 -------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you have any problems with OpenSSL then please take the following steps
 | 
					 If you have any problems with OpenSSL then please take the following steps
 | 
				
			||||||
@@ -141,7 +131,7 @@
 | 
				
			|||||||
    - Download the current snapshot from ftp://ftp.openssl.org/snapshot/
 | 
					    - Download the current snapshot from ftp://ftp.openssl.org/snapshot/
 | 
				
			||||||
      to see if the problem has already been addressed
 | 
					      to see if the problem has already been addressed
 | 
				
			||||||
    - Remove ASM versions of libraries
 | 
					    - Remove ASM versions of libraries
 | 
				
			||||||
    - Remove compiler optimisation flags
 | 
					    - Remove compiler optimisation flags 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 If you wish to report a bug then please include the following information in
 | 
					 If you wish to report a bug then please include the following information in
 | 
				
			||||||
 any bug report:
 | 
					 any bug report:
 | 
				
			||||||
@@ -156,13 +146,11 @@
 | 
				
			|||||||
    - Problem Description (steps that will reproduce the problem, if known)
 | 
					    - Problem Description (steps that will reproduce the problem, if known)
 | 
				
			||||||
    - Stack Traceback (if the application dumps core)
 | 
					    - Stack Traceback (if the application dumps core)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Report the bug to the OpenSSL project via the Request Tracker
 | 
					 Report the bug to the OpenSSL project at:
 | 
				
			||||||
 (http://www.openssl.org/support/rt.html) by mail to:
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    openssl-bugs@openssl.org
 | 
					    openssl-bugs@openssl.org
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Note that mail to openssl-bugs@openssl.org is recorded in the publicly
 | 
					 Note that mail to openssl-bugs@openssl.org is forwarded to a public
 | 
				
			||||||
 readable request tracker database and is forwarded to a public
 | 
					 | 
				
			||||||
 mailing list. Confidential mail may be sent to openssl-security@openssl.org
 | 
					 mailing list. Confidential mail may be sent to openssl-security@openssl.org
 | 
				
			||||||
 (PGP key available from the key servers).
 | 
					 (PGP key available from the key servers).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -176,17 +164,9 @@
 | 
				
			|||||||
 textual explanation of what your patch does.
 | 
					 textual explanation of what your patch does.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Note: For legal reasons, contributions from the US can be accepted only
 | 
					 Note: For legal reasons, contributions from the US can be accepted only
 | 
				
			||||||
 if a TSU notification and a copy of the patch are sent to crypt@bis.doc.gov
 | 
					 if a copy of the patch is sent to crypt@bxa.doc.gov
 | 
				
			||||||
 (formerly BXA) with a copy to the ENC Encryption Request Coordinator;
 | 
					 | 
				
			||||||
 please take some time to look at
 | 
					 | 
				
			||||||
    http://www.bis.doc.gov/Encryption/PubAvailEncSourceCodeNofify.html [sic]
 | 
					 | 
				
			||||||
 and
 | 
					 | 
				
			||||||
    http://w3.access.gpo.gov/bis/ear/pdf/740.pdf (EAR Section 740.13(e))
 | 
					 | 
				
			||||||
 for the details. If "your encryption source code is too large to serve as
 | 
					 | 
				
			||||||
 an email attachment", they are glad to receive it by fax instead; hope you
 | 
					 | 
				
			||||||
 have a cheap long-distance plan.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Our preferred format for changes is "diff -u" output. You might
 | 
					 The preferred format for changes is "diff -u" output. You might
 | 
				
			||||||
 generate it like this:
 | 
					 generate it like this:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 # cd openssl-work
 | 
					 # cd openssl-work
 | 
				
			||||||
@@ -194,4 +174,3 @@
 | 
				
			|||||||
 # ./Configure dist; make clean
 | 
					 # ./Configure dist; make clean
 | 
				
			||||||
 # cd ..
 | 
					 # cd ..
 | 
				
			||||||
 # diff -ur openssl-orig openssl-work > mydiffs.patch
 | 
					 # diff -ur openssl-orig openssl-work > mydiffs.patch
 | 
				
			||||||
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -154,7 +154,7 @@
 | 
				
			|||||||
    shared-library that contains the ENGINE implementation, and "NO_VCHECK"
 | 
					    shared-library that contains the ENGINE implementation, and "NO_VCHECK"
 | 
				
			||||||
    might possibly be useful if there is a minor version conflict and you
 | 
					    might possibly be useful if there is a minor version conflict and you
 | 
				
			||||||
    (or a vendor helpdesk) is convinced you can safely ignore it.
 | 
					    (or a vendor helpdesk) is convinced you can safely ignore it.
 | 
				
			||||||
    "ID" is probably only needed if a shared-library implements
 | 
					    "ENGINE_ID" is probably only needed if a shared-library implements
 | 
				
			||||||
    multiple ENGINEs, but if you know the engine id you expect to be using,
 | 
					    multiple ENGINEs, but if you know the engine id you expect to be using,
 | 
				
			||||||
    it doesn't hurt to specify it (and this provides a sanity check if
 | 
					    it doesn't hurt to specify it (and this provides a sanity check if
 | 
				
			||||||
    nothing else). "LIST_ADD" is only required if you actually wish the
 | 
					    nothing else). "LIST_ADD" is only required if you actually wish the
 | 
				
			||||||
@@ -174,7 +174,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
       ENGINE *e = ENGINE_by_id("dynamic");
 | 
					       ENGINE *e = ENGINE_by_id("dynamic");
 | 
				
			||||||
       ENGINE_ctrl_cmd_string(e, "SO_PATH", "/lib/libfoo.so", 0);
 | 
					       ENGINE_ctrl_cmd_string(e, "SO_PATH", "/lib/libfoo.so", 0);
 | 
				
			||||||
       ENGINE_ctrl_cmd_string(e, "ID", "foo", 0);
 | 
					       ENGINE_ctrl_cmd_string(e, "ENGINE_ID", "foo", 0);
 | 
				
			||||||
       ENGINE_ctrl_cmd_string(e, "LOAD", NULL, 0);
 | 
					       ENGINE_ctrl_cmd_string(e, "LOAD", NULL, 0);
 | 
				
			||||||
       ENGINE_ctrl_cmd_string(e, "CMD_FOO", "some input data", 0);
 | 
					       ENGINE_ctrl_cmd_string(e, "CMD_FOO", "some input data", 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -184,7 +184,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
       openssl engine dynamic \
 | 
					       openssl engine dynamic \
 | 
				
			||||||
                 -pre SO_PATH:/lib/libfoo.so \
 | 
					                 -pre SO_PATH:/lib/libfoo.so \
 | 
				
			||||||
                 -pre ID:foo \
 | 
					                 -pre ENGINE_ID:foo \
 | 
				
			||||||
                 -pre LOAD \
 | 
					                 -pre LOAD \
 | 
				
			||||||
                 -pre "CMD_FOO:some input data"
 | 
					                 -pre "CMD_FOO:some input data"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -192,7 +192,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
       openssl engine -vvvv dynamic \
 | 
					       openssl engine -vvvv dynamic \
 | 
				
			||||||
                 -pre SO_PATH:/lib/libfoo.so \
 | 
					                 -pre SO_PATH:/lib/libfoo.so \
 | 
				
			||||||
                 -pre ID:foo \
 | 
					                 -pre ENGINE_ID:foo \
 | 
				
			||||||
                 -pre LOAD
 | 
					                 -pre LOAD
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    Applications that support the ENGINE API and more specifically, the
 | 
					    Applications that support the ENGINE API and more specifically, the
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										44
									
								
								STATUS
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								STATUS
									
									
									
									
									
								
							@@ -1,39 +1,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  OpenSSL STATUS                           Last modified at
 | 
					  OpenSSL STATUS                           Last modified at
 | 
				
			||||||
  ______________                           $Date: 2008/04/07 06:34:10 $
 | 
					  ______________                           $Date: 2002/05/16 10:01:53 $
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  DEVELOPMENT STATE
 | 
					  DEVELOPMENT STATE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    o  OpenSSL 0.9.9:  Under development...
 | 
					    o  OpenSSL 0.9.7:  Under development...
 | 
				
			||||||
    o  OpenSSL 0.9.8e: Released on February  23rd, 2007
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8d: Released on September 28th, 2006
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8c: Released on September  5th, 2006
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8b: Released on May        4th, 2006
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8a: Released on October   11th, 2005
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.8:  Released on July       5th, 2005
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7m: Released on February  23rd, 2007
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7l: Released on September 28th, 2006
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7k: Released on September  5th, 2006
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7j: Released on May        4th, 2006
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7i: Released on October   14th, 2005
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7h: Released on October   11th, 2005
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7g: Released on April     11th, 2005
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7f: Released on March     22nd, 2005
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7e: Released on October   25th, 2004
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7d: Released on March     17th, 2004
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7c: Released on September 30th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7b: Released on April     10th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7a: Released on February  19th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.7:  Released on December  31st, 2002
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6m: Released on March     17th, 2004
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6l: Released on November   4th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6k: Released on September 30th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6j: Released on April     10th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6i: Released on February  19th, 2003
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6h: Released on December   5th, 2002
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6g: Released on August     9th, 2002
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6f: Released on August     8th, 2002
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6e: Released on July      30th, 2002
 | 
					 | 
				
			||||||
    o  OpenSSL 0.9.6d: Released on May        9th, 2002
 | 
					    o  OpenSSL 0.9.6d: Released on May        9th, 2002
 | 
				
			||||||
    o  OpenSSL 0.9.6c: Released on December  21st, 2001
 | 
					    o  OpenSSL 0.9.6c: Released on December  21st, 2001
 | 
				
			||||||
    o  OpenSSL 0.9.6b: Released on July       9th, 2001
 | 
					    o  OpenSSL 0.9.6b: Released on July       9th, 2001
 | 
				
			||||||
@@ -47,11 +18,12 @@
 | 
				
			|||||||
    o  OpenSSL 0.9.2b: Released on March     22th, 1999
 | 
					    o  OpenSSL 0.9.2b: Released on March     22th, 1999
 | 
				
			||||||
    o  OpenSSL 0.9.1c: Released on December  23th, 1998
 | 
					    o  OpenSSL 0.9.1c: Released on December  23th, 1998
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  [See also http://www.openssl.org/support/rt.html]
 | 
					  [See also http://www.openssl.org/support/rt2.html]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  RELEASE SHOWSTOPPERS
 | 
					  RELEASE SHOWSTOPPERS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    o 
 | 
					    o BN_mod_mul verification fails for mips3-sgi-irix
 | 
				
			||||||
 | 
					      unless configured with no-asm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  AVAILABLE PATCHES
 | 
					  AVAILABLE PATCHES
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -74,8 +46,9 @@
 | 
				
			|||||||
	UTIL (a new set of library functions to support some higher level
 | 
						UTIL (a new set of library functions to support some higher level
 | 
				
			||||||
	      functionality that is currently missing).
 | 
						      functionality that is currently missing).
 | 
				
			||||||
	Shared library support for VMS.
 | 
						Shared library support for VMS.
 | 
				
			||||||
	Kerberos 5 authentication (Heimdal)
 | 
						Kerberos 5 authentication
 | 
				
			||||||
	Constification
 | 
						Constification
 | 
				
			||||||
 | 
						OCSP
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  NEEDS PATCH
 | 
					  NEEDS PATCH
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -85,6 +58,9 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  OPEN ISSUES
 | 
					  OPEN ISSUES
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    o  Do we want the EVP API changes in 0.9.7?
 | 
				
			||||||
 | 
					       Can compatibility be improved?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    o  The Makefile hierarchy and build mechanism is still not a round thing:
 | 
					    o  The Makefile hierarchy and build mechanism is still not a round thing:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
       1. The config vs. Configure scripts
 | 
					       1. The config vs. Configure scripts
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,34 +0,0 @@
 | 
				
			|||||||
#! /usr/bin/perl
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
use strict;
 | 
					 | 
				
			||||||
use warnings;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
my @directory_vars = ( "dir", "certs", "crl_dir", "new_certs_dir" );
 | 
					 | 
				
			||||||
my @file_vars = ( "database", "certificate", "serial", "crlnumber",
 | 
					 | 
				
			||||||
		  "crl", "private_key", "RANDFILE" );
 | 
					 | 
				
			||||||
while(<STDIN>) {
 | 
					 | 
				
			||||||
    chomp;
 | 
					 | 
				
			||||||
    foreach my $d (@directory_vars) {
 | 
					 | 
				
			||||||
	if (/^(\s*\#?\s*${d}\s*=\s*)\.\/([^\s\#]*)([\s\#].*)$/) {
 | 
					 | 
				
			||||||
	    $_ = "$1sys\\\$disk:\[.$2$3";
 | 
					 | 
				
			||||||
	} elsif (/^(\s*\#?\s*${d}\s*=\s*)(\w[^\s\#]*)([\s\#].*)$/) {
 | 
					 | 
				
			||||||
	    $_ = "$1sys\\\$disk:\[.$2$3";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	s/^(\s*\#?\s*${d}\s*=\s*\$\w+)\/([^\s\#]*)([\s\#].*)$/$1.$2\]$3/;
 | 
					 | 
				
			||||||
	while(/^(\s*\#?\s*${d}\s*=\s*(\$\w+\.|sys\\\$disk:\[\.)[\w\.]+)\/([^\]]*)\](.*)$/) {
 | 
					 | 
				
			||||||
	    $_ = "$1.$3]$4";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    foreach my $f (@file_vars) {
 | 
					 | 
				
			||||||
	s/^(\s*\#?\s*${f}\s*=\s*)\.\/(.*)$/$1sys\\\$disk:\[\/$2/;
 | 
					 | 
				
			||||||
	while(/^(\s*\#?\s*${f}\s*=\s*(\$\w+|sys\\\$disk:\[)[^\/]*)\/(\w+\/[^\s\#]*)([\s\#].*)$/) {
 | 
					 | 
				
			||||||
	    $_ = "$1.$3$4";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	if (/^(\s*\#?\s*${f}\s*=\s*(\$\w+|sys\\\$disk:\[)[^\/]*)\/(\w+)([\s\#].*)$/) {
 | 
					 | 
				
			||||||
	    $_ = "$1]$3.$4";
 | 
					 | 
				
			||||||
	} elsif  (/^(\s*\#?\s*${f}\s*=\s*(\$\w+|sys\\\$disk:\[)[^\/]*)\/([^\s\#]*)([\s\#].*)$/) {
 | 
					 | 
				
			||||||
	    $_ = "$1]$3$4";
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
   }
 | 
					 | 
				
			||||||
    print $_,"\n";
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -266,14 +266,6 @@ $             falsesum = falsesum + 1
 | 
				
			|||||||
$         endif
 | 
					$         endif
 | 
				
			||||||
$         if plat_entry .eqs. "VMS" then truesum = truesum + 1
 | 
					$         if plat_entry .eqs. "VMS" then truesum = truesum + 1
 | 
				
			||||||
$         if plat_entry .eqs. "!VMS" then falsesum = falsesum + 1
 | 
					$         if plat_entry .eqs. "!VMS" then falsesum = falsesum + 1
 | 
				
			||||||
$         if f$trnlnm("OPENSSL_FIPS") .nes. ""
 | 
					 | 
				
			||||||
$         then
 | 
					 | 
				
			||||||
$           if plat_entry .eqs. "OPENSSL_FIPS" then truesum = truesum + 1
 | 
					 | 
				
			||||||
$           if plat_entry .eqs. "!OPENSSL_FIPS" then falsesum = falsesum + 1
 | 
					 | 
				
			||||||
$         else
 | 
					 | 
				
			||||||
$           if plat_entry .eqs. "OPENSSL_FIPS" then falsesum = falsesum + 1
 | 
					 | 
				
			||||||
$           if plat_entry .eqs. "!OPENSSL_FIPS" then truesum = truesum + 1
 | 
					 | 
				
			||||||
$         endif
 | 
					 | 
				
			||||||
$	  goto loop1
 | 
					$	  goto loop1
 | 
				
			||||||
$       endif
 | 
					$       endif
 | 
				
			||||||
$     endloop1:
 | 
					$     endloop1:
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1 +0,0 @@
 | 
				
			|||||||
sys$share:tcpip$ipc_shr.exe/share
 | 
					 | 
				
			||||||
@@ -3,6 +3,3 @@ Makefile.save
 | 
				
			|||||||
der_chop
 | 
					der_chop
 | 
				
			||||||
der_chop.bak
 | 
					der_chop.bak
 | 
				
			||||||
CA.pl
 | 
					CA.pl
 | 
				
			||||||
openssl.sha1
 | 
					 | 
				
			||||||
*.flc
 | 
					 | 
				
			||||||
semantic.cache
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -36,21 +36,13 @@
 | 
				
			|||||||
# default openssl.cnf file has setup as per the following
 | 
					# default openssl.cnf file has setup as per the following
 | 
				
			||||||
# demoCA ... where everything is stored
 | 
					# demoCA ... where everything is stored
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my $openssl;
 | 
					 | 
				
			||||||
if(defined $ENV{OPENSSL}) {
 | 
					 | 
				
			||||||
	$openssl = $ENV{OPENSSL};
 | 
					 | 
				
			||||||
} else {
 | 
					 | 
				
			||||||
	$openssl = "openssl";
 | 
					 | 
				
			||||||
	$ENV{OPENSSL} = $openssl;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
$SSLEAY_CONFIG=$ENV{"SSLEAY_CONFIG"};
 | 
					$SSLEAY_CONFIG=$ENV{"SSLEAY_CONFIG"};
 | 
				
			||||||
$DAYS="-days 365";
 | 
					$DAYS="-days 365";
 | 
				
			||||||
$REQ="$openssl req $SSLEAY_CONFIG";
 | 
					$REQ="openssl req $SSLEAY_CONFIG";
 | 
				
			||||||
$CA="$openssl ca $SSLEAY_CONFIG";
 | 
					$CA="openssl ca $SSLEAY_CONFIG";
 | 
				
			||||||
$VERIFY="$openssl verify";
 | 
					$VERIFY="openssl verify";
 | 
				
			||||||
$X509="$openssl x509";
 | 
					$X509="openssl x509";
 | 
				
			||||||
$PKCS12="$openssl pkcs12";
 | 
					$PKCS12="openssl pkcs12";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$CATOP="./demoCA";
 | 
					$CATOP="./demoCA";
 | 
				
			||||||
$CAKEY="cakey.pem";
 | 
					$CAKEY="cakey.pem";
 | 
				
			||||||
@@ -66,19 +58,19 @@ foreach (@ARGV) {
 | 
				
			|||||||
	    exit 0;
 | 
						    exit 0;
 | 
				
			||||||
	} elsif (/^-newcert$/) {
 | 
						} elsif (/^-newcert$/) {
 | 
				
			||||||
	    # create a certificate
 | 
						    # create a certificate
 | 
				
			||||||
	    system ("$REQ -new -x509 -keyout newkey.pem -out newcert.pem $DAYS");
 | 
						    system ("$REQ -new -x509 -keyout newreq.pem -out newreq.pem $DAYS");
 | 
				
			||||||
	    $RET=$?;
 | 
						    $RET=$?;
 | 
				
			||||||
	    print "Certificate is in newcert.pem, private key is in newkey.pem\n"
 | 
						    print "Certificate (and private key) is in newreq.pem\n"
 | 
				
			||||||
	} elsif (/^-newreq$/) {
 | 
						} elsif (/^-newreq$/) {
 | 
				
			||||||
	    # create a certificate request
 | 
						    # create a certificate request
 | 
				
			||||||
	    system ("$REQ -new -keyout newkey.pem -out newreq.pem $DAYS");
 | 
						    system ("$REQ -new -keyout newreq.pem -out newreq.pem $DAYS");
 | 
				
			||||||
	    $RET=$?;
 | 
						    $RET=$?;
 | 
				
			||||||
	    print "Request is in newreq.pem, private key is in newkey.pem\n";
 | 
						    print "Request (and private key) is in newreq.pem\n";
 | 
				
			||||||
	} elsif (/^-newreq-nodes$/) {
 | 
						} elsif (/^-newreq-nodes$/) {
 | 
				
			||||||
	    # create a certificate request
 | 
						    # create a certificate request
 | 
				
			||||||
	    system ("$REQ -new -nodes -keyout newkey.pem -out newreq.pem $DAYS");
 | 
						    system ("$REQ -new -nodes -keyout newreq.pem -out newreq.pem $DAYS");
 | 
				
			||||||
	    $RET=$?;
 | 
						    $RET=$?;
 | 
				
			||||||
	    print "Request is in newreq.pem, private key is in newkey.pem\n";
 | 
						    print "Request (and private key) is in newreq.pem\n";
 | 
				
			||||||
	} elsif (/^-newca$/) {
 | 
						} elsif (/^-newca$/) {
 | 
				
			||||||
		# if explicitly asked for or it doesn't exist then setup the
 | 
							# if explicitly asked for or it doesn't exist then setup the
 | 
				
			||||||
		# directory structure that Eric likes to manage things 
 | 
							# directory structure that Eric likes to manage things 
 | 
				
			||||||
@@ -90,6 +82,9 @@ foreach (@ARGV) {
 | 
				
			|||||||
		mkdir "${CATOP}/crl", $DIRMODE ;
 | 
							mkdir "${CATOP}/crl", $DIRMODE ;
 | 
				
			||||||
		mkdir "${CATOP}/newcerts", $DIRMODE;
 | 
							mkdir "${CATOP}/newcerts", $DIRMODE;
 | 
				
			||||||
		mkdir "${CATOP}/private", $DIRMODE;
 | 
							mkdir "${CATOP}/private", $DIRMODE;
 | 
				
			||||||
 | 
							open OUT, ">${CATOP}/serial";
 | 
				
			||||||
 | 
							print OUT "01\n";
 | 
				
			||||||
 | 
							close OUT;
 | 
				
			||||||
		open OUT, ">${CATOP}/index.txt";
 | 
							open OUT, ">${CATOP}/index.txt";
 | 
				
			||||||
		close OUT;
 | 
							close OUT;
 | 
				
			||||||
	    }
 | 
						    }
 | 
				
			||||||
@@ -111,18 +106,13 @@ foreach (@ARGV) {
 | 
				
			|||||||
		    $RET=$?;
 | 
							    $RET=$?;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	    }
 | 
						    }
 | 
				
			||||||
	    if (! -f "${CATOP}/serial" ) {
 | 
					 | 
				
			||||||
		system ("$X509 -in ${CATOP}/$CACERT -noout "
 | 
					 | 
				
			||||||
			. "-next_serial -out ${CATOP}/serial");
 | 
					 | 
				
			||||||
	    }
 | 
					 | 
				
			||||||
	} elsif (/^-pkcs12$/) {
 | 
						} elsif (/^-pkcs12$/) {
 | 
				
			||||||
	    my $cname = $ARGV[1];
 | 
						    my $cname = $ARGV[1];
 | 
				
			||||||
	    $cname = "My Certificate" unless defined $cname;
 | 
						    $cname = "My Certificate" unless defined $cname;
 | 
				
			||||||
	    system ("$PKCS12 -in newcert.pem -inkey newkey.pem " .
 | 
						    system ("$PKCS12 -in newcert.pem -inkey newreq.pem " .
 | 
				
			||||||
			"-certfile ${CATOP}/$CACERT -out newcert.p12 " .
 | 
								"-certfile ${CATOP}/$CACERT -out newcert.p12 " .
 | 
				
			||||||
			"-export -name \"$cname\"");
 | 
								"-export -name \"$cname\"");
 | 
				
			||||||
	    $RET=$?;
 | 
						    $RET=$?;
 | 
				
			||||||
	    print "PKCS #12 file is in newcert.p12\n";
 | 
					 | 
				
			||||||
	    exit $RET;
 | 
						    exit $RET;
 | 
				
			||||||
	} elsif (/^-xsign$/) {
 | 
						} elsif (/^-xsign$/) {
 | 
				
			||||||
	    system ("$CA -policy policy_anything -infiles newreq.pem");
 | 
						    system ("$CA -policy policy_anything -infiles newreq.pem");
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										18
									
								
								apps/CA.sh
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								apps/CA.sh
									
									
									
									
									
								
							@@ -30,13 +30,11 @@
 | 
				
			|||||||
# default openssl.cnf file has setup as per the following
 | 
					# default openssl.cnf file has setup as per the following
 | 
				
			||||||
# demoCA ... where everything is stored
 | 
					# demoCA ... where everything is stored
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -z "$OPENSSL" ]; then OPENSSL=openssl; fi
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
DAYS="-days 365"
 | 
					DAYS="-days 365"
 | 
				
			||||||
REQ="$OPENSSL req $SSLEAY_CONFIG"
 | 
					REQ="openssl req $SSLEAY_CONFIG"
 | 
				
			||||||
CA="$OPENSSL ca $SSLEAY_CONFIG"
 | 
					CA="openssl ca $SSLEAY_CONFIG"
 | 
				
			||||||
VERIFY="$OPENSSL verify"
 | 
					VERIFY="openssl verify"
 | 
				
			||||||
X509="$OPENSSL x509"
 | 
					X509="openssl x509"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CATOP=./demoCA
 | 
					CATOP=./demoCA
 | 
				
			||||||
CAKEY=./cakey.pem
 | 
					CAKEY=./cakey.pem
 | 
				
			||||||
@@ -51,15 +49,15 @@ case $i in
 | 
				
			|||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-newcert) 
 | 
					-newcert) 
 | 
				
			||||||
    # create a certificate
 | 
					    # create a certificate
 | 
				
			||||||
    $REQ -new -x509 -keyout newkey.pem -out newcert.pem $DAYS
 | 
					    $REQ -new -x509 -keyout newreq.pem -out newreq.pem $DAYS
 | 
				
			||||||
    RET=$?
 | 
					    RET=$?
 | 
				
			||||||
    echo "Certificate is in newcert.pem, private key is in newkey.pem"
 | 
					    echo "Certificate (and private key) is in newreq.pem"
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-newreq) 
 | 
					-newreq) 
 | 
				
			||||||
    # create a certificate request
 | 
					    # create a certificate request
 | 
				
			||||||
    $REQ -new -keyout newkey.pem -out newreq.pem $DAYS
 | 
					    $REQ -new -keyout newreq.pem -out newreq.pem $DAYS
 | 
				
			||||||
    RET=$?
 | 
					    RET=$?
 | 
				
			||||||
    echo "Request is in newreq.pem, private key is in newkey.pem"
 | 
					    echo "Request (and private key) is in newreq.pem"
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
-newca)     
 | 
					-newca)     
 | 
				
			||||||
    # if explicitly asked for or it doesn't exist then setup the directory
 | 
					    # if explicitly asked for or it doesn't exist then setup the directory
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										1171
									
								
								apps/Makefile
									
									
									
									
									
								
							
							
						
						
									
										1171
									
								
								apps/Makefile
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										945
									
								
								apps/Makefile.ssl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										945
									
								
								apps/Makefile.ssl
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,945 @@
 | 
				
			|||||||
 | 
					#
 | 
				
			||||||
 | 
					#  apps/Makefile.ssl
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DIR=		apps
 | 
				
			||||||
 | 
					TOP=		..
 | 
				
			||||||
 | 
					CC=		cc
 | 
				
			||||||
 | 
					INCLUDES=	-I$(TOP) -I../include $(KRB5_INCLUDES)
 | 
				
			||||||
 | 
					CFLAG=		-g -static
 | 
				
			||||||
 | 
					INSTALL_PREFIX=
 | 
				
			||||||
 | 
					INSTALLTOP=	/usr/local/ssl
 | 
				
			||||||
 | 
					OPENSSLDIR=	/usr/local/ssl
 | 
				
			||||||
 | 
					MAKE=		make -f Makefile.ssl
 | 
				
			||||||
 | 
					MAKEDEPPROG=	makedepend
 | 
				
			||||||
 | 
					MAKEDEPEND=	$(TOP)/util/domd $(TOP) -MD $(MAKEDEPPROG)
 | 
				
			||||||
 | 
					MAKEFILE=	Makefile.ssl
 | 
				
			||||||
 | 
					PERL= perl
 | 
				
			||||||
 | 
					RM=		rm -f
 | 
				
			||||||
 | 
					# KRB5 stuff
 | 
				
			||||||
 | 
					KRB5_INCLUDES=
 | 
				
			||||||
 | 
					LIBKRB5=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PEX_LIBS=
 | 
				
			||||||
 | 
					EX_LIBS= 
 | 
				
			||||||
 | 
					EXE_EXT= 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SHLIB_TARGET=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					CFLAGS= -DMONOLITH $(INCLUDES) $(CFLAG)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					GENERAL=Makefile makeapps.com install.com
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DLIBCRYPTO=../libcrypto.a
 | 
				
			||||||
 | 
					DLIBSSL=../libssl.a
 | 
				
			||||||
 | 
					LIBCRYPTO=-L.. -lcrypto
 | 
				
			||||||
 | 
					LIBSSL=-L.. -lssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PROGRAM= openssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SCRIPTS=CA.sh CA.pl der_chop
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					EXE= $(PROGRAM)$(EXE_EXT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					E_EXE=	verify asn1pars req dgst dh dhparam enc passwd gendh errstr \
 | 
				
			||||||
 | 
						ca crl rsa rsautl dsa dsaparam ecdsa ecdsaparam\
 | 
				
			||||||
 | 
						x509 genrsa gendsa s_server s_client speed \
 | 
				
			||||||
 | 
						s_time version pkcs7 crl2pkcs7 sess_id ciphers nseq pkcs12 \
 | 
				
			||||||
 | 
						pkcs8 spkac smime rand engine ocsp
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PROGS= $(PROGRAM).c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					A_OBJ=apps.o
 | 
				
			||||||
 | 
					A_SRC=apps.c
 | 
				
			||||||
 | 
					S_OBJ=	s_cb.o s_socket.o
 | 
				
			||||||
 | 
					S_SRC=	s_cb.c s_socket.c
 | 
				
			||||||
 | 
					RAND_OBJ=app_rand.o
 | 
				
			||||||
 | 
					RAND_SRC=app_rand.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					E_OBJ=	verify.o asn1pars.o req.o dgst.o dh.o dhparam.o enc.o passwd.o gendh.o errstr.o \
 | 
				
			||||||
 | 
						ca.o pkcs7.o crl2p7.o crl.o \
 | 
				
			||||||
 | 
						rsa.o rsautl.o dsa.o dsaparam.o ecdsa.o ecdsaparam.o\
 | 
				
			||||||
 | 
						x509.o genrsa.o gendsa.o s_server.o s_client.o speed.o \
 | 
				
			||||||
 | 
						s_time.o $(A_OBJ) $(S_OBJ) $(RAND_OBJ) version.o sess_id.o \
 | 
				
			||||||
 | 
						ciphers.o nseq.o pkcs12.o pkcs8.o spkac.o smime.o rand.o engine.o ocsp.o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					E_SRC=	verify.c asn1pars.c req.c dgst.c dh.c enc.c passwd.c gendh.c errstr.c ca.c \
 | 
				
			||||||
 | 
						pkcs7.c crl2p7.c crl.c \
 | 
				
			||||||
 | 
						rsa.c rsautl.c dsa.c dsaparam.c ecdsa.c ecdsaparam.c\
 | 
				
			||||||
 | 
						x509.c genrsa.c gendsa.c s_server.c s_client.c speed.c \
 | 
				
			||||||
 | 
						s_time.c $(A_SRC) $(S_SRC) $(RAND_SRC) version.c sess_id.c \
 | 
				
			||||||
 | 
						ciphers.c nseq.c pkcs12.c pkcs8.c spkac.c smime.c rand.c engine.c ocsp.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRC=$(E_SRC)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					EXHEADER=
 | 
				
			||||||
 | 
					HEADER=	apps.h progs.h s_apps.h \
 | 
				
			||||||
 | 
						testdsa.h testrsa.h \
 | 
				
			||||||
 | 
						$(EXHEADER)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ALL=    $(GENERAL) $(SRC) $(HEADER)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					top:
 | 
				
			||||||
 | 
						@(cd ..; $(MAKE) DIRS=$(DIR) all)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					all:	exe
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					exe:	$(PROGRAM)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					req: sreq.o $(A_OBJ) $(DLIBCRYPTO)
 | 
				
			||||||
 | 
						$(CC) -o req $(CFLAG) sreq.o $(A_OBJ) $(RAND_OBJ) $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sreq.o: req.c 
 | 
				
			||||||
 | 
						$(CC) -c $(INCLUDES) $(CFLAG) -o sreq.o req.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					files:
 | 
				
			||||||
 | 
						$(PERL) $(TOP)/util/files.pl Makefile.ssl >> $(TOP)/MINFO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					install:
 | 
				
			||||||
 | 
						@for i in $(EXE); \
 | 
				
			||||||
 | 
						do  \
 | 
				
			||||||
 | 
						(echo installing $$i; \
 | 
				
			||||||
 | 
						 cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i; \
 | 
				
			||||||
 | 
						 chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i ); \
 | 
				
			||||||
 | 
						 done;
 | 
				
			||||||
 | 
						@for i in $(SCRIPTS); \
 | 
				
			||||||
 | 
						do  \
 | 
				
			||||||
 | 
						(echo installing $$i; \
 | 
				
			||||||
 | 
						 cp $$i $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$i; \
 | 
				
			||||||
 | 
						 chmod 755 $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$i ); \
 | 
				
			||||||
 | 
						 done
 | 
				
			||||||
 | 
						@cp openssl.cnf $(INSTALL_PREFIX)$(OPENSSLDIR); \
 | 
				
			||||||
 | 
						chmod 644 $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					tags:
 | 
				
			||||||
 | 
						ctags $(SRC)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					tests:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					links:
 | 
				
			||||||
 | 
						@$(TOP)/util/point.sh Makefile.ssl Makefile
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					lint:
 | 
				
			||||||
 | 
						lint -DLINT $(INCLUDES) $(SRC)>fluff
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					depend:
 | 
				
			||||||
 | 
						$(MAKEDEPEND) $(INCLUDES) $(DEPFLAG) $(PROGS) $(SRC)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					dclean:
 | 
				
			||||||
 | 
						$(PERL) -pe 'if (/^# DO NOT DELETE THIS LINE/) {print; exit(0);}' $(MAKEFILE) >Makefile.new
 | 
				
			||||||
 | 
						mv -f Makefile.new $(MAKEFILE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					clean:
 | 
				
			||||||
 | 
						rm -f *.o *.obj lib tags core .pure .nfs* *.old *.bak fluff $(EXE)
 | 
				
			||||||
 | 
						rm -f req
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(DLIBSSL):
 | 
				
			||||||
 | 
						(cd ../ssl; $(MAKE))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(DLIBCRYPTO):
 | 
				
			||||||
 | 
						(cd ../crypto; $(MAKE))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(PROGRAM): progs.h $(E_OBJ) $(PROGRAM).o $(DLIBCRYPTO) $(DLIBSSL)
 | 
				
			||||||
 | 
						$(RM) $(PROGRAM)
 | 
				
			||||||
 | 
						if [ "$(SHLIB_TARGET)" = "hpux-shared" ] ; then \
 | 
				
			||||||
 | 
						  $(CC) -o $(PROGRAM) $(CFLAGS) $(PROGRAM).o $(E_OBJ) $(PEX_LIBS) $(DLIBSSL) $(LIBKRB5) $(DLIBCRYPTO) $(EX_LIBS) ; \
 | 
				
			||||||
 | 
						else \
 | 
				
			||||||
 | 
						  $(CC) -o $(PROGRAM) $(CFLAGS) $(PROGRAM).o $(E_OBJ) $(PEX_LIBS) $(LIBSSL) $(LIBKRB5) $(LIBCRYPTO) $(EX_LIBS) ; \
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
						-(cd ..; OPENSSL="`pwd`/apps/openssl"; export OPENSSL; \
 | 
				
			||||||
 | 
							LIBPATH="`pwd`"; LD_LIBRARY_PATH="`pwd`"; SHLIB_PATH="`pwd`"; \
 | 
				
			||||||
 | 
							export LD_LIBRARY_PATH SHLIB_PATH LIBPATH; \
 | 
				
			||||||
 | 
							$(PERL) tools/c_rehash certs)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					progs.h: progs.pl
 | 
				
			||||||
 | 
						$(PERL) progs.pl $(E_EXE) >progs.h
 | 
				
			||||||
 | 
						$(RM) $(PROGRAM).o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# DO NOT DELETE THIS LINE -- make depend depends on it.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					app_rand.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/ossl_typ.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					app_rand.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h app_rand.c
 | 
				
			||||||
 | 
					app_rand.o: apps.h
 | 
				
			||||||
 | 
					apps.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/pem2.h ../include/openssl/pkcs12.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					apps.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.c apps.h
 | 
				
			||||||
 | 
					asn1pars.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					asn1pars.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					asn1pars.o: asn1pars.c
 | 
				
			||||||
 | 
					ca.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/ocsp.h ../include/openssl/opensslconf.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/pem.h ../include/openssl/pem2.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					ca.o: ../include/openssl/x509_vfy.h ../include/openssl/x509v3.h apps.h ca.c
 | 
				
			||||||
 | 
					ciphers.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					ciphers.o: ../include/openssl/x509_vfy.h apps.h ciphers.c
 | 
				
			||||||
 | 
					crl.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
				
			||||||
 | 
					crl.o: ../include/openssl/x509v3.h apps.h crl.c
 | 
				
			||||||
 | 
					crl2p7.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					crl2p7.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					crl2p7.o: crl2p7.c
 | 
				
			||||||
 | 
					dgst.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					dgst.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h dgst.c
 | 
				
			||||||
 | 
					dh.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					dh.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h dh.c
 | 
				
			||||||
 | 
					dsa.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					dsa.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h dsa.c
 | 
				
			||||||
 | 
					dsaparam.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					dsaparam.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					dsaparam.o: dsaparam.c
 | 
				
			||||||
 | 
					ecdsa.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					ecdsa.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h ecdsa.c
 | 
				
			||||||
 | 
					ecdsaparam.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					ecdsaparam.o: ecdsaparam.c
 | 
				
			||||||
 | 
					enc.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					enc.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h enc.c
 | 
				
			||||||
 | 
					engine.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					engine.o: ../include/openssl/x509_vfy.h apps.h engine.c
 | 
				
			||||||
 | 
					errstr.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					errstr.o: ../include/openssl/x509_vfy.h apps.h errstr.c
 | 
				
			||||||
 | 
					gendh.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					gendh.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h gendh.c
 | 
				
			||||||
 | 
					gendsa.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					gendsa.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					gendsa.o: gendsa.c
 | 
				
			||||||
 | 
					genrsa.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					genrsa.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					genrsa.o: genrsa.c
 | 
				
			||||||
 | 
					nseq.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					nseq.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h nseq.c
 | 
				
			||||||
 | 
					ocsp.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/ocsp.h ../include/openssl/opensslconf.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/pem.h ../include/openssl/pem2.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/sha.h ../include/openssl/ssl.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/ssl2.h ../include/openssl/ssl23.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/ssl3.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/symhacks.h ../include/openssl/tls1.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
				
			||||||
 | 
					ocsp.o: ../include/openssl/x509v3.h apps.h ocsp.c
 | 
				
			||||||
 | 
					openssl.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					openssl.o: ../include/openssl/x509_vfy.h apps.h openssl.c progs.h s_apps.h
 | 
				
			||||||
 | 
					passwd.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/crypto.h ../include/openssl/des.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/des_old.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/md5.h ../include/openssl/obj_mac.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/objects.h ../include/openssl/opensslconf.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/ui.h ../include/openssl/ui_compat.h
 | 
				
			||||||
 | 
					passwd.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					passwd.o: passwd.c
 | 
				
			||||||
 | 
					pkcs12.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/pem2.h ../include/openssl/pkcs12.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					pkcs12.o: ../include/openssl/x509_vfy.h apps.h pkcs12.c
 | 
				
			||||||
 | 
					pkcs7.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					pkcs7.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h pkcs7.c
 | 
				
			||||||
 | 
					pkcs8.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/pem2.h ../include/openssl/pkcs12.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					pkcs8.o: ../include/openssl/x509_vfy.h apps.h pkcs8.c
 | 
				
			||||||
 | 
					rand.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/ossl_typ.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					rand.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h rand.c
 | 
				
			||||||
 | 
					req.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
				
			||||||
 | 
					req.o: ../include/openssl/x509v3.h apps.h req.c
 | 
				
			||||||
 | 
					rsa.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					rsa.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h rsa.c
 | 
				
			||||||
 | 
					rsautl.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					rsautl.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h
 | 
				
			||||||
 | 
					rsautl.o: rsautl.c
 | 
				
			||||||
 | 
					s_cb.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					s_cb.o: ../include/openssl/x509_vfy.h apps.h s_apps.h s_cb.c
 | 
				
			||||||
 | 
					s_client.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					s_client.o: ../include/openssl/x509_vfy.h apps.h s_apps.h s_client.c
 | 
				
			||||||
 | 
					s_server.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					s_server.o: ../include/openssl/x509_vfy.h apps.h s_apps.h s_server.c
 | 
				
			||||||
 | 
					s_socket.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					s_socket.o: ../include/openssl/x509_vfy.h apps.h s_apps.h s_socket.c
 | 
				
			||||||
 | 
					s_time.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					s_time.o: ../include/openssl/x509_vfy.h apps.h s_apps.h s_time.c
 | 
				
			||||||
 | 
					sess_id.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/buffer.h ../include/openssl/comp.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/kssl.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/tls1.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/ui.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					sess_id.o: ../include/openssl/x509_vfy.h apps.h sess_id.c
 | 
				
			||||||
 | 
					smime.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					smime.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h smime.c
 | 
				
			||||||
 | 
					speed.o: ../e_os.h ../include/openssl/aes.h ../include/openssl/asn1.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/asn1t.h ../include/openssl/bio.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/blowfish.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/buffer.h ../include/openssl/cast.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/des.h ../include/openssl/des_old.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/hmac.h ../include/openssl/idea.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/lhash.h ../include/openssl/md2.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/md4.h ../include/openssl/md5.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/mdc2.h ../include/openssl/obj_mac.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/objects.h ../include/openssl/opensslconf.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/rc2.h ../include/openssl/rc4.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/rc5.h ../include/openssl/ripemd.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/sha.h ../include/openssl/stack.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/symhacks.h ../include/openssl/txt_db.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/ui.h ../include/openssl/ui_compat.h
 | 
				
			||||||
 | 
					speed.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h speed.c
 | 
				
			||||||
 | 
					speed.o: testdsa.h testrsa.h
 | 
				
			||||||
 | 
					spkac.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					spkac.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h apps.h spkac.c
 | 
				
			||||||
 | 
					verify.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
				
			||||||
 | 
					verify.o: ../include/openssl/x509v3.h apps.h verify.c
 | 
				
			||||||
 | 
					version.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/bio.h ../include/openssl/blowfish.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/bn.h ../include/openssl/buffer.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/conf.h ../include/openssl/crypto.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/des.h ../include/openssl/des_old.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/dh.h ../include/openssl/dsa.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/e_os2.h ../include/openssl/ec.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/ecdsa.h ../include/openssl/engine.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/err.h ../include/openssl/evp.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/idea.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/md2.h ../include/openssl/obj_mac.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/objects.h ../include/openssl/opensslconf.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/opensslv.h ../include/openssl/ossl_typ.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/rc4.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/ui_compat.h ../include/openssl/x509.h
 | 
				
			||||||
 | 
					version.o: ../include/openssl/x509_vfy.h apps.h version.c
 | 
				
			||||||
 | 
					x509.o: ../e_os.h ../include/openssl/asn1.h ../include/openssl/asn1t.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/bio.h ../include/openssl/bn.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/buffer.h ../include/openssl/conf.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/crypto.h ../include/openssl/dh.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/ec.h ../include/openssl/ecdsa.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/engine.h ../include/openssl/err.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/evp.h ../include/openssl/lhash.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/obj_mac.h ../include/openssl/objects.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/ossl_typ.h ../include/openssl/pem.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/pem2.h ../include/openssl/pkcs7.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/rand.h ../include/openssl/rsa.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/safestack.h ../include/openssl/sha.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/stack.h ../include/openssl/symhacks.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/txt_db.h ../include/openssl/ui.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
 | 
				
			||||||
 | 
					x509.o: ../include/openssl/x509v3.h apps.h x509.c
 | 
				
			||||||
							
								
								
									
										850
									
								
								apps/apps.c
									
									
									
									
									
								
							
							
						
						
									
										850
									
								
								apps/apps.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										123
									
								
								apps/apps.h
									
									
									
									
									
								
							
							
						
						
									
										123
									
								
								apps/apps.h
									
									
									
									
									
								
							@@ -121,9 +121,7 @@
 | 
				
			|||||||
#include <openssl/lhash.h>
 | 
					#include <openssl/lhash.h>
 | 
				
			||||||
#include <openssl/conf.h>
 | 
					#include <openssl/conf.h>
 | 
				
			||||||
#include <openssl/txt_db.h>
 | 
					#include <openssl/txt_db.h>
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
#include <openssl/engine.h>
 | 
					#include <openssl/engine.h>
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#include <openssl/ossl_typ.h>
 | 
					#include <openssl/ossl_typ.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int app_RAND_load_file(const char *file, BIO *bio_e, int dont_warn);
 | 
					int app_RAND_load_file(const char *file, BIO *bio_e, int dont_warn);
 | 
				
			||||||
@@ -136,6 +134,10 @@ long app_RAND_load_files(char *file); /* `file' is a list of files to read,
 | 
				
			|||||||
                                       * (see e_os.h).  The string is
 | 
					                                       * (see e_os.h).  The string is
 | 
				
			||||||
                                       * destroyed! */
 | 
					                                       * destroyed! */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef OPENSSL_NO_STDIO
 | 
				
			||||||
 | 
					BIO_METHOD *BIO_s_file();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_SYS_WIN32
 | 
					#ifdef OPENSSL_SYS_WIN32
 | 
				
			||||||
#define rename(from,to) WIN32_rename((from),(to))
 | 
					#define rename(from,to) WIN32_rename((from),(to))
 | 
				
			||||||
int WIN32_rename(char *oldname,char *newname);
 | 
					int WIN32_rename(char *oldname,char *newname);
 | 
				
			||||||
@@ -146,13 +148,9 @@ int WIN32_rename(char *oldname,char *newname);
 | 
				
			|||||||
#define MAIN(a,v)	main(a,v)
 | 
					#define MAIN(a,v)	main(a,v)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef NON_MAIN
 | 
					#ifndef NON_MAIN
 | 
				
			||||||
CONF *config=NULL;
 | 
					 | 
				
			||||||
BIO *bio_err=NULL;
 | 
					BIO *bio_err=NULL;
 | 
				
			||||||
int in_FIPS_mode=0;
 | 
					 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
extern CONF *config;
 | 
					 | 
				
			||||||
extern BIO *bio_err;
 | 
					extern BIO *bio_err;
 | 
				
			||||||
extern int in_FIPS_mode;
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
@@ -161,7 +159,6 @@ extern int in_FIPS_mode;
 | 
				
			|||||||
extern CONF *config;
 | 
					extern CONF *config;
 | 
				
			||||||
extern char *default_config_file;
 | 
					extern char *default_config_file;
 | 
				
			||||||
extern BIO *bio_err;
 | 
					extern BIO *bio_err;
 | 
				
			||||||
extern int in_FIPS_mode;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -178,57 +175,30 @@ extern int in_FIPS_mode;
 | 
				
			|||||||
		do_pipe_sig()
 | 
							do_pipe_sig()
 | 
				
			||||||
#  define apps_shutdown()
 | 
					#  define apps_shutdown()
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
#  ifndef OPENSSL_NO_ENGINE
 | 
					#  if defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_WIN16) || \
 | 
				
			||||||
#    if defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_WIN16) || \
 | 
					   defined(OPENSSL_SYS_WIN32)
 | 
				
			||||||
     defined(OPENSSL_SYS_WIN32)
 | 
					#    ifdef _O_BINARY
 | 
				
			||||||
#      ifdef _O_BINARY
 | 
					#      define apps_startup() \
 | 
				
			||||||
#        define apps_startup() \
 | 
							do { _fmode=_O_BINARY; do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
				
			||||||
			do { _fmode=_O_BINARY; do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
							ERR_load_crypto_strings(); OpenSSL_add_all_algorithms(); \
 | 
				
			||||||
			ERR_load_crypto_strings(); OpenSSL_add_all_algorithms(); \
 | 
							ENGINE_load_builtin_engines(); setup_ui_method(); } while(0)
 | 
				
			||||||
			ENGINE_load_builtin_engines(); setup_ui_method(); } while(0)
 | 
					 | 
				
			||||||
#      else
 | 
					 | 
				
			||||||
#        define apps_startup() \
 | 
					 | 
				
			||||||
			do { _fmode=O_BINARY; do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
					 | 
				
			||||||
			ERR_load_crypto_strings(); OpenSSL_add_all_algorithms(); \
 | 
					 | 
				
			||||||
			ENGINE_load_builtin_engines(); setup_ui_method(); } while(0)
 | 
					 | 
				
			||||||
#      endif
 | 
					 | 
				
			||||||
#    else
 | 
					#    else
 | 
				
			||||||
#      define apps_startup() \
 | 
					#      define apps_startup() \
 | 
				
			||||||
			do { do_pipe_sig(); OpenSSL_add_all_algorithms(); \
 | 
							do { _fmode=O_BINARY; do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
				
			||||||
			ERR_load_crypto_strings(); ENGINE_load_builtin_engines(); \
 | 
							ERR_load_crypto_strings(); OpenSSL_add_all_algorithms(); \
 | 
				
			||||||
			setup_ui_method(); } while(0)
 | 
							ENGINE_load_builtin_engines(); setup_ui_method(); } while(0)
 | 
				
			||||||
#    endif
 | 
					#    endif
 | 
				
			||||||
#    define apps_shutdown() \
 | 
					 | 
				
			||||||
			do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
					 | 
				
			||||||
			EVP_cleanup(); ENGINE_cleanup(); \
 | 
					 | 
				
			||||||
			CRYPTO_cleanup_all_ex_data(); ERR_remove_state(0); \
 | 
					 | 
				
			||||||
			ERR_free_strings(); } while(0)
 | 
					 | 
				
			||||||
#  else
 | 
					#  else
 | 
				
			||||||
#    if defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_WIN16) || \
 | 
					#    define apps_startup() \
 | 
				
			||||||
     defined(OPENSSL_SYS_WIN32)
 | 
							do { do_pipe_sig(); OpenSSL_add_all_algorithms(); \
 | 
				
			||||||
#      ifdef _O_BINARY
 | 
							ERR_load_crypto_strings(); ENGINE_load_builtin_engines(); \
 | 
				
			||||||
#        define apps_startup() \
 | 
							setup_ui_method(); } while(0)
 | 
				
			||||||
			do { _fmode=_O_BINARY; do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
					 | 
				
			||||||
			ERR_load_crypto_strings(); OpenSSL_add_all_algorithms(); \
 | 
					 | 
				
			||||||
			setup_ui_method(); } while(0)
 | 
					 | 
				
			||||||
#      else
 | 
					 | 
				
			||||||
#        define apps_startup() \
 | 
					 | 
				
			||||||
			do { _fmode=O_BINARY; do_pipe_sig(); CRYPTO_malloc_init(); \
 | 
					 | 
				
			||||||
			ERR_load_crypto_strings(); OpenSSL_add_all_algorithms(); \
 | 
					 | 
				
			||||||
			setup_ui_method(); } while(0)
 | 
					 | 
				
			||||||
#      endif
 | 
					 | 
				
			||||||
#    else
 | 
					 | 
				
			||||||
#      define apps_startup() \
 | 
					 | 
				
			||||||
			do { do_pipe_sig(); OpenSSL_add_all_algorithms(); \
 | 
					 | 
				
			||||||
			ERR_load_crypto_strings(); \
 | 
					 | 
				
			||||||
			setup_ui_method(); } while(0)
 | 
					 | 
				
			||||||
#    endif
 | 
					 | 
				
			||||||
#    define apps_shutdown() \
 | 
					 | 
				
			||||||
			do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
					 | 
				
			||||||
			EVP_cleanup(); \
 | 
					 | 
				
			||||||
			CRYPTO_cleanup_all_ex_data(); ERR_remove_state(0); \
 | 
					 | 
				
			||||||
			ERR_free_strings(); } while(0)
 | 
					 | 
				
			||||||
#  endif
 | 
					#  endif
 | 
				
			||||||
 | 
					#  define apps_shutdown() \
 | 
				
			||||||
 | 
							do { CONF_modules_unload(1); destroy_ui_method(); \
 | 
				
			||||||
 | 
							EVP_cleanup(); ENGINE_cleanup(); \
 | 
				
			||||||
 | 
							CRYPTO_cleanup_all_ex_data(); ERR_remove_state(0); \
 | 
				
			||||||
 | 
							ERR_free_strings(); } while(0)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct args_st
 | 
					typedef struct args_st
 | 
				
			||||||
@@ -247,8 +217,8 @@ typedef struct pw_cb_data
 | 
				
			|||||||
int password_callback(char *buf, int bufsiz, int verify,
 | 
					int password_callback(char *buf, int bufsiz, int verify,
 | 
				
			||||||
	PW_CB_DATA *cb_data);
 | 
						PW_CB_DATA *cb_data);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int setup_ui_method(void);
 | 
					int setup_ui_method();
 | 
				
			||||||
void destroy_ui_method(void);
 | 
					void destroy_ui_method();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int should_retry(int i);
 | 
					int should_retry(int i);
 | 
				
			||||||
int args_from_file(char *file, int *argc, char **argv[]);
 | 
					int args_from_file(char *file, int *argc, char **argv[]);
 | 
				
			||||||
@@ -267,56 +237,21 @@ int app_passwd(BIO *err, char *arg1, char *arg2, char **pass1, char **pass2);
 | 
				
			|||||||
int add_oid_section(BIO *err, CONF *conf);
 | 
					int add_oid_section(BIO *err, CONF *conf);
 | 
				
			||||||
X509 *load_cert(BIO *err, const char *file, int format,
 | 
					X509 *load_cert(BIO *err, const char *file, int format,
 | 
				
			||||||
	const char *pass, ENGINE *e, const char *cert_descrip);
 | 
						const char *pass, ENGINE *e, const char *cert_descrip);
 | 
				
			||||||
EVP_PKEY *load_key(BIO *err, const char *file, int format, int maybe_stdin,
 | 
					EVP_PKEY *load_key(BIO *err, const char *file, int format,
 | 
				
			||||||
	const char *pass, ENGINE *e, const char *key_descrip);
 | 
						const char *pass, ENGINE *e, const char *key_descrip);
 | 
				
			||||||
EVP_PKEY *load_pubkey(BIO *err, const char *file, int format, int maybe_stdin,
 | 
					EVP_PKEY *load_pubkey(BIO *err, const char *file, int format,
 | 
				
			||||||
	const char *pass, ENGINE *e, const char *key_descrip);
 | 
						const char *pass, ENGINE *e, const char *key_descrip);
 | 
				
			||||||
STACK_OF(X509) *load_certs(BIO *err, const char *file, int format,
 | 
					STACK_OF(X509) *load_certs(BIO *err, const char *file, int format,
 | 
				
			||||||
	const char *pass, ENGINE *e, const char *cert_descrip);
 | 
						const char *pass, ENGINE *e, const char *cert_descrip);
 | 
				
			||||||
X509_STORE *setup_verify(BIO *bp, char *CAfile, char *CApath);
 | 
					X509_STORE *setup_verify(BIO *bp, char *CAfile, char *CApath);
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
ENGINE *setup_engine(BIO *err, const char *engine, int debug);
 | 
					ENGINE *setup_engine(BIO *err, const char *engine, int debug);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
int load_config(BIO *err, CONF *cnf);
 | 
					int load_config(BIO *err, CONF *cnf);
 | 
				
			||||||
char *make_config_name(void);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Functions defined in ca.c and also used in ocsp.c */
 | 
					/* Functions defined in ca.c and also used in ocsp.c */
 | 
				
			||||||
int unpack_revinfo(ASN1_TIME **prevtm, int *preason, ASN1_OBJECT **phold,
 | 
					int unpack_revinfo(ASN1_TIME **prevtm, int *preason, ASN1_OBJECT **phold,
 | 
				
			||||||
			ASN1_GENERALIZEDTIME **pinvtm, char *str);
 | 
								ASN1_GENERALIZEDTIME **pinvtm, char *str);
 | 
				
			||||||
 | 
					int make_serial_index(TXT_DB *db);
 | 
				
			||||||
#define DB_type         0
 | 
					 | 
				
			||||||
#define DB_exp_date     1
 | 
					 | 
				
			||||||
#define DB_rev_date     2
 | 
					 | 
				
			||||||
#define DB_serial       3       /* index - unique */
 | 
					 | 
				
			||||||
#define DB_file         4       
 | 
					 | 
				
			||||||
#define DB_name         5       /* index - unique when active and not disabled */
 | 
					 | 
				
			||||||
#define DB_NUMBER       6
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define DB_TYPE_REV	'R'
 | 
					 | 
				
			||||||
#define DB_TYPE_EXP	'E'
 | 
					 | 
				
			||||||
#define DB_TYPE_VAL	'V'
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
typedef struct db_attr_st
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	int unique_subject;
 | 
					 | 
				
			||||||
	} DB_ATTR;
 | 
					 | 
				
			||||||
typedef struct ca_db_st
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	DB_ATTR attributes;
 | 
					 | 
				
			||||||
	TXT_DB *db;
 | 
					 | 
				
			||||||
	} CA_DB;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
BIGNUM *load_serial(char *serialfile, int create, ASN1_INTEGER **retai);
 | 
					 | 
				
			||||||
int save_serial(char *serialfile, char *suffix, BIGNUM *serial, ASN1_INTEGER **retai);
 | 
					 | 
				
			||||||
int rotate_serial(char *serialfile, char *new_suffix, char *old_suffix);
 | 
					 | 
				
			||||||
int rand_serial(BIGNUM *b, ASN1_INTEGER *ai);
 | 
					 | 
				
			||||||
CA_DB *load_index(char *dbfile, DB_ATTR *dbattr);
 | 
					 | 
				
			||||||
int index_index(CA_DB *db);
 | 
					 | 
				
			||||||
int save_index(char *dbfile, char *suffix, CA_DB *db);
 | 
					 | 
				
			||||||
int rotate_index(char *dbfile, char *new_suffix, char *old_suffix);
 | 
					 | 
				
			||||||
void free_index(CA_DB *db);
 | 
					 | 
				
			||||||
int index_name_cmp(const char **a, const char **b);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
X509_NAME *do_subject(char *str, long chtype);
 | 
					X509_NAME *do_subject(char *str, long chtype);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -339,6 +274,4 @@ X509_NAME *do_subject(char *str, long chtype);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#define APP_PASS_LEN	1024
 | 
					#define APP_PASS_LEN	1024
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define SERIAL_RAND_BITS	64
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -182,9 +182,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
bad:
 | 
					bad:
 | 
				
			||||||
		BIO_printf(bio_err,"%s [options] <infile\n",prog);
 | 
							BIO_printf(bio_err,"%s [options] <infile\n",prog);
 | 
				
			||||||
		BIO_printf(bio_err,"where options are\n");
 | 
							BIO_printf(bio_err,"where options are\n");
 | 
				
			||||||
		BIO_printf(bio_err," -inform arg   input format - one of DER PEM\n");
 | 
							BIO_printf(bio_err," -inform arg   input format - one of DER TXT PEM\n");
 | 
				
			||||||
		BIO_printf(bio_err," -in arg       input file\n");
 | 
							BIO_printf(bio_err," -in arg       input file\n");
 | 
				
			||||||
		BIO_printf(bio_err," -out arg      output file (output format is always DER\n");
 | 
							BIO_printf(bio_err," -out arg      output file\n");
 | 
				
			||||||
		BIO_printf(bio_err," -noout arg    don't produce any output\n");
 | 
							BIO_printf(bio_err," -noout arg    don't produce any output\n");
 | 
				
			||||||
		BIO_printf(bio_err," -offset arg   offset into file\n");
 | 
							BIO_printf(bio_err," -offset arg   offset into file\n");
 | 
				
			||||||
		BIO_printf(bio_err," -length arg   length of section in file\n");
 | 
							BIO_printf(bio_err," -length arg   length of section in file\n");
 | 
				
			||||||
@@ -195,6 +195,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -strparse offset\n");
 | 
							BIO_printf(bio_err," -strparse offset\n");
 | 
				
			||||||
		BIO_printf(bio_err,"               a series of these can be used to 'dig' into multiple\n");
 | 
							BIO_printf(bio_err,"               a series of these can be used to 'dig' into multiple\n");
 | 
				
			||||||
		BIO_printf(bio_err,"               ASN1 blob wrappings\n");
 | 
							BIO_printf(bio_err,"               ASN1 blob wrappings\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -out filename output DER encoding to file\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -278,7 +279,6 @@ bad:
 | 
				
			|||||||
		tmplen=num;
 | 
							tmplen=num;
 | 
				
			||||||
		for (i=0; i<sk_num(osk); i++)
 | 
							for (i=0; i<sk_num(osk); i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			int typ;
 | 
					 | 
				
			||||||
			ASN1_TYPE *atmp;
 | 
								ASN1_TYPE *atmp;
 | 
				
			||||||
			j=atoi(sk_value(osk,i));
 | 
								j=atoi(sk_value(osk,i));
 | 
				
			||||||
			if (j == 0)
 | 
								if (j == 0)
 | 
				
			||||||
@@ -297,15 +297,6 @@ bad:
 | 
				
			|||||||
				ERR_print_errors(bio_err);
 | 
									ERR_print_errors(bio_err);
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			typ = ASN1_TYPE_get(at);
 | 
					 | 
				
			||||||
			if ((typ == V_ASN1_OBJECT)
 | 
					 | 
				
			||||||
				|| (typ == V_ASN1_NULL))
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err, "Can't parse %s type\n",
 | 
					 | 
				
			||||||
					typ == V_ASN1_NULL ? "NULL" : "OBJECT");
 | 
					 | 
				
			||||||
				ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			/* hmm... this is a little evil but it works */
 | 
								/* hmm... this is a little evil but it works */
 | 
				
			||||||
			tmpbuf=at->value.asn1_string->data;
 | 
								tmpbuf=at->value.asn1_string->data;
 | 
				
			||||||
			tmplen=at->value.asn1_string->length;
 | 
								tmplen=at->value.asn1_string->length;
 | 
				
			||||||
@@ -314,15 +305,7 @@ bad:
 | 
				
			|||||||
		num=tmplen;
 | 
							num=tmplen;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (offset >= num)
 | 
						if (length == 0) length=(unsigned int)num;
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error: offset too large\n");
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	num -= offset;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if ((length == 0) || ((long)length > num)) length=(unsigned int)num;
 | 
					 | 
				
			||||||
	if(derout) {
 | 
						if(derout) {
 | 
				
			||||||
		if(BIO_write(derout, str + offset, length) != (int)length) {
 | 
							if(BIO_write(derout, str + offset, length) != (int)length) {
 | 
				
			||||||
			BIO_printf(bio_err, "Error writing output\n");
 | 
								BIO_printf(bio_err, "Error writing output\n");
 | 
				
			||||||
@@ -350,6 +333,6 @@ end:
 | 
				
			|||||||
	if (osk != NULL) sk_free(osk);
 | 
						if (osk != NULL) sk_free(osk);
 | 
				
			||||||
	OBJ_cleanup();
 | 
						OBJ_cleanup();
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -187,7 +187,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_puts(STDout,SSL_CIPHER_description(
 | 
								BIO_puts(STDout,SSL_CIPHER_description(
 | 
				
			||||||
				sk_SSL_CIPHER_value(sk,i),
 | 
									sk_SSL_CIPHER_value(sk,i),
 | 
				
			||||||
				buf,sizeof buf));
 | 
									buf,512));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -203,6 +203,6 @@ end:
 | 
				
			|||||||
	if (ssl != NULL) SSL_free(ssl);
 | 
						if (ssl != NULL) SSL_free(ssl);
 | 
				
			||||||
	if (STDout != NULL) BIO_free_all(STDout);
 | 
						if (STDout != NULL) BIO_free_all(STDout);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -81,7 +81,6 @@ static char *crl_usage[]={
 | 
				
			|||||||
" -in arg         - input file - default stdin\n",
 | 
					" -in arg         - input file - default stdin\n",
 | 
				
			||||||
" -out arg        - output file - default stdout\n",
 | 
					" -out arg        - output file - default stdout\n",
 | 
				
			||||||
" -hash           - print hash value\n",
 | 
					" -hash           - print hash value\n",
 | 
				
			||||||
" -fingerprint    - print the crl fingerprint\n",
 | 
					 | 
				
			||||||
" -issuer         - print issuer DN\n",
 | 
					" -issuer         - print issuer DN\n",
 | 
				
			||||||
" -lastupdate     - lastUpdate field\n",
 | 
					" -lastupdate     - lastUpdate field\n",
 | 
				
			||||||
" -nextupdate     - nextUpdate field\n",
 | 
					" -nextupdate     - nextUpdate field\n",
 | 
				
			||||||
@@ -355,11 +354,7 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (text) X509_CRL_print(out, x);
 | 
						if (text) X509_CRL_print(out, x);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (noout) 
 | 
						if (noout) goto end;
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		ret = 0;
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if 	(outformat == FORMAT_ASN1)
 | 
						if 	(outformat == FORMAT_ASN1)
 | 
				
			||||||
		i=(int)i2d_X509_CRL_bio(out,x);
 | 
							i=(int)i2d_X509_CRL_bio(out,x);
 | 
				
			||||||
@@ -382,7 +377,7 @@ end:
 | 
				
			|||||||
		X509_STORE_free(store);
 | 
							X509_STORE_free(store);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static X509_CRL *load_crl(char *infile, int format)
 | 
					static X509_CRL *load_crl(char *infile, int format)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -280,7 +280,7 @@ end:
 | 
				
			|||||||
	if (crl != NULL) X509_CRL_free(crl);
 | 
						if (crl != NULL) X509_CRL_free(crl);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										305
									
								
								apps/der_chop.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										305
									
								
								apps/der_chop.in
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,305 @@
 | 
				
			|||||||
 | 
					#!/usr/local/bin/perl
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# der_chop ... this is one total hack that Eric is really not proud of
 | 
				
			||||||
 | 
					#              so don't look at it and don't ask for support
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# The "documentation" for this (i.e. all the comments) are my fault --tjh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This program takes the "raw" output of derparse/asn1parse and 
 | 
				
			||||||
 | 
					# converts it into tokens and then runs regular expression matches
 | 
				
			||||||
 | 
					# to try to figure out what to grab to get the things that are needed
 | 
				
			||||||
 | 
					# and it is possible that this will do the wrong thing as it is a *hack*
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# SSLeay 0.5.2+ should have direct read support for x509 (via -inform NET)
 | 
				
			||||||
 | 
					# [I know ... promises promises :-)]
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# To convert a Netscape Certificate:
 | 
				
			||||||
 | 
					#    der_chop < ServerCert.der > cert.pem
 | 
				
			||||||
 | 
					# To convert a Netscape Key (and encrypt it again to protect it)
 | 
				
			||||||
 | 
					#    rsa -inform NET -in ServerKey.der -des > key.pem
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 23-Apr-96 eay    Added the extra ASN.1 string types, I still think this
 | 
				
			||||||
 | 
					#		   is an evil hack.  If nothing else the parsing should
 | 
				
			||||||
 | 
					#		   be relative, not absolute.
 | 
				
			||||||
 | 
					# 19-Apr-96 tjh    hacked (with eay) into 0.5.x format
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Tim Hudson
 | 
				
			||||||
 | 
					# tjh@cryptsoft.com
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					require 'getopts.pl';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$debug=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# this was the 0.4.x way of doing things ...
 | 
				
			||||||
 | 
					$cmd="derparse";
 | 
				
			||||||
 | 
					$x509_cmd="x509";
 | 
				
			||||||
 | 
					$crl_cmd="crl";
 | 
				
			||||||
 | 
					$rc4_cmd="rc4";
 | 
				
			||||||
 | 
					$md2_cmd="md2";
 | 
				
			||||||
 | 
					$md4_cmd="md4";
 | 
				
			||||||
 | 
					$rsa_cmd="rsa -des -inform der ";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# this was the 0.5.x way of doing things ...
 | 
				
			||||||
 | 
					$cmd="openssl asn1parse";
 | 
				
			||||||
 | 
					$x509_cmd="openssl x509";
 | 
				
			||||||
 | 
					$crl_cmd="openssl crl";
 | 
				
			||||||
 | 
					$rc4_cmd="openssl rc4";
 | 
				
			||||||
 | 
					$md2_cmd="openssl md2";
 | 
				
			||||||
 | 
					$md4_cmd="openssl md4";
 | 
				
			||||||
 | 
					$rsa_cmd="openssl rsa -des -inform der ";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&Getopts('vd:') || die "usage:$0 [-v] [-d num] file";
 | 
				
			||||||
 | 
					$depth=($opt_d =~ /^\d+$/)?$opt_d:0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&init_der();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if ($#ARGV != -1)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						foreach $file (@ARGV)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							print STDERR "doing $file\n";
 | 
				
			||||||
 | 
							&dofile($file);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						$file="/tmp/a$$.DER";
 | 
				
			||||||
 | 
						open(OUT,">$file") || die "unable to open $file:$!\n";
 | 
				
			||||||
 | 
						for (;;)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							$i=sysread(STDIN,$b,1024*10);
 | 
				
			||||||
 | 
							last if ($i <= 0);
 | 
				
			||||||
 | 
							$i=syswrite(OUT,$b,$i);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						&dofile($file);
 | 
				
			||||||
 | 
						unlink($file);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					sub dofile
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($file)=@_;
 | 
				
			||||||
 | 
						local(@p);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						$b=&load_file($file);
 | 
				
			||||||
 | 
						@p=&load_file_parse($file);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						foreach $_ (@p)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							($off,$d,$hl,$len)=&parse_line($_);
 | 
				
			||||||
 | 
							$d-=$depth;
 | 
				
			||||||
 | 
							next if ($d != 0);
 | 
				
			||||||
 | 
							next if ($len == 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							$o=substr($b,$off,$len+$hl);
 | 
				
			||||||
 | 
							($str,@data)=&der_str($o);
 | 
				
			||||||
 | 
							print "$str\n" if ($opt_v);
 | 
				
			||||||
 | 
							if ($str =~ /^$crl/)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								open(OUT,"|$crl_cmd -inform d -hash -issuer") ||
 | 
				
			||||||
 | 
									die "unable to run $crl_cmd:$!\n";
 | 
				
			||||||
 | 
								print OUT $o;
 | 
				
			||||||
 | 
								close(OUT);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							elsif ($str =~ /^$x509/)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								open(OUT,"|$x509_cmd -inform d -hash -subject -issuer")
 | 
				
			||||||
 | 
									|| die "unable to run $x509_cmd:$!\n";
 | 
				
			||||||
 | 
								print OUT $o;
 | 
				
			||||||
 | 
								close(OUT);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							elsif ($str =~ /^$rsa/)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								($type)=($data[3] =~ /OBJECT_IDENTIFIER :(.*)\s*$/);
 | 
				
			||||||
 | 
								next unless ($type eq "rsaEncryption");
 | 
				
			||||||
 | 
								($off,$d,$hl,$len)=&parse_line($data[5]);
 | 
				
			||||||
 | 
								$os=substr($o,$off+$hl,$len);
 | 
				
			||||||
 | 
								open(OUT,"|$rsa_cmd")
 | 
				
			||||||
 | 
									|| die "unable to run $rsa_cmd:$!\n";
 | 
				
			||||||
 | 
								print OUT $os;
 | 
				
			||||||
 | 
								close(OUT);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							elsif ($str =~ /^0G-1D-1G/)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								($off,$d,$hl,$len)=&parse_line($data[1]);
 | 
				
			||||||
 | 
								$os=substr($o,$off+$hl,$len);
 | 
				
			||||||
 | 
								print STDERR "<$os>\n" if $opt_v;
 | 
				
			||||||
 | 
								&do_certificate($o,@data)
 | 
				
			||||||
 | 
									if (($os eq "certificate") &&
 | 
				
			||||||
 | 
									    ($str =! /^0G-1D-1G-2G-3F-3E-2D/));
 | 
				
			||||||
 | 
								&do_private_key($o,@data)
 | 
				
			||||||
 | 
									if (($os eq "private-key") &&
 | 
				
			||||||
 | 
									    ($str =! /^0G-1D-1G-2G-3F-3E-2D/));
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sub der_str
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($str)=@_;
 | 
				
			||||||
 | 
						local(*OUT,*IN,@a,$t,$d,$ret);
 | 
				
			||||||
 | 
						local($file)="/tmp/b$$.DER";
 | 
				
			||||||
 | 
						local(@ret);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						open(OUT,">$file");
 | 
				
			||||||
 | 
						print OUT $str;
 | 
				
			||||||
 | 
						close(OUT);
 | 
				
			||||||
 | 
						open(IN,"$cmd -inform 'd' -in $file |") ||
 | 
				
			||||||
 | 
							die "unable to run $cmd:$!\n";
 | 
				
			||||||
 | 
						$ret="";
 | 
				
			||||||
 | 
						while (<IN>)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							chop;
 | 
				
			||||||
 | 
							push(@ret,$_);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							print STDERR "$_\n" if ($debug);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							@a=split(/\s*:\s*/);
 | 
				
			||||||
 | 
							($d)=($a[1] =~ /d=\s*(\d+)/);
 | 
				
			||||||
 | 
							$a[2] =~ s/\s+$//;
 | 
				
			||||||
 | 
							$t=$DER_s2i{$a[2]};
 | 
				
			||||||
 | 
							$ret.="$d$t-";
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						close(IN);
 | 
				
			||||||
 | 
						unlink($file);
 | 
				
			||||||
 | 
						chop $ret;
 | 
				
			||||||
 | 
						$ret =~ s/(-3H(-4G-5F-5[IJKMQRS])+)+/-NAME/g;
 | 
				
			||||||
 | 
						$ret =~ s/(-3G-4B-4L)+/-RCERT/g;
 | 
				
			||||||
 | 
						return($ret,@ret);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sub init_der
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						$crl= "0G-1G-2G-3F-3E-2G-NAME-2L-2L-2G-RCERT-1G-2F-2E-1C";
 | 
				
			||||||
 | 
						$x509="0G-1G-2B-2G-3F-3E-2G-NAME-2G-3L-3L-2G-NAME-2G-3G-4F-4E-3C-1G-2F-2E-1C";
 | 
				
			||||||
 | 
						$rsa= "0G-1B-1G-2F-2E-1D";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						%DER_i2s=(
 | 
				
			||||||
 | 
							# SSLeay 0.4.x has this list
 | 
				
			||||||
 | 
							"A","EOC",
 | 
				
			||||||
 | 
							"B","INTEGER",
 | 
				
			||||||
 | 
							"C","BIT STRING",
 | 
				
			||||||
 | 
							"D","OCTET STRING",
 | 
				
			||||||
 | 
							"E","NULL",
 | 
				
			||||||
 | 
							"F","OBJECT",
 | 
				
			||||||
 | 
							"G","SEQUENCE",
 | 
				
			||||||
 | 
							"H","SET",
 | 
				
			||||||
 | 
							"I","PRINTABLESTRING",
 | 
				
			||||||
 | 
							"J","T61STRING",
 | 
				
			||||||
 | 
							"K","IA5STRING",
 | 
				
			||||||
 | 
							"L","UTCTIME",
 | 
				
			||||||
 | 
							"M","NUMERICSTRING",
 | 
				
			||||||
 | 
							"N","VIDEOTEXSTRING",
 | 
				
			||||||
 | 
							"O","GENERALIZEDTIME",
 | 
				
			||||||
 | 
							"P","GRAPHICSTRING",
 | 
				
			||||||
 | 
							"Q","ISO64STRING",
 | 
				
			||||||
 | 
							"R","GENERALSTRING",
 | 
				
			||||||
 | 
							"S","UNIVERSALSTRING",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							# SSLeay 0.5.x changed some things ... and I'm
 | 
				
			||||||
 | 
							# leaving in the old stuff but adding in these
 | 
				
			||||||
 | 
							# to handle the new as well --tjh
 | 
				
			||||||
 | 
							# - Well I've just taken them out and added the extra new
 | 
				
			||||||
 | 
							# ones :-) - eay
 | 
				
			||||||
 | 
							);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						foreach (keys %DER_i2s)
 | 
				
			||||||
 | 
							{ $DER_s2i{$DER_i2s{$_}}=$_; }
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sub parse_line
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($_)=@_;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return(/\s*(\d+):d=\s*(\d+)\s+hl=\s*(\d+)\s+l=\s*(\d+|inf)\s/);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#  0:d=0 hl=4 l=377 cons: univ: SEQUENCE          
 | 
				
			||||||
 | 
					#  4:d=1 hl=2 l= 11 prim: univ: OCTET_STRING      
 | 
				
			||||||
 | 
					# 17:d=1 hl=4 l=360 cons: univ: SEQUENCE          
 | 
				
			||||||
 | 
					# 21:d=2 hl=2 l= 12 cons: univ: SEQUENCE          
 | 
				
			||||||
 | 
					# 23:d=3 hl=2 l=  8 prim: univ: OBJECT_IDENTIFIER :rc4
 | 
				
			||||||
 | 
					# 33:d=3 hl=2 l=  0 prim: univ: NULL              
 | 
				
			||||||
 | 
					# 35:d=2 hl=4 l=342 prim: univ: OCTET_STRING
 | 
				
			||||||
 | 
					sub do_private_key
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($data,@struct)=@_;
 | 
				
			||||||
 | 
						local($file)="/tmp/b$$.DER";
 | 
				
			||||||
 | 
						local($off,$d,$hl,$len,$_,$b,@p,$s);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						($type)=($struct[4] =~ /OBJECT_IDENTIFIER :(.*)\s*$/);
 | 
				
			||||||
 | 
						if ($type eq "rc4")
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							($off,$d,$hl,$len)=&parse_line($struct[6]);
 | 
				
			||||||
 | 
							open(OUT,"|$rc4_cmd >$file") ||
 | 
				
			||||||
 | 
								die "unable to run $rc4_cmd:$!\n";
 | 
				
			||||||
 | 
							print OUT substr($data,$off+$hl,$len);
 | 
				
			||||||
 | 
							close(OUT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							$b=&load_file($file);
 | 
				
			||||||
 | 
							unlink($file);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							($s,@p)=&der_str($b);
 | 
				
			||||||
 | 
							die "unknown rsa key type\n$s\n"
 | 
				
			||||||
 | 
								if ($s ne '0G-1B-1G-2F-2E-1D');
 | 
				
			||||||
 | 
							local($off,$d,$hl,$len)=&parse_line($p[5]);
 | 
				
			||||||
 | 
							$b=substr($b,$off+$hl,$len);
 | 
				
			||||||
 | 
							($s,@p)=&der_str($b);
 | 
				
			||||||
 | 
							open(OUT,"|$rsa_cmd") || die "unable to run $rsa_cmd:$!\n";
 | 
				
			||||||
 | 
							print OUT $b;
 | 
				
			||||||
 | 
							close(OUT);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							print "'$type' is unknown\n";
 | 
				
			||||||
 | 
							exit(1);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sub do_certificate
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($data,@struct)=@_;
 | 
				
			||||||
 | 
						local($file)="/tmp/b$$.DER";
 | 
				
			||||||
 | 
						local($off,$d,$hl,$len,$_,$b,@p,$s);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						($off,$d,$hl,$len)=&parse_line($struct[2]);
 | 
				
			||||||
 | 
						$b=substr($data,$off,$len+$hl);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						open(OUT,"|$x509_cmd -inform d") || die "unable to run $x509_cmd:$!\n";
 | 
				
			||||||
 | 
						print OUT $b;
 | 
				
			||||||
 | 
						close(OUT);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sub load_file
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($file)=@_;
 | 
				
			||||||
 | 
						local(*IN,$r,$b,$i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						$r="";
 | 
				
			||||||
 | 
						open(IN,"<$file") || die "unable to open $file:$!\n";
 | 
				
			||||||
 | 
						for (;;)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							$i=sysread(IN,$b,10240);
 | 
				
			||||||
 | 
							last if ($i <= 0);
 | 
				
			||||||
 | 
							$r.=$b;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						close(IN);
 | 
				
			||||||
 | 
						return($r);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sub load_file_parse
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						local($file)=@_;
 | 
				
			||||||
 | 
						local(*IN,$r,@ret,$_,$i,$n,$b);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						open(IN,"$cmd -inform d -in $file|")
 | 
				
			||||||
 | 
							|| die "unable to run der_parse\n";
 | 
				
			||||||
 | 
						while (<IN>)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							chop;
 | 
				
			||||||
 | 
							push(@ret,$_);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						return($r,@ret);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										149
									
								
								apps/dgst.c
									
									
									
									
									
								
							
							
						
						
									
										149
									
								
								apps/dgst.c
									
									
									
									
									
								
							@@ -66,7 +66,6 @@
 | 
				
			|||||||
#include <openssl/objects.h>
 | 
					#include <openssl/objects.h>
 | 
				
			||||||
#include <openssl/x509.h>
 | 
					#include <openssl/x509.h>
 | 
				
			||||||
#include <openssl/pem.h>
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
#include <openssl/hmac.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef BUFSIZE
 | 
					#undef BUFSIZE
 | 
				
			||||||
#define BUFSIZE	1024*8
 | 
					#define BUFSIZE	1024*8
 | 
				
			||||||
@@ -74,11 +73,8 @@
 | 
				
			|||||||
#undef PROG
 | 
					#undef PROG
 | 
				
			||||||
#define PROG	dgst_main
 | 
					#define PROG	dgst_main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static HMAC_CTX hmac_ctx;
 | 
					void do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			||||||
 | 
							EVP_PKEY *key, unsigned char *sigin, int siglen);
 | 
				
			||||||
int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
					 | 
				
			||||||
	  EVP_PKEY *key, unsigned char *sigin, int siglen, const char *title,
 | 
					 | 
				
			||||||
	  const char *file,BIO *bmd,const char *hmac_key, int non_fips_allow);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -103,12 +99,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	EVP_PKEY *sigkey = NULL;
 | 
						EVP_PKEY *sigkey = NULL;
 | 
				
			||||||
	unsigned char *sigbuf = NULL;
 | 
						unsigned char *sigbuf = NULL;
 | 
				
			||||||
	int siglen = 0;
 | 
						int siglen = 0;
 | 
				
			||||||
	char *passargin = NULL, *passin = NULL;
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *hmac_key=NULL;
 | 
					 | 
				
			||||||
	int non_fips_allow = 0;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -125,7 +116,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* first check the program name */
 | 
						/* first check the program name */
 | 
				
			||||||
	program_name(argv[0],pname,sizeof pname);
 | 
						program_name(argv[0],pname,PROG_NAME_SIZE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	md=EVP_get_digestbyname(pname);
 | 
						md=EVP_get_digestbyname(pname);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -151,12 +142,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
			keyfile=*(++argv);
 | 
								keyfile=*(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*argv,"-passin"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1)
 | 
					 | 
				
			||||||
				break;
 | 
					 | 
				
			||||||
			passargin=*++argv;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-verify") == 0)
 | 
							else if (strcmp(*argv,"-verify") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
@@ -180,27 +165,17 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
			keyform=str2fmt(*(++argv));
 | 
								keyform=str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-hex") == 0)
 | 
							else if (strcmp(*argv,"-hex") == 0)
 | 
				
			||||||
			out_bin = 0;
 | 
								out_bin = 0;
 | 
				
			||||||
		else if (strcmp(*argv,"-binary") == 0)
 | 
							else if (strcmp(*argv,"-binary") == 0)
 | 
				
			||||||
			out_bin = 1;
 | 
								out_bin = 1;
 | 
				
			||||||
		else if (strcmp(*argv,"-d") == 0)
 | 
							else if (strcmp(*argv,"-d") == 0)
 | 
				
			||||||
			debug=1;
 | 
								debug=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-non-fips-allow") == 0)
 | 
					 | 
				
			||||||
			non_fips_allow=1;
 | 
					 | 
				
			||||||
		else if (!strcmp(*argv,"-hmac"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1)
 | 
					 | 
				
			||||||
				break;
 | 
					 | 
				
			||||||
			hmac_key=*++argv;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if ((m=EVP_get_digestbyname(&((*argv)[1]))) != NULL)
 | 
							else if ((m=EVP_get_digestbyname(&((*argv)[1]))) != NULL)
 | 
				
			||||||
			md=m;
 | 
								md=m;
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
@@ -232,9 +207,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf(bio_err,"-keyform arg    key file format (PEM or ENGINE)\n");
 | 
							BIO_printf(bio_err,"-keyform arg    key file format (PEM or ENGINE)\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-signature file signature to verify\n");
 | 
							BIO_printf(bio_err,"-signature file signature to verify\n");
 | 
				
			||||||
		BIO_printf(bio_err,"-binary         output in binary form\n");
 | 
							BIO_printf(bio_err,"-binary         output in binary form\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"-engine e       use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err,"-engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		BIO_printf(bio_err,"-%3s to use the %s message digest algorithm (default)\n",
 | 
							BIO_printf(bio_err,"-%3s to use the %s message digest algorithm (default)\n",
 | 
				
			||||||
			LN_md5,LN_md5);
 | 
								LN_md5,LN_md5);
 | 
				
			||||||
@@ -254,9 +227,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
	e = setup_engine(bio_err, engine, 0);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	in=BIO_new(BIO_s_file());
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
	bmd=BIO_new(BIO_f_md());
 | 
						bmd=BIO_new(BIO_f_md());
 | 
				
			||||||
@@ -267,12 +238,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_set_callback_arg(in,bio_err);
 | 
							BIO_set_callback_arg(in,bio_err);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, NULL, &passin, NULL))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error getting password\n");
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if ((in == NULL) || (bmd == NULL))
 | 
						if ((in == NULL) || (bmd == NULL))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
@@ -311,10 +276,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if(keyfile)
 | 
						if(keyfile)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (want_pub)
 | 
							if (want_pub)
 | 
				
			||||||
			sigkey = load_pubkey(bio_err, keyfile, keyform, 0, NULL,
 | 
								sigkey = load_pubkey(bio_err, keyfile, keyform, NULL,
 | 
				
			||||||
				e, "key file");
 | 
									e, "key file");
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			sigkey = load_key(bio_err, keyfile, keyform, 0, passin,
 | 
								sigkey = load_key(bio_err, keyfile, keyform, NULL,
 | 
				
			||||||
				e, "key file");
 | 
									e, "key file");
 | 
				
			||||||
		if (!sigkey)
 | 
							if (!sigkey)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -344,131 +309,74 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (non_fips_allow)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		EVP_MD_CTX *md_ctx;
 | 
					 | 
				
			||||||
		BIO_get_md_ctx(bmd,&md_ctx);
 | 
					 | 
				
			||||||
		EVP_MD_CTX_set_flags(md_ctx, EVP_MD_CTX_FLAG_NON_FIPS_ALLOW);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* we use md as a filter, reading from 'in' */
 | 
						/* we use md as a filter, reading from 'in' */
 | 
				
			||||||
	if (!BIO_set_md(bmd,md))
 | 
						BIO_set_md(bmd,md);
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error setting digest %s\n",
 | 
					 | 
				
			||||||
							EVP_MD_name(md));
 | 
					 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
		
 | 
					 | 
				
			||||||
	inp=BIO_push(bmd,in);
 | 
						inp=BIO_push(bmd,in);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (argc == 0)
 | 
						if (argc == 0)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
				
			||||||
		err=do_fp(out, buf,inp,separator, out_bin, sigkey, sigbuf,
 | 
							do_fp(out, buf,inp,separator, out_bin, sigkey, sigbuf, siglen);
 | 
				
			||||||
			  siglen,"","(stdin)",bmd,hmac_key, non_fips_allow);
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		name=OBJ_nid2sn(md->type);
 | 
							name=OBJ_nid2sn(md->type);
 | 
				
			||||||
		for (i=0; i<argc; i++)
 | 
							for (i=0; i<argc; i++)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			char *tmp,*tofree=NULL;
 | 
					 | 
				
			||||||
			int r;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			if (BIO_read_filename(in,argv[i]) <= 0)
 | 
								if (BIO_read_filename(in,argv[i]) <= 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				perror(argv[i]);
 | 
									perror(argv[i]);
 | 
				
			||||||
				err++;
 | 
									err++;
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			if(!out_bin)
 | 
								if(!out_bin) BIO_printf(out, "%s(%s)= ",name,argv[i]);
 | 
				
			||||||
				{
 | 
								do_fp(out, buf,inp,separator, out_bin, sigkey, 
 | 
				
			||||||
				size_t len = strlen(name)+strlen(argv[i])+(hmac_key ? 5 : 0)+5;
 | 
													sigbuf, siglen);
 | 
				
			||||||
				tmp=tofree=OPENSSL_malloc(len);
 | 
					 | 
				
			||||||
				BIO_snprintf(tmp,len,"%s%s(%s)= ",
 | 
					 | 
				
			||||||
							 hmac_key ? "HMAC-" : "",name,argv[i]);
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				tmp="";
 | 
					 | 
				
			||||||
			r=do_fp(out,buf,inp,separator,out_bin,sigkey,sigbuf,
 | 
					 | 
				
			||||||
				siglen,tmp,argv[i],bmd,hmac_key,non_fips_allow);
 | 
					 | 
				
			||||||
			if(r)
 | 
					 | 
				
			||||||
			    err=r;
 | 
					 | 
				
			||||||
			if(tofree)
 | 
					 | 
				
			||||||
				OPENSSL_free(tofree);
 | 
					 | 
				
			||||||
			(void)BIO_reset(bmd);
 | 
								(void)BIO_reset(bmd);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
	if (buf != NULL)
 | 
						if (buf != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		OPENSSL_cleanse(buf,BUFSIZE);
 | 
							memset(buf,0,BUFSIZE);
 | 
				
			||||||
		OPENSSL_free(buf);
 | 
							OPENSSL_free(buf);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (in != NULL) BIO_free(in);
 | 
						if (in != NULL) BIO_free(in);
 | 
				
			||||||
	if (passin)
 | 
					 | 
				
			||||||
		OPENSSL_free(passin);
 | 
					 | 
				
			||||||
	BIO_free_all(out);
 | 
						BIO_free_all(out);
 | 
				
			||||||
	EVP_PKEY_free(sigkey);
 | 
						EVP_PKEY_free(sigkey);
 | 
				
			||||||
	if(sigbuf) OPENSSL_free(sigbuf);
 | 
						if(sigbuf) OPENSSL_free(sigbuf);
 | 
				
			||||||
	if (bmd != NULL) BIO_free(bmd);
 | 
						if (bmd != NULL) BIO_free(bmd);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(err);
 | 
						EXIT(err);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
					void do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			||||||
	  EVP_PKEY *key, unsigned char *sigin, int siglen, const char *title,
 | 
								EVP_PKEY *key, unsigned char *sigin, int siglen)
 | 
				
			||||||
	  const char *file,BIO *bmd,const char *hmac_key, int non_fips_allow)
 | 
					 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	unsigned int len;
 | 
						int len;
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	EVP_MD_CTX *md_ctx;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (hmac_key)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		EVP_MD *md;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		BIO_get_md(bmd,&md);
 | 
					 | 
				
			||||||
		HMAC_CTX_init(&hmac_ctx);
 | 
					 | 
				
			||||||
		if (non_fips_allow)
 | 
					 | 
				
			||||||
			HMAC_CTX_set_flags(&hmac_ctx,
 | 
					 | 
				
			||||||
					EVP_MD_CTX_FLAG_NON_FIPS_ALLOW);
 | 
					 | 
				
			||||||
		HMAC_Init_ex(&hmac_ctx,hmac_key,strlen(hmac_key),md, NULL);
 | 
					 | 
				
			||||||
		BIO_get_md_ctx(bmd,&md_ctx);
 | 
					 | 
				
			||||||
		BIO_set_md_ctx(bmd,&hmac_ctx.md_ctx);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	for (;;)
 | 
						for (;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		i=BIO_read(bp,(char *)buf,BUFSIZE);
 | 
							i=BIO_read(bp,(char *)buf,BUFSIZE);
 | 
				
			||||||
		if(i < 0)
 | 
							if (i <= 0) break;
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Read Error in %s\n",file);
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			return 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (i == 0) break;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if(sigin)
 | 
						if(sigin)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		EVP_MD_CTX *ctx;
 | 
							EVP_MD_CTX *ctx;
 | 
				
			||||||
		BIO_get_md_ctx(bp, &ctx);
 | 
							BIO_get_md_ctx(bp, &ctx);
 | 
				
			||||||
		i = EVP_VerifyFinal(ctx, sigin, (unsigned int)siglen, key); 
 | 
							i = EVP_VerifyFinal(ctx, sigin, (unsigned int)siglen, key); 
 | 
				
			||||||
		if(i > 0)
 | 
							if(i > 0) BIO_printf(out, "Verified OK\n");
 | 
				
			||||||
			BIO_printf(out, "Verified OK\n");
 | 
							else if(i == 0) BIO_printf(out, "Verification Failure\n");
 | 
				
			||||||
		else if(i == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(out, "Verification Failure\n");
 | 
					 | 
				
			||||||
			return 1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error Verifying Data\n");
 | 
								BIO_printf(bio_err, "Error Verifying Data\n");
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
			return 1;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		return 0;
 | 
							return;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if(key)
 | 
						if(key)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -478,22 +386,16 @@ int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error Signing Data\n");
 | 
								BIO_printf(bio_err, "Error Signing Data\n");
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
			return 1;
 | 
								return;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else if(hmac_key)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		HMAC_Final(&hmac_ctx,buf,&len);
 | 
					 | 
				
			||||||
		HMAC_CTX_cleanup(&hmac_ctx);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		len=BIO_gets(bp,(char *)buf,BUFSIZE);
 | 
							len=BIO_gets(bp,(char *)buf,BUFSIZE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(binout) BIO_write(out, buf, len);
 | 
						if(binout) BIO_write(out, buf, len);
 | 
				
			||||||
	else 
 | 
						else 
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_write(out,title,strlen(title));
 | 
							for (i=0; i<len; i++)
 | 
				
			||||||
		for (i=0; (unsigned int)i<len; i++)
 | 
					 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (sep && (i != 0))
 | 
								if (sep && (i != 0))
 | 
				
			||||||
				BIO_printf(out, ":");
 | 
									BIO_printf(out, ":");
 | 
				
			||||||
@@ -501,10 +403,5 @@ int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		BIO_printf(out, "\n");
 | 
							BIO_printf(out, "\n");
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (hmac_key)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_set_md_ctx(bmd,md_ctx);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										17
									
								
								apps/dh.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								apps/dh.c
									
									
									
									
									
								
							@@ -87,17 +87,12 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	DH *dh=NULL;
 | 
						DH *dh=NULL;
 | 
				
			||||||
	int i,badops=0,text=0;
 | 
						int i,badops=0,text=0;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
	int informat,outformat,check=0,noout=0,C=0,ret=1;
 | 
						int informat,outformat,check=0,noout=0,C=0,ret=1;
 | 
				
			||||||
	char *infile,*outfile,*prog;
 | 
						char *infile,*outfile,*prog,*engine;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -108,9 +103,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if (!load_config(bio_err, NULL))
 | 
						if (!load_config(bio_err, NULL))
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	engine=NULL;
 | 
						engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	infile=NULL;
 | 
						infile=NULL;
 | 
				
			||||||
	outfile=NULL;
 | 
						outfile=NULL;
 | 
				
			||||||
	informat=FORMAT_PEM;
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
@@ -141,13 +134,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			outfile= *(++argv);
 | 
								outfile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-check") == 0)
 | 
							else if (strcmp(*argv,"-check") == 0)
 | 
				
			||||||
			check=1;
 | 
								check=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-text") == 0)
 | 
							else if (strcmp(*argv,"-text") == 0)
 | 
				
			||||||
@@ -179,17 +170,13 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -text         print a text form of the DH parameters\n");
 | 
							BIO_printf(bio_err," -text         print a text form of the DH parameters\n");
 | 
				
			||||||
		BIO_printf(bio_err," -C            Output C code\n");
 | 
							BIO_printf(bio_err," -C            Output C code\n");
 | 
				
			||||||
		BIO_printf(bio_err," -noout        no output\n");
 | 
							BIO_printf(bio_err," -noout        no output\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	in=BIO_new(BIO_s_file());
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
	out=BIO_new(BIO_s_file());
 | 
						out=BIO_new(BIO_s_file());
 | 
				
			||||||
@@ -346,6 +333,6 @@ end:
 | 
				
			|||||||
	if (out != NULL) BIO_free_all(out);
 | 
						if (out != NULL) BIO_free_all(out);
 | 
				
			||||||
	if (dh != NULL) DH_free(dh);
 | 
						if (dh != NULL) DH_free(dh);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -148,9 +148,7 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	DH *dh=NULL;
 | 
						DH *dh=NULL;
 | 
				
			||||||
	int i,badops=0,text=0;
 | 
						int i,badops=0,text=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
@@ -159,10 +157,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
	int informat,outformat,check=0,noout=0,C=0,ret=1;
 | 
						int informat,outformat,check=0,noout=0,C=0,ret=1;
 | 
				
			||||||
	char *infile,*outfile,*prog;
 | 
						char *infile,*outfile,*prog;
 | 
				
			||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL,*engine=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int num = 0, g = 0;
 | 
						int num = 0, g = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
@@ -204,13 +199,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			outfile= *(++argv);
 | 
								outfile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-check") == 0)
 | 
							else if (strcmp(*argv,"-check") == 0)
 | 
				
			||||||
			check=1;
 | 
								check=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-text") == 0)
 | 
							else if (strcmp(*argv,"-text") == 0)
 | 
				
			||||||
@@ -256,9 +249,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -2            generate parameters using  2 as the generator value\n");
 | 
							BIO_printf(bio_err," -2            generate parameters using  2 as the generator value\n");
 | 
				
			||||||
		BIO_printf(bio_err," -5            generate parameters using  5 as the generator value\n");
 | 
							BIO_printf(bio_err," -5            generate parameters using  5 as the generator value\n");
 | 
				
			||||||
		BIO_printf(bio_err," numbits       number of bits in to generate (default 512)\n");
 | 
							BIO_printf(bio_err," numbits       number of bits in to generate (default 512)\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
							BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
		BIO_printf(bio_err,"               - load the file (or the files in the directory) into\n");
 | 
							BIO_printf(bio_err,"               - load the file (or the files in the directory) into\n");
 | 
				
			||||||
		BIO_printf(bio_err,"               the random number generator\n");
 | 
							BIO_printf(bio_err,"               the random number generator\n");
 | 
				
			||||||
@@ -268,9 +259,7 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (g && !num)
 | 
						if (g && !num)
 | 
				
			||||||
		num = DEFBITS;
 | 
							num = DEFBITS;
 | 
				
			||||||
@@ -530,7 +519,7 @@ end:
 | 
				
			|||||||
	if (out != NULL) BIO_free_all(out);
 | 
						if (out != NULL) BIO_free_all(out);
 | 
				
			||||||
	if (dh != NULL) DH_free(dh);
 | 
						if (dh != NULL) DH_free(dh);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* dh_cb is identical to dsa_cb in apps/dsaparam.c */
 | 
					/* dh_cb is identical to dsa_cb in apps/dsaparam.c */
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										17
									
								
								apps/dsa.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								apps/dsa.c
									
									
									
									
									
								
							@@ -90,9 +90,7 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int ret=1;
 | 
						int ret=1;
 | 
				
			||||||
	DSA *dsa=NULL;
 | 
						DSA *dsa=NULL;
 | 
				
			||||||
	int i,badops=0;
 | 
						int i,badops=0;
 | 
				
			||||||
@@ -100,10 +98,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
	int informat,outformat,text=0,noout=0;
 | 
						int informat,outformat,text=0,noout=0;
 | 
				
			||||||
	int pubin = 0, pubout = 0;
 | 
						int pubin = 0, pubout = 0;
 | 
				
			||||||
	char *infile,*outfile,*prog;
 | 
						char *infile,*outfile,*prog,*engine;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *passargin = NULL, *passargout = NULL;
 | 
						char *passargin = NULL, *passargout = NULL;
 | 
				
			||||||
	char *passin = NULL, *passout = NULL;
 | 
						char *passin = NULL, *passout = NULL;
 | 
				
			||||||
	int modulus=0;
 | 
						int modulus=0;
 | 
				
			||||||
@@ -117,9 +112,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if (!load_config(bio_err, NULL))
 | 
						if (!load_config(bio_err, NULL))
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	engine=NULL;
 | 
						engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	infile=NULL;
 | 
						infile=NULL;
 | 
				
			||||||
	outfile=NULL;
 | 
						outfile=NULL;
 | 
				
			||||||
	informat=FORMAT_PEM;
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
@@ -160,13 +153,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			passargout= *(++argv);
 | 
								passargout= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-noout") == 0)
 | 
							else if (strcmp(*argv,"-noout") == 0)
 | 
				
			||||||
			noout=1;
 | 
								noout=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-text") == 0)
 | 
							else if (strcmp(*argv,"-text") == 0)
 | 
				
			||||||
@@ -198,9 +189,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -passin arg     input file pass phrase source\n");
 | 
							BIO_printf(bio_err," -passin arg     input file pass phrase source\n");
 | 
				
			||||||
		BIO_printf(bio_err," -out arg        output file\n");
 | 
							BIO_printf(bio_err," -out arg        output file\n");
 | 
				
			||||||
		BIO_printf(bio_err," -passout arg    output file pass phrase source\n");
 | 
							BIO_printf(bio_err," -passout arg    output file pass phrase source\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -des            encrypt PEM output with cbc des\n");
 | 
							BIO_printf(bio_err," -des            encrypt PEM output with cbc des\n");
 | 
				
			||||||
		BIO_printf(bio_err," -des3           encrypt PEM output with ede cbc des using 168 bit key\n");
 | 
							BIO_printf(bio_err," -des3           encrypt PEM output with ede cbc des using 168 bit key\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_IDEA
 | 
					#ifndef OPENSSL_NO_IDEA
 | 
				
			||||||
@@ -218,9 +207,7 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) {
 | 
						if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) {
 | 
				
			||||||
		BIO_printf(bio_err, "Error getting passwords\n");
 | 
							BIO_printf(bio_err, "Error getting passwords\n");
 | 
				
			||||||
@@ -327,6 +314,6 @@ end:
 | 
				
			|||||||
	if(passin) OPENSSL_free(passin);
 | 
						if(passin) OPENSSL_free(passin);
 | 
				
			||||||
	if(passout) OPENSSL_free(passout);
 | 
						if(passout) OPENSSL_free(passout);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -90,9 +90,7 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	DSA *dsa=NULL;
 | 
						DSA *dsa=NULL;
 | 
				
			||||||
	int i,badops=0,text=0;
 | 
						int i,badops=0,text=0;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
@@ -100,9 +98,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *infile,*outfile,*prog,*inrand=NULL;
 | 
						char *infile,*outfile,*prog,*inrand=NULL;
 | 
				
			||||||
	int numbits= -1,num,genkey=0;
 | 
						int numbits= -1,num,genkey=0;
 | 
				
			||||||
	int need_rand=0;
 | 
						int need_rand=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -143,13 +139,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			outfile= *(++argv);
 | 
								outfile= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if(strcmp(*argv, "-engine") == 0)
 | 
							else if(strcmp(*argv, "-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine = *(++argv);
 | 
								engine = *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-text") == 0)
 | 
							else if (strcmp(*argv,"-text") == 0)
 | 
				
			||||||
			text=1;
 | 
								text=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-C") == 0)
 | 
							else if (strcmp(*argv,"-C") == 0)
 | 
				
			||||||
@@ -197,9 +191,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -noout        no output\n");
 | 
							BIO_printf(bio_err," -noout        no output\n");
 | 
				
			||||||
		BIO_printf(bio_err," -genkey       generate a DSA key\n");
 | 
							BIO_printf(bio_err," -genkey       generate a DSA key\n");
 | 
				
			||||||
		BIO_printf(bio_err," -rand         files to use for random number input\n");
 | 
							BIO_printf(bio_err," -rand         files to use for random number input\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," number        number of bits to use for generating private key\n");
 | 
							BIO_printf(bio_err," number        number of bits to use for generating private key\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -243,9 +235,7 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (need_rand)
 | 
						if (need_rand)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -382,7 +372,7 @@ end:
 | 
				
			|||||||
	if (out != NULL) BIO_free_all(out);
 | 
						if (out != NULL) BIO_free_all(out);
 | 
				
			||||||
	if (dsa != NULL) DSA_free(dsa);
 | 
						if (dsa != NULL) DSA_free(dsa);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void MS_CALLBACK dsa_cb(int p, int n, void *arg)
 | 
					static void MS_CALLBACK dsa_cb(int p, int n, void *arg)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										445
									
								
								apps/ecdsa.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										445
									
								
								apps/ecdsa.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,445 @@
 | 
				
			|||||||
 | 
					/* apps/ecdsa.c */
 | 
				
			||||||
 | 
					/* ====================================================================
 | 
				
			||||||
 | 
					 * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
 | 
					 * are met:
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 1. Redistributions of source code must retain the above copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer. 
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 2. Redistributions in binary form must reproduce the above copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer in
 | 
				
			||||||
 | 
					 *    the documentation and/or other materials provided with the
 | 
				
			||||||
 | 
					 *    distribution.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 3. All advertising materials mentioning features or use of this
 | 
				
			||||||
 | 
					 *    software must display the following acknowledgment:
 | 
				
			||||||
 | 
					 *    "This product includes software developed by the OpenSSL Project
 | 
				
			||||||
 | 
					 *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
 | 
				
			||||||
 | 
					 *    endorse or promote products derived from this software without
 | 
				
			||||||
 | 
					 *    prior written permission. For written permission, please contact
 | 
				
			||||||
 | 
					 *    openssl-core@openssl.org.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 5. Products derived from this software may not be called "OpenSSL"
 | 
				
			||||||
 | 
					 *    nor may "OpenSSL" appear in their names without prior written
 | 
				
			||||||
 | 
					 *    permission of the OpenSSL Project.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 6. Redistributions of any form whatsoever must retain the following
 | 
				
			||||||
 | 
					 *    acknowledgment:
 | 
				
			||||||
 | 
					 *    "This product includes software developed by the OpenSSL Project
 | 
				
			||||||
 | 
					 *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
 | 
				
			||||||
 | 
					 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
				
			||||||
 | 
					 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 | 
				
			||||||
 | 
					 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
 | 
				
			||||||
 | 
					 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 | 
				
			||||||
 | 
					 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 | 
				
			||||||
 | 
					 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | 
				
			||||||
 | 
					 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | 
				
			||||||
 | 
					 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 | 
				
			||||||
 | 
					 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 | 
				
			||||||
 | 
					 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 | 
				
			||||||
 | 
					 * OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
				
			||||||
 | 
					 * ====================================================================
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This product includes cryptographic software written by Eric Young
 | 
				
			||||||
 | 
					 * (eay@cryptsoft.com).  This product includes software written by Tim
 | 
				
			||||||
 | 
					 * Hudson (tjh@cryptsoft.com).
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
 | 
				
			||||||
 | 
					 * All rights reserved.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This package is an SSL implementation written
 | 
				
			||||||
 | 
					 * by Eric Young (eay@cryptsoft.com).
 | 
				
			||||||
 | 
					 * The implementation was written so as to conform with Netscapes SSL.
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * This library is free for commercial and non-commercial use as long as
 | 
				
			||||||
 | 
					 * the following conditions are aheared to.  The following conditions
 | 
				
			||||||
 | 
					 * apply to all code found in this distribution, be it the RC4, RSA,
 | 
				
			||||||
 | 
					 * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
 | 
				
			||||||
 | 
					 * included with this distribution is covered by the same copyright terms
 | 
				
			||||||
 | 
					 * except that the holder is Tim Hudson (tjh@cryptsoft.com).
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * Copyright remains Eric Young's, and as such any Copyright notices in
 | 
				
			||||||
 | 
					 * the code are not to be removed.
 | 
				
			||||||
 | 
					 * If this package is used in a product, Eric Young should be given attribution
 | 
				
			||||||
 | 
					 * as the author of the parts of the library used.
 | 
				
			||||||
 | 
					 * This can be in the form of a textual message at program startup or
 | 
				
			||||||
 | 
					 * in documentation (online or textual) provided with the package.
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
 | 
					 * are met:
 | 
				
			||||||
 | 
					 * 1. Redistributions of source code must retain the copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer.
 | 
				
			||||||
 | 
					 * 2. Redistributions in binary form must reproduce the above copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer in the
 | 
				
			||||||
 | 
					 *    documentation and/or other materials provided with the distribution.
 | 
				
			||||||
 | 
					 * 3. All advertising materials mentioning features or use of this software
 | 
				
			||||||
 | 
					 *    must display the following acknowledgement:
 | 
				
			||||||
 | 
					 *    "This product includes cryptographic software written by
 | 
				
			||||||
 | 
					 *     Eric Young (eay@cryptsoft.com)"
 | 
				
			||||||
 | 
					 *    The word 'cryptographic' can be left out if the rouines from the library
 | 
				
			||||||
 | 
					 *    being used are not cryptographic related :-).
 | 
				
			||||||
 | 
					 * 4. If you include any Windows specific code (or a derivative thereof) from 
 | 
				
			||||||
 | 
					 *    the apps directory (application code) you must include an acknowledgement:
 | 
				
			||||||
 | 
					 *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
 | 
				
			||||||
 | 
					 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
				
			||||||
 | 
					 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 | 
				
			||||||
 | 
					 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
 | 
				
			||||||
 | 
					 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | 
				
			||||||
 | 
					 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 | 
				
			||||||
 | 
					 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | 
				
			||||||
 | 
					 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 | 
				
			||||||
 | 
					 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 | 
				
			||||||
 | 
					 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 | 
				
			||||||
 | 
					 * SUCH DAMAGE.
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * The licence and distribution terms for any publically available version or
 | 
				
			||||||
 | 
					 * derivative of this code cannot be changed.  i.e. this code cannot simply be
 | 
				
			||||||
 | 
					 * copied and put under another distribution licence
 | 
				
			||||||
 | 
					 * [including the GNU Public Licence.]
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
					#include <stdio.h>
 | 
				
			||||||
 | 
					#include <stdlib.h>
 | 
				
			||||||
 | 
					#include <string.h>
 | 
				
			||||||
 | 
					#include <time.h>
 | 
				
			||||||
 | 
					#include "apps.h"
 | 
				
			||||||
 | 
					#include <openssl/bio.h>
 | 
				
			||||||
 | 
					#include <openssl/err.h>
 | 
				
			||||||
 | 
					#include <openssl/ecdsa.h>
 | 
				
			||||||
 | 
					#include <openssl/evp.h>
 | 
				
			||||||
 | 
					#include <openssl/x509.h>
 | 
				
			||||||
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#undef PROG
 | 
				
			||||||
 | 
					#define PROG	ecdsa_main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* -inform arg	- input format - default PEM (one of DER, NET or PEM)
 | 
				
			||||||
 | 
					 * -outform arg - output format - default PEM
 | 
				
			||||||
 | 
					 * -in arg	- input file - default stdin
 | 
				
			||||||
 | 
					 * -out arg	- output file - default stdout
 | 
				
			||||||
 | 
					 * -des		- encrypt output if PEM format with DES in cbc mode
 | 
				
			||||||
 | 
					 * -des3	- encrypt output if PEM format
 | 
				
			||||||
 | 
					 * -idea	- encrypt output if PEM format
 | 
				
			||||||
 | 
					 * -aes128	- encrypt output if PEM format
 | 
				
			||||||
 | 
					 * -aes192	- encrypt output if PEM format
 | 
				
			||||||
 | 
					 * -aes256	- encrypt output if PEM format
 | 
				
			||||||
 | 
					 * -text	- print a text version
 | 
				
			||||||
 | 
					 * -pub		- print the ECDSA public key
 | 
				
			||||||
 | 
					 * -compressed  - print the public key in compressed form ( default )   
 | 
				
			||||||
 | 
					 * -hybrid 	- print the public key in hybrid form
 | 
				
			||||||
 | 
					 * -uncompressed - print the public key in uncompressed form
 | 
				
			||||||
 | 
					 *		  the last three options ( compressed, hybrid and uncompressed )
 | 
				
			||||||
 | 
					 *		  are only used if the "-pub" option is also selected.
 | 
				
			||||||
 | 
					 *	  	  For a precise description of the the meaning of compressed,
 | 
				
			||||||
 | 
					 *		  hybrid and uncompressed please refer to the X9.62 standart.
 | 
				
			||||||
 | 
					 *		  All three forms represents ways to express the ecdsa public
 | 
				
			||||||
 | 
					 *		  key ( a point on a elliptic curve ) as octet string. Let len be
 | 
				
			||||||
 | 
					 *		  the length ( in bytes ) of an element of the field over which
 | 
				
			||||||
 | 
					 *		  the curve is defined, then a compressed octet string has the form
 | 
				
			||||||
 | 
					 *		  0x02 + result of BN_bn2bin() of the x coordinate of the public key
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						ENGINE 	*e = NULL;
 | 
				
			||||||
 | 
						int 	ret = 1;
 | 
				
			||||||
 | 
						ECDSA 	*ecdsa = NULL;
 | 
				
			||||||
 | 
						int 	i, badops = 0;
 | 
				
			||||||
 | 
						const EVP_CIPHER *enc = NULL;
 | 
				
			||||||
 | 
						BIO 	*in = NULL, *out = NULL;
 | 
				
			||||||
 | 
						int 	informat, outformat, text=0, noout=0;
 | 
				
			||||||
 | 
						int  	pubin = 0, pubout = 0;
 | 
				
			||||||
 | 
						char 	*infile, *outfile, *prog, *engine;
 | 
				
			||||||
 | 
						char 	*passargin = NULL, *passargout = NULL;
 | 
				
			||||||
 | 
						char 	*passin = NULL, *passout = NULL;
 | 
				
			||||||
 | 
						int 	pub = 0, point_form = 0;
 | 
				
			||||||
 | 
						unsigned char *buffer = NULL;
 | 
				
			||||||
 | 
						unsigned int  buf_len = 0;
 | 
				
			||||||
 | 
						BIGNUM	*tmp_bn = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (bio_err == NULL)
 | 
				
			||||||
 | 
							if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
				
			||||||
 | 
								BIO_set_fp(bio_err, stderr, BIO_NOCLOSE|BIO_FP_TEXT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!load_config(bio_err, NULL))
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						engine = NULL;
 | 
				
			||||||
 | 
						infile = NULL;
 | 
				
			||||||
 | 
						outfile = NULL;
 | 
				
			||||||
 | 
						informat = FORMAT_PEM;
 | 
				
			||||||
 | 
						outformat = FORMAT_PEM;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						prog = argv[0];
 | 
				
			||||||
 | 
						argc--;
 | 
				
			||||||
 | 
						argv++;
 | 
				
			||||||
 | 
						while (argc >= 1)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (strcmp(*argv,"-inform") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								informat=str2fmt(*(++argv));
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-outform") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								outformat=str2fmt(*(++argv));
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-in") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								infile= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-out") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								outfile= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-passin") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								passargin= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-passout") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								passargout= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-engine") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								engine= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-noout") == 0)
 | 
				
			||||||
 | 
								noout = 1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-text") == 0)
 | 
				
			||||||
 | 
								text = 1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-pub") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								pub = 1;
 | 
				
			||||||
 | 
								buffer = (unsigned char *)(*(argv+1));
 | 
				
			||||||
 | 
								if (strcmp((char *)buffer, "compressed") == 0)
 | 
				
			||||||
 | 
									point_form = POINT_CONVERSION_COMPRESSED;
 | 
				
			||||||
 | 
								else if (strcmp((char *)buffer, "hybrid") == 0)
 | 
				
			||||||
 | 
									point_form = POINT_CONVERSION_HYBRID;
 | 
				
			||||||
 | 
								else if (strcmp((char *)buffer, "uncompressed") == 0)
 | 
				
			||||||
 | 
									point_form = POINT_CONVERSION_UNCOMPRESSED;
 | 
				
			||||||
 | 
								if (point_form)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									argc--;
 | 
				
			||||||
 | 
									argv++;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-pubin") == 0)
 | 
				
			||||||
 | 
								pubin=1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-pubout") == 0)
 | 
				
			||||||
 | 
								pubout=1;
 | 
				
			||||||
 | 
							else if ((enc=EVP_get_cipherbyname(&(argv[0][1]))) == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
				
			||||||
 | 
								badops=1;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							argc--;
 | 
				
			||||||
 | 
							argv++;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (badops)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					bad:
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "%s [options] <infile >outfile\n",prog);
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "where options are\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -inform arg     input format - DER or PEM\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -outform arg    output format - DER or PEM\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -in arg         input file\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -passin arg     input file pass phrase source\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -out arg        output file\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -passout arg    output file pass phrase source\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -des            encrypt PEM output with cbc des\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -des3           encrypt PEM output with ede cbc des using 168 bit key\n");
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_IDEA
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -idea           encrypt PEM output with cbc idea\n");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_AES
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -aes128, -aes192, -aes256\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "                 encrypt PEM output with cbc aes\n");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -text           print the key in text\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -noout          don't print key out\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, " -pub [compressed | hybrid | uncompressed] \n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "         compressed     print the public key in compressed form ( default )\n");   
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "         hybrid         print the public key in hybrid form\n");
 | 
				
			||||||
 | 
					 		BIO_printf(bio_err, "         uncompressed   print the public key in uncompressed form\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) 
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "Error getting passwords\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						in = BIO_new(BIO_s_file());
 | 
				
			||||||
 | 
						out = BIO_new(BIO_s_file());
 | 
				
			||||||
 | 
						if ((in == NULL) || (out == NULL))
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (infile == NULL)
 | 
				
			||||||
 | 
							BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (BIO_read_filename(in,infile) <= 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror(infile);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						BIO_printf(bio_err,"read ECDSA key\n");
 | 
				
			||||||
 | 
						if (informat == FORMAT_ASN1) 
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (pubin) 
 | 
				
			||||||
 | 
								ecdsa = d2i_ECDSA_PUBKEY_bio(in, NULL);
 | 
				
			||||||
 | 
							else 
 | 
				
			||||||
 | 
								ecdsa = d2i_ECDSAPrivateKey_bio(in, NULL);
 | 
				
			||||||
 | 
						} else if (informat == FORMAT_PEM) 
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (pubin) 
 | 
				
			||||||
 | 
								ecdsa = PEM_read_bio_ECDSA_PUBKEY(in, NULL, NULL, NULL);
 | 
				
			||||||
 | 
							else 
 | 
				
			||||||
 | 
								ecdsa = PEM_read_bio_ECDSAPrivateKey(in, NULL, NULL, passin);
 | 
				
			||||||
 | 
						} else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "bad input format specified for key\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (ecdsa == NULL)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"unable to load Key\n");
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (outfile == NULL)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_set_fp(out, stdout, BIO_NOCLOSE);
 | 
				
			||||||
 | 
					#ifdef OPENSSL_SYS_VMS
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
				
			||||||
 | 
								out = BIO_push(tmpbio, out);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (BIO_write_filename(out, outfile) <= 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror(outfile);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (text) 
 | 
				
			||||||
 | 
							if (!ECDSA_print(out, ecdsa, 0))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror(outfile);
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (pub)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							fprintf(stdout, "Public Key (");
 | 
				
			||||||
 | 
							if (point_form == POINT_CONVERSION_COMPRESSED)
 | 
				
			||||||
 | 
								fprintf(stdout, "COMPRESSED");
 | 
				
			||||||
 | 
							else if (point_form == POINT_CONVERSION_UNCOMPRESSED)
 | 
				
			||||||
 | 
								fprintf(stdout, "UNCOMPRESSED");
 | 
				
			||||||
 | 
							else if (point_form == POINT_CONVERSION_HYBRID)
 | 
				
			||||||
 | 
								fprintf(stdout, "HYBRID");
 | 
				
			||||||
 | 
							fprintf(stdout, ")=");
 | 
				
			||||||
 | 
							buf_len = EC_POINT_point2oct(ecdsa->group, EC_GROUP_get0_generator(ecdsa->group),
 | 
				
			||||||
 | 
										     point_form, NULL, 0, NULL);
 | 
				
			||||||
 | 
							if (!buf_len)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"invalid public key length\n");
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if ((tmp_bn = BN_new()) == NULL ||
 | 
				
			||||||
 | 
							    (buffer = OPENSSL_malloc(buf_len)) == NULL) goto end;
 | 
				
			||||||
 | 
							if (!EC_POINT_point2oct(ecdsa->group, EC_GROUP_get0_generator(ecdsa->group),
 | 
				
			||||||
 | 
										     point_form, buffer, buf_len, NULL) ||
 | 
				
			||||||
 | 
							    !BN_bin2bn(buffer, buf_len, tmp_bn))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"can not encode public key\n");
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								OPENSSL_free(buffer);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							BN_print(out, tmp_bn);
 | 
				
			||||||
 | 
							fprintf(stdout,"\n");
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (noout) 
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						BIO_printf(bio_err, "writing ECDSA key\n");
 | 
				
			||||||
 | 
						if (outformat == FORMAT_ASN1) 
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if(pubin || pubout) 
 | 
				
			||||||
 | 
								i = i2d_ECDSA_PUBKEY_bio(out, ecdsa);
 | 
				
			||||||
 | 
							else 
 | 
				
			||||||
 | 
								i = i2d_ECDSAPrivateKey_bio(out, ecdsa);
 | 
				
			||||||
 | 
						} else if (outformat == FORMAT_PEM) 
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if(pubin || pubout)
 | 
				
			||||||
 | 
								i = PEM_write_bio_ECDSA_PUBKEY(out, ecdsa);
 | 
				
			||||||
 | 
							else 
 | 
				
			||||||
 | 
								i = PEM_write_bio_ECDSAPrivateKey(out, ecdsa, enc,
 | 
				
			||||||
 | 
												NULL, 0, NULL, passout);
 | 
				
			||||||
 | 
						} else 
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "bad output format specified for outfile\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (!i)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "unable to write private key\n");
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							ret=0;
 | 
				
			||||||
 | 
					end:
 | 
				
			||||||
 | 
						if (in) 	BIO_free(in);
 | 
				
			||||||
 | 
						if (out)	BIO_free_all(out);
 | 
				
			||||||
 | 
						if (ecdsa) 	ECDSA_free(ecdsa);
 | 
				
			||||||
 | 
						if (tmp_bn)	BN_free(tmp_bn);
 | 
				
			||||||
 | 
						if (passin) 	OPENSSL_free(passin);
 | 
				
			||||||
 | 
						if (passout) 	OPENSSL_free(passout);
 | 
				
			||||||
 | 
						apps_shutdown();
 | 
				
			||||||
 | 
						EXIT(ret);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										660
									
								
								apps/ecdsaparam.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										660
									
								
								apps/ecdsaparam.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,660 @@
 | 
				
			|||||||
 | 
					/* apps/ecdsaparam.c */
 | 
				
			||||||
 | 
					/* ====================================================================
 | 
				
			||||||
 | 
					 * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
 | 
					 * are met:
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 1. Redistributions of source code must retain the above copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer. 
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 2. Redistributions in binary form must reproduce the above copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer in
 | 
				
			||||||
 | 
					 *    the documentation and/or other materials provided with the
 | 
				
			||||||
 | 
					 *    distribution.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 3. All advertising materials mentioning features or use of this
 | 
				
			||||||
 | 
					 *    software must display the following acknowledgment:
 | 
				
			||||||
 | 
					 *    "This product includes software developed by the OpenSSL Project
 | 
				
			||||||
 | 
					 *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
 | 
				
			||||||
 | 
					 *    endorse or promote products derived from this software without
 | 
				
			||||||
 | 
					 *    prior written permission. For written permission, please contact
 | 
				
			||||||
 | 
					 *    openssl-core@openssl.org.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 5. Products derived from this software may not be called "OpenSSL"
 | 
				
			||||||
 | 
					 *    nor may "OpenSSL" appear in their names without prior written
 | 
				
			||||||
 | 
					 *    permission of the OpenSSL Project.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 6. Redistributions of any form whatsoever must retain the following
 | 
				
			||||||
 | 
					 *    acknowledgment:
 | 
				
			||||||
 | 
					 *    "This product includes software developed by the OpenSSL Project
 | 
				
			||||||
 | 
					 *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
 | 
				
			||||||
 | 
					 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
				
			||||||
 | 
					 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 | 
				
			||||||
 | 
					 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
 | 
				
			||||||
 | 
					 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 | 
				
			||||||
 | 
					 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 | 
				
			||||||
 | 
					 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | 
				
			||||||
 | 
					 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | 
				
			||||||
 | 
					 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 | 
				
			||||||
 | 
					 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 | 
				
			||||||
 | 
					 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 | 
				
			||||||
 | 
					 * OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
				
			||||||
 | 
					 * ====================================================================
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This product includes cryptographic software written by Eric Young
 | 
				
			||||||
 | 
					 * (eay@cryptsoft.com).  This product includes software written by Tim
 | 
				
			||||||
 | 
					 * Hudson (tjh@cryptsoft.com).
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
 | 
				
			||||||
 | 
					 * All rights reserved.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This package is an SSL implementation written
 | 
				
			||||||
 | 
					 * by Eric Young (eay@cryptsoft.com).
 | 
				
			||||||
 | 
					 * The implementation was written so as to conform with Netscapes SSL.
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * This library is free for commercial and non-commercial use as long as
 | 
				
			||||||
 | 
					 * the following conditions are aheared to.  The following conditions
 | 
				
			||||||
 | 
					 * apply to all code found in this distribution, be it the RC4, RSA,
 | 
				
			||||||
 | 
					 * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
 | 
				
			||||||
 | 
					 * included with this distribution is covered by the same copyright terms
 | 
				
			||||||
 | 
					 * except that the holder is Tim Hudson (tjh@cryptsoft.com).
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * Copyright remains Eric Young's, and as such any Copyright notices in
 | 
				
			||||||
 | 
					 * the code are not to be removed.
 | 
				
			||||||
 | 
					 * If this package is used in a product, Eric Young should be given attribution
 | 
				
			||||||
 | 
					 * as the author of the parts of the library used.
 | 
				
			||||||
 | 
					 * This can be in the form of a textual message at program startup or
 | 
				
			||||||
 | 
					 * in documentation (online or textual) provided with the package.
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
 | 
					 * are met:
 | 
				
			||||||
 | 
					 * 1. Redistributions of source code must retain the copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer.
 | 
				
			||||||
 | 
					 * 2. Redistributions in binary form must reproduce the above copyright
 | 
				
			||||||
 | 
					 *    notice, this list of conditions and the following disclaimer in the
 | 
				
			||||||
 | 
					 *    documentation and/or other materials provided with the distribution.
 | 
				
			||||||
 | 
					 * 3. All advertising materials mentioning features or use of this software
 | 
				
			||||||
 | 
					 *    must display the following acknowledgement:
 | 
				
			||||||
 | 
					 *    "This product includes cryptographic software written by
 | 
				
			||||||
 | 
					 *     Eric Young (eay@cryptsoft.com)"
 | 
				
			||||||
 | 
					 *    The word 'cryptographic' can be left out if the rouines from the library
 | 
				
			||||||
 | 
					 *    being used are not cryptographic related :-).
 | 
				
			||||||
 | 
					 * 4. If you include any Windows specific code (or a derivative thereof) from 
 | 
				
			||||||
 | 
					 *    the apps directory (application code) you must include an acknowledgement:
 | 
				
			||||||
 | 
					 *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
 | 
				
			||||||
 | 
					 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
				
			||||||
 | 
					 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 | 
				
			||||||
 | 
					 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
 | 
				
			||||||
 | 
					 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | 
				
			||||||
 | 
					 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 | 
				
			||||||
 | 
					 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | 
				
			||||||
 | 
					 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 | 
				
			||||||
 | 
					 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 | 
				
			||||||
 | 
					 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 | 
				
			||||||
 | 
					 * SUCH DAMAGE.
 | 
				
			||||||
 | 
					 * 
 | 
				
			||||||
 | 
					 * The licence and distribution terms for any publically available version or
 | 
				
			||||||
 | 
					 * derivative of this code cannot be changed.  i.e. this code cannot simply be
 | 
				
			||||||
 | 
					 * copied and put under another distribution licence
 | 
				
			||||||
 | 
					 * [including the GNU Public Licence.]
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
					#include <assert.h>
 | 
				
			||||||
 | 
					#include <stdio.h>
 | 
				
			||||||
 | 
					#include <stdlib.h>
 | 
				
			||||||
 | 
					#include <time.h>
 | 
				
			||||||
 | 
					#include <string.h>
 | 
				
			||||||
 | 
					#include "apps.h"
 | 
				
			||||||
 | 
					#include <openssl/bio.h>
 | 
				
			||||||
 | 
					#include <openssl/err.h>
 | 
				
			||||||
 | 
					#include <openssl/bn.h>
 | 
				
			||||||
 | 
					#include <openssl/ec.h>
 | 
				
			||||||
 | 
					#include <openssl/ecdsa.h>
 | 
				
			||||||
 | 
					#include <openssl/x509.h>
 | 
				
			||||||
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#undef PROG
 | 
				
			||||||
 | 
					#define PROG	ecdsaparam_main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* -inform arg	  	- input format - default PEM (DER or PEM)
 | 
				
			||||||
 | 
					 * -outform arg 	- output format - default PEM
 | 
				
			||||||
 | 
					 * -in arg		- input file  - default stdin
 | 
				
			||||||
 | 
					 * -out arg		- output file - default stdout
 | 
				
			||||||
 | 
					 * -noout
 | 
				
			||||||
 | 
					 * -text
 | 
				
			||||||
 | 
					 * -check               - validate the ec parameters
 | 
				
			||||||
 | 
					 * -C
 | 
				
			||||||
 | 
					 * -noout
 | 
				
			||||||
 | 
					 * -genkey		- generate a private public keypair based on the supplied curve
 | 
				
			||||||
 | 
					 * -named_curve		- use the curve oid instead of the parameters
 | 
				
			||||||
 | 
					 * -NIST_192		- use the NIST recommended curve parameters over a 192 bit prime field
 | 
				
			||||||
 | 
					 * -NIST_224		- use the NIST recommended curve parameters over a 224 bit prime field
 | 
				
			||||||
 | 
					 * -NIST_256		- use the NIST recommended curve parameters over a 256 bit prime field
 | 
				
			||||||
 | 
					 * -NIST_384		- use the NIST recommended curve parameters over a 384 bit prime field
 | 
				
			||||||
 | 
					 * -NIST_521		- use the NIST recommended curve parameters over a 521 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_192v1		- use the X9_62 192v1 example curve over a 192 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_192v2		- use the X9_62 192v2 example curve over a 192 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_192v3		- use the X9_62 192v3 example curve over a 192 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_239v1		- use the X9_62 239v1 example curve over a 239 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_239v2		- use the X9_62 239v2 example curve over a 239 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_239v3		- use the X9_62 239v3 example curve over a 239 bit prime field
 | 
				
			||||||
 | 
					 * -X9_62_256v1		- use the X9_62 239v1 example curve over a 256 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_112R1    - use the SECG 112r1 recommended curve over a 112 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_112R2    - use the SECG 112r2 recommended curve over a 112 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_128R1    - use the SECG 128r1 recommended curve over a 128 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_128R2    - use the SECG 128r2 recommended curve over a 128 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_160K1    - use the SECG 160k1 recommended curve over a 160 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_160R1    - use the SECG 160r1 recommended curve over a 160 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_160R2    - use the SECG 160r2 recommended curve over a 160 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_192K1    - use the SECG 192k1 recommended curve over a 192 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_192R1    - use the SECG 192r1 recommended curve over a 192 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_224K1    - use the SECG 224k1 recommended curve over a 224 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_224R1    - use the SECG 224r1 recommended curve over a 224 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_256K1    - use the SECG 256k1 recommended curve over a 256 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_256R1    - use the SECG 256r1 recommended curve over a 256 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_384R1    - use the SECG 384r1 recommended curve over a 384 bit prime field
 | 
				
			||||||
 | 
					 * -SECG_PRIME_521R1    - use the SECG 521r1 recommended curve over a 521 bit prime field
 | 
				
			||||||
 | 
					 * -WTLS_6              - use the WAP/WTLS recommended curve number 6 over a 112 bit field
 | 
				
			||||||
 | 
					 * -WTLS_8              - use the WAP/WTLS recommended curve number 8 over a 112 bit field
 | 
				
			||||||
 | 
					 * -WTLS_9              - use the WAP/WTLS recommended curve number 9 over a 160 bit field
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						ENGINE 	*e = NULL;
 | 
				
			||||||
 | 
						ECDSA 	*ecdsa = NULL;
 | 
				
			||||||
 | 
						int 	i, badops = 0, text = 0;
 | 
				
			||||||
 | 
						BIO 	*in = NULL, *out = NULL;
 | 
				
			||||||
 | 
						int 	informat, outformat, noout = 0, C = 0, ret = 1;
 | 
				
			||||||
 | 
						char 	*infile, *outfile, *prog, *inrand = NULL;
 | 
				
			||||||
 | 
						int 	genkey = 0;
 | 
				
			||||||
 | 
						int	check = 0;
 | 
				
			||||||
 | 
						int 	need_rand = 0;
 | 
				
			||||||
 | 
						char 	*engine=NULL;
 | 
				
			||||||
 | 
						int	curve_type = EC_GROUP_NO_CURVE;
 | 
				
			||||||
 | 
						int	named_curve = 0;
 | 
				
			||||||
 | 
						BIGNUM	*tmp_1 = NULL, *tmp_2 = NULL, *tmp_3 = NULL, *tmp_4 = NULL, *tmp_5 = NULL,
 | 
				
			||||||
 | 
							*tmp_6 = NULL, *tmp_7 = NULL;
 | 
				
			||||||
 | 
						BN_CTX	*ctx = NULL;
 | 
				
			||||||
 | 
						EC_POINT *point = NULL;
 | 
				
			||||||
 | 
						unsigned char *data = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (bio_err == NULL)
 | 
				
			||||||
 | 
							if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
				
			||||||
 | 
								BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!load_config(bio_err, NULL))
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						infile=NULL;
 | 
				
			||||||
 | 
						outfile=NULL;
 | 
				
			||||||
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
 | 
						outformat=FORMAT_PEM;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						prog=argv[0];
 | 
				
			||||||
 | 
						argc--;
 | 
				
			||||||
 | 
						argv++;
 | 
				
			||||||
 | 
						while (argc >= 1)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							if 	(strcmp(*argv,"-inform") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								informat=str2fmt(*(++argv));
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-outform") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								outformat=str2fmt(*(++argv));
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-in") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								infile= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-out") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								outfile= *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if(strcmp(*argv, "-engine") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								engine = *(++argv);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-text") == 0)
 | 
				
			||||||
 | 
								text = 1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-C") == 0)
 | 
				
			||||||
 | 
								C = 1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-check") == 0)
 | 
				
			||||||
 | 
								check = 1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-genkey") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								genkey = 1;
 | 
				
			||||||
 | 
								need_rand = 1;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								inrand= *(++argv);
 | 
				
			||||||
 | 
								need_rand=1;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-named_curve") == 0)
 | 
				
			||||||
 | 
								named_curve = 1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-NIST_192") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_NIST_PRIME_192;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-NIST_224") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_NIST_PRIME_224;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-NIST_256") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_NIST_PRIME_256;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-NIST_384") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_NIST_PRIME_384;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-NIST_521") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_NIST_PRIME_521;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_192v1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_192V1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_192v2") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_192V2;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_192v3") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_192V3;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_239v1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_239V1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_239v2") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_239V2;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_239v3") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_239V3;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-X9_62_256v1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_X9_62_PRIME_256V1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_112R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_112R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_112R2") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_112R2;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_128R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_128R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_128R2") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_128R2;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_160K1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_160K1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_160R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_160R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_160R2") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_160R2;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_192K1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_192K1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_192R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_192R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_224K1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_224K1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_224R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_224R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_256K1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_256K1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_256R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_256R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_384R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_384R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-SECG_PRIME_521R1") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_SECG_PRIME_521R1;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-WTLS_6") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_WTLS_6;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-WTLS_8") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_WTLS_8;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-WTLS_9") == 0)
 | 
				
			||||||
 | 
								curve_type = EC_GROUP_WTLS_9;
 | 
				
			||||||
 | 
							else if (strcmp(*argv, "-noout") == 0)
 | 
				
			||||||
 | 
								noout=1;
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
				
			||||||
 | 
								badops=1;
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							argc--;
 | 
				
			||||||
 | 
							argv++;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (badops)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					bad:
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"%s [options] [bits] <infile >outfile\n",prog);
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"where options are\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -inform arg        input format - DER or PEM\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -outform arg       output format - DER or PEM\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -in arg            input file\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -out arg           output file\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -text              print as text\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -C                 Output C code\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -check             validate the ec parameters\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -noout             no output\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -rand              files to use for random number input\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -engine e          use engine e, possibly a hardware device.\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -named_curve       use the curve oid instead of the parameters\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -NIST_192          use the NIST recommended curve parameters over a 192 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -NIST_224          use the NIST recommended curve parameters over a 224 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -NIST_256          use the NIST recommended curve parameters over a 256 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -NIST_384          use the NIST recommended curve parameters over a 384 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -NIST_521          use the NIST recommended curve parameters over a 521 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_192v1       use the X9_62 192v1 example curve over a 192 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_192v2       use the X9_62 192v2 example curve over a 192 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_192v3       use the X9_62 192v3 example curve over a 192 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_239v1       use the X9_62 239v1 example curve over a 239 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_239v2       use the X9_62 239v2 example curve over a 239 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_239v3       use the X9_62 239v3 example curve over a 239 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -X9_62_256v1       use the X9_62 239v1 example curve over a 256 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_112R1  use the SECG 112r1 recommended curve over a 112 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_112R2  use the SECG 112r2 recommended curve over a 112 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_128R1  use the SECG 128r1 recommended curve over a 128 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_128R2  use the SECG 128r2 recommended curve over a 128 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_160K1  use the SECG 160k1 recommended curve over a 160 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_160R1  use the SECG 160r1 recommended curve over a 160 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_160R2  use the SECG 160r2 recommended curve over a 160 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_192K1  use the SECG 192k1 recommended curve over a 192 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_192R1  use the SECG 192r1 recommended curve over a 192 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_224K1  use the SECG 224k1 recommended curve over a 224 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_224R1  use the SECG 224r1 recommended curve over a 224 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_256K1  use the SECG 256k1 recommended curve over a 256 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_256R1  use the SECG 256r1 recommended curve over a 256 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_384R1  use the SECG 384r1 recommended curve over a 384 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -SECG_PRIME_521R1  use the SECG 521r1 recommended curve over a 521 bit prime field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -WTLS_6            use the WAP/WTLS recommended curve number 6 over a 112 bit field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -WTLS_8            use the WAP/WTLS recommended curve number 8 over a 112 bit field\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -WTLS_9            use the WAP/WTLS recommended curve number 9 over a 112 bit field\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
 | 
						out=BIO_new(BIO_s_file());
 | 
				
			||||||
 | 
						if ((in == NULL) || (out == NULL))
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (infile == NULL)
 | 
				
			||||||
 | 
							BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (BIO_read_filename(in,infile) <= 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror(infile);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (outfile == NULL)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_set_fp(out,stdout,BIO_NOCLOSE);
 | 
				
			||||||
 | 
					#ifdef OPENSSL_SYS_VMS
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
				
			||||||
 | 
							out = BIO_push(tmpbio, out);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (BIO_write_filename(out,outfile) <= 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror(outfile);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (need_rand)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							app_RAND_load_file(NULL, bio_err, (inrand != NULL));
 | 
				
			||||||
 | 
							if (inrand != NULL)
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"%ld semi-random bytes loaded\n",
 | 
				
			||||||
 | 
									app_RAND_load_files(inrand));
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (curve_type != EC_GROUP_NO_CURVE)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if ((ecdsa = ECDSA_new()) == NULL)
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							ecdsa->group = EC_GROUP_new_by_name(curve_type);
 | 
				
			||||||
 | 
							if (named_curve)
 | 
				
			||||||
 | 
								ECDSA_set_parameter_flags(ecdsa, ECDSA_FLAG_NAMED_CURVE);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else if (informat == FORMAT_ASN1)
 | 
				
			||||||
 | 
							ecdsa = d2i_ECDSAParameters_bio(in,NULL);
 | 
				
			||||||
 | 
						else if (informat == FORMAT_PEM)
 | 
				
			||||||
 | 
							ecdsa = PEM_read_bio_ECDSAParameters(in, NULL, NULL, NULL);
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "bad input format specified\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (ecdsa == NULL)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "unable to load ECDSA parameters\n");
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (text)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							ECDSAParameters_print(out, ecdsa);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (check)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (ecdsa == NULL)
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "no elliptic curve parameters\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "checking elliptic curve parameters: ");
 | 
				
			||||||
 | 
							if (!EC_GROUP_check(ecdsa->group, NULL))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "failed\n");
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "ok\n");
 | 
				
			||||||
 | 
								
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (C)
 | 
				
			||||||
 | 
						{	/* TODO: characteristic two */
 | 
				
			||||||
 | 
							int 	l, len, bits_p;
 | 
				
			||||||
 | 
							if ((tmp_1 = BN_new()) == NULL || (tmp_2 = BN_new()) == NULL ||
 | 
				
			||||||
 | 
							    (tmp_3 = BN_new()) == NULL || (tmp_4 = BN_new()) == NULL ||
 | 
				
			||||||
 | 
							    (tmp_5 = BN_new()) == NULL || (tmp_6 = BN_new()) == NULL ||
 | 
				
			||||||
 | 
					                    (tmp_7 = BN_new()) == NULL || (ctx = BN_CTX_new()) == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror("OPENSSL_malloc");
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if (!EC_GROUP_get_curve_GFp(ecdsa->group, tmp_1, tmp_2, tmp_3, ctx))
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							if ((point = EC_GROUP_get0_generator(ecdsa->group)) == NULL)
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							if (!EC_POINT_get_affine_coordinates_GFp(ecdsa->group, point, tmp_4, tmp_5, ctx))
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							if (!EC_GROUP_get_order(ecdsa->group, tmp_6, ctx))
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							if (!EC_GROUP_get_cofactor(ecdsa->group, tmp_7, ctx))
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							len    = BN_num_bytes(tmp_1);
 | 
				
			||||||
 | 
							bits_p = BN_num_bits(tmp_1);
 | 
				
			||||||
 | 
							data=(unsigned char *)OPENSSL_malloc(len+20);
 | 
				
			||||||
 | 
							if (data == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								perror("OPENSSL_malloc");
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_1, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_p[]={", bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_2, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_a[]={",bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_3, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_b[]={", bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_4, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_x[]={", bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_5, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_y[]={", bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_6, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_o[]={", bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							l = BN_bn2bin(tmp_7, data);
 | 
				
			||||||
 | 
							printf("static unsigned char ecdsa%d_c[]={", bits_p);
 | 
				
			||||||
 | 
							for (i=0; i<l; i++)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								if ((i%12) == 0) printf("\n\t");
 | 
				
			||||||
 | 
								printf("0x%02X,",data[i]);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							printf("\n\t};\n\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* FIXME:
 | 
				
			||||||
 | 
							 * generated code should check for errors
 | 
				
			||||||
 | 
							 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							printf("ECDSA *get_ecdsa%d(void)\n\t{\n",bits_p);
 | 
				
			||||||
 | 
							printf("\tint ok=0;\n");
 | 
				
			||||||
 | 
							printf("\tECDSA    *ecdsa=NULL;\n");
 | 
				
			||||||
 | 
							printf("\tEC_POINT *point=NULL;\n");
 | 
				
			||||||
 | 
							printf("\tBIGNUM   *tmp_1=NULL,*tmp_2=NULL,*tmp_3=NULL;\n\n");
 | 
				
			||||||
 | 
							printf("\tif ((ecdsa=ECDSA_new()) == NULL)\n");
 | 
				
			||||||
 | 
							printf("\t\treturn(NULL);\n\n");
 | 
				
			||||||
 | 
							printf("\t/* generate EC_GROUP structure */\n");
 | 
				
			||||||
 | 
							printf("\tif ((tmp_1 = BN_bin2bn(ecdsa%d_p, sizeof(ecdsa%d_p), NULL)) == NULL) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif ((tmp_2 = BN_bin2bn(ecdsa%d_a, sizeof(ecdsa%d_a), NULL)) == NULL) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif ((tmp_3 = BN_bin2bn(ecdsa%d_b, sizeof(ecdsa%d_b), NULL)) == NULL) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif ((ecdsa->group = EC_GROUP_new_curve_GFp(tmp_1, tmp_2, tmp_3, NULL)) == NULL) goto err;\n\n");
 | 
				
			||||||
 | 
							printf("\t/* build generator */\n");
 | 
				
			||||||
 | 
							printf("\tif (!BN_bin2bn(ecdsa%d_x, sizeof(ecdsa%d_x), tmp_1)) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif (!BN_bin2bn(ecdsa%d_y, sizeof(ecdsa%d_y), tmp_2)) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif ((point = EC_POINT_new(ecdsa->group)) == NULL) goto err;\n");
 | 
				
			||||||
 | 
							printf("\tif (!EC_POINT_set_affine_coordinates_GFp(ecdsa->group, point, tmp_1, tmp_2, NULL)) goto err;\n");
 | 
				
			||||||
 | 
							printf("\t/* set generator, order and cofactor */\n");
 | 
				
			||||||
 | 
							printf("\tif (!BN_bin2bn(ecdsa%d_o, sizeof(ecdsa%d_o), tmp_1)) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif (!BN_bin2bn(ecdsa%d_c, sizeof(ecdsa%d_c), tmp_2)) goto err;\n", bits_p, bits_p);
 | 
				
			||||||
 | 
							printf("\tif (!EC_GROUP_set_generator(ecdsa->group, point, tmp_1, tmp_2)) goto err;\n");
 | 
				
			||||||
 | 
							printf("\n\tok=1;\n");
 | 
				
			||||||
 | 
							printf("err:\n");
 | 
				
			||||||
 | 
							printf("\tif (tmp_1) BN_free(tmp_1);\n");
 | 
				
			||||||
 | 
							printf("\tif (tmp_2) BN_free(tmp_2);\n");
 | 
				
			||||||
 | 
							printf("\tif (tmp_3) BN_free(tmp_3);\n");
 | 
				
			||||||
 | 
							printf("\tif (point) EC_POINT_free(point);\n");
 | 
				
			||||||
 | 
							printf("\tif (!ok)\n");
 | 
				
			||||||
 | 
							printf("\t\t{\n");
 | 
				
			||||||
 | 
							printf("\t\tECDSA_free(ecdsa);\n");
 | 
				
			||||||
 | 
							printf("\t\tecdsa = NULL;\n");
 | 
				
			||||||
 | 
							printf("\t\t}\n");
 | 
				
			||||||
 | 
							printf("\treturn(ecdsa);\n\t}\n");
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!noout)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							if (outformat == FORMAT_ASN1)
 | 
				
			||||||
 | 
								i = i2d_ECDSAParameters_bio(out, ecdsa);
 | 
				
			||||||
 | 
							else if (outformat == FORMAT_PEM)
 | 
				
			||||||
 | 
								i = PEM_write_bio_ECDSAParameters(out, ecdsa);
 | 
				
			||||||
 | 
							else	
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"bad output format specified for outfile\n");
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if (!i)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "unable to write ECDSA parameters\n");
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (genkey)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							ECDSA *ecdsakey;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							assert(need_rand);
 | 
				
			||||||
 | 
							if ((ecdsakey = ECDSAParameters_dup(ecdsa)) == NULL) goto end;
 | 
				
			||||||
 | 
							if (!ECDSA_generate_key(ecdsakey)) goto end;
 | 
				
			||||||
 | 
							if (outformat == FORMAT_ASN1)
 | 
				
			||||||
 | 
								i = i2d_ECDSAPrivateKey_bio(out, ecdsakey);
 | 
				
			||||||
 | 
							else if (outformat == FORMAT_PEM)
 | 
				
			||||||
 | 
								i = PEM_write_bio_ECDSAPrivateKey(out, ecdsakey, NULL, NULL, 0, NULL, NULL);
 | 
				
			||||||
 | 
							else	
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "bad output format specified for outfile\n");
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							ECDSA_free(ecdsakey);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (need_rand)
 | 
				
			||||||
 | 
							app_RAND_write_file(NULL, bio_err);
 | 
				
			||||||
 | 
						ret=0;
 | 
				
			||||||
 | 
					end:
 | 
				
			||||||
 | 
						if (in != NULL) 	BIO_free(in);
 | 
				
			||||||
 | 
						if (out != NULL) 	BIO_free_all(out);
 | 
				
			||||||
 | 
						if (ecdsa != NULL) 	ECDSA_free(ecdsa);
 | 
				
			||||||
 | 
						if (tmp_1)		BN_free(tmp_1);
 | 
				
			||||||
 | 
						if (tmp_2)		BN_free(tmp_2);
 | 
				
			||||||
 | 
						if (tmp_3)		BN_free(tmp_3);
 | 
				
			||||||
 | 
						if (tmp_3)		BN_free(tmp_4);
 | 
				
			||||||
 | 
						if (tmp_3)		BN_free(tmp_5);
 | 
				
			||||||
 | 
						if (tmp_3)		BN_free(tmp_6);
 | 
				
			||||||
 | 
						if (tmp_3)		BN_free(tmp_7);
 | 
				
			||||||
 | 
						if (ctx)		BN_CTX_free(ctx);
 | 
				
			||||||
 | 
						if (data)		OPENSSL_free(data);
 | 
				
			||||||
 | 
						apps_shutdown();
 | 
				
			||||||
 | 
						EXIT(ret);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										119
									
								
								apps/enc.c
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								apps/enc.c
									
									
									
									
									
								
							@@ -78,7 +78,7 @@ int set_hex(char *in,unsigned char *out,int size);
 | 
				
			|||||||
#define BSIZE	(8*1024)
 | 
					#define BSIZE	(8*1024)
 | 
				
			||||||
#define	PROG	enc_main
 | 
					#define	PROG	enc_main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void show_ciphers(const OBJ_NAME *name,void *bio_)
 | 
					void show_ciphers(const OBJ_NAME *name,void *bio_)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BIO *bio=bio_;
 | 
						BIO *bio=bio_;
 | 
				
			||||||
	static int n;
 | 
						static int n;
 | 
				
			||||||
@@ -100,11 +100,9 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	static const char magic[]="Salted__";
 | 
						static const char magic[]="Salted__";
 | 
				
			||||||
	char mbuf[sizeof magic-1];
 | 
						char mbuf[8];	/* should be 1 smaller than magic */
 | 
				
			||||||
	char *strbuf=NULL;
 | 
						char *strbuf=NULL;
 | 
				
			||||||
	unsigned char *buff=NULL,*bufsize=NULL;
 | 
						unsigned char *buff=NULL,*bufsize=NULL;
 | 
				
			||||||
	int bsize=BSIZE,verbose=0;
 | 
						int bsize=BSIZE,verbose=0;
 | 
				
			||||||
@@ -114,20 +112,14 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	unsigned char salt[PKCS5_SALT_LEN];
 | 
						unsigned char salt[PKCS5_SALT_LEN];
 | 
				
			||||||
	char *str=NULL, *passarg = NULL, *pass = NULL;
 | 
						char *str=NULL, *passarg = NULL, *pass = NULL;
 | 
				
			||||||
	char *hkey=NULL,*hiv=NULL,*hsalt = NULL;
 | 
						char *hkey=NULL,*hiv=NULL,*hsalt = NULL;
 | 
				
			||||||
	char *md=NULL;
 | 
					 | 
				
			||||||
	int enc=1,printkey=0,i,base64=0;
 | 
						int enc=1,printkey=0,i,base64=0;
 | 
				
			||||||
	int debug=0,olb64=0,nosalt=0;
 | 
						int debug=0,olb64=0,nosalt=0;
 | 
				
			||||||
	const EVP_CIPHER *cipher=NULL,*c;
 | 
						const EVP_CIPHER *cipher=NULL,*c;
 | 
				
			||||||
	EVP_CIPHER_CTX *ctx = NULL;
 | 
					 | 
				
			||||||
	char *inf=NULL,*outf=NULL;
 | 
						char *inf=NULL,*outf=NULL;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL,*b64=NULL,*benc=NULL,*rbio=NULL,*wbio=NULL;
 | 
						BIO *in=NULL,*out=NULL,*b64=NULL,*benc=NULL,*rbio=NULL,*wbio=NULL;
 | 
				
			||||||
#define PROG_NAME_SIZE  39
 | 
					#define PROG_NAME_SIZE  39
 | 
				
			||||||
	char pname[PROG_NAME_SIZE+1];
 | 
						char pname[PROG_NAME_SIZE+1];
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine = NULL;
 | 
						char *engine = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	const EVP_MD *dgst=NULL;
 | 
					 | 
				
			||||||
	int non_fips_allow = 0;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -139,7 +131,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* first check the program name */
 | 
						/* first check the program name */
 | 
				
			||||||
	program_name(argv[0],pname,sizeof pname);
 | 
						program_name(argv[0],pname,PROG_NAME_SIZE);
 | 
				
			||||||
	if (strcmp(pname,"base64") == 0)
 | 
						if (strcmp(pname,"base64") == 0)
 | 
				
			||||||
		base64=1;
 | 
							base64=1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -171,13 +163,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			passarg= *(++argv);
 | 
								passarg= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-d") == 0)
 | 
							else if	(strcmp(*argv,"-d") == 0)
 | 
				
			||||||
			enc=0;
 | 
								enc=0;
 | 
				
			||||||
		else if	(strcmp(*argv,"-p") == 0)
 | 
							else if	(strcmp(*argv,"-p") == 0)
 | 
				
			||||||
@@ -226,7 +216,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			buf[0]='\0';
 | 
								buf[0]='\0';
 | 
				
			||||||
			fgets(buf,sizeof buf,infile);
 | 
								fgets(buf,128,infile);
 | 
				
			||||||
			fclose(infile);
 | 
								fclose(infile);
 | 
				
			||||||
			i=strlen(buf);
 | 
								i=strlen(buf);
 | 
				
			||||||
			if ((i > 0) &&
 | 
								if ((i > 0) &&
 | 
				
			||||||
@@ -257,13 +247,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			hiv= *(++argv);
 | 
								hiv= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-md") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			md= *(++argv);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-non-fips-allow") == 0)
 | 
					 | 
				
			||||||
			non_fips_allow = 1;
 | 
					 | 
				
			||||||
		else if	((argv[0][0] == '-') &&
 | 
							else if	((argv[0][0] == '-') &&
 | 
				
			||||||
			((c=EVP_get_cipherbyname(&(argv[0][1]))) != NULL))
 | 
								((c=EVP_get_cipherbyname(&(argv[0][1]))) != NULL))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -282,16 +265,12 @@ bad:
 | 
				
			|||||||
			BIO_printf(bio_err,"%-14s encrypt\n","-e");
 | 
								BIO_printf(bio_err,"%-14s encrypt\n","-e");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s decrypt\n","-d");
 | 
								BIO_printf(bio_err,"%-14s decrypt\n","-d");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s base64 encode/decode, depending on encryption flag\n","-a/-base64");
 | 
								BIO_printf(bio_err,"%-14s base64 encode/decode, depending on encryption flag\n","-a/-base64");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s passphrase is the next argument\n","-k");
 | 
								BIO_printf(bio_err,"%-14s key is the next argument\n","-k");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s passphrase is the first line of the file argument\n","-kfile");
 | 
								BIO_printf(bio_err,"%-14s key is the first line of the file argument\n","-kfile");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s the next argument is the md to use to create a key\n","-md");
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"%-14s   from a passphrase.  One of md2, md5, sha or sha1\n","");
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"%-14s key/iv in hex is the next argument\n","-K/-iv");
 | 
								BIO_printf(bio_err,"%-14s key/iv in hex is the next argument\n","-K/-iv");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s print the iv/key (then exit if -P)\n","-[pP]");
 | 
								BIO_printf(bio_err,"%-14s print the iv/key (then exit if -P)\n","-[pP]");
 | 
				
			||||||
			BIO_printf(bio_err,"%-14s buffer size\n","-bufsize <n>");
 | 
								BIO_printf(bio_err,"%-14s buffer size\n","-bufsize <n>");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"%-14s use engine e, possibly a hardware device.\n","-engine e");
 | 
								BIO_printf(bio_err,"%-14s use engine e, possibly a hardware device.\n","-engine e");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			BIO_printf(bio_err,"Cipher Types\n");
 | 
								BIO_printf(bio_err,"Cipher Types\n");
 | 
				
			||||||
			OBJ_NAME_do_all_sorted(OBJ_NAME_TYPE_CIPHER_METH,
 | 
								OBJ_NAME_do_all_sorted(OBJ_NAME_TYPE_CIPHER_METH,
 | 
				
			||||||
@@ -305,23 +284,7 @@ bad:
 | 
				
			|||||||
		argv++;
 | 
							argv++;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (md && (dgst=EVP_get_digestbyname(md)) == NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"%s is an unsupported message digest type\n",md);
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (dgst == NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		if (in_FIPS_mode)
 | 
					 | 
				
			||||||
			dgst = EVP_sha1();
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			dgst = EVP_md5();
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (bufsize != NULL)
 | 
						if (bufsize != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -346,7 +309,7 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* It must be large enough for a base64 encoded line */
 | 
							/* It must be large enough for a base64 encoded line */
 | 
				
			||||||
		if (base64 && n < 80) n=80;
 | 
							if (n < 80) n=80;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		bsize=(int)n;
 | 
							bsize=(int)n;
 | 
				
			||||||
		if (verbose) BIO_printf(bio_err,"bufsize=%d\n",bsize);
 | 
							if (verbose) BIO_printf(bio_err,"bufsize=%d\n",bsize);
 | 
				
			||||||
@@ -376,11 +339,7 @@ bad:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (inf == NULL)
 | 
						if (inf == NULL)
 | 
				
			||||||
	        {
 | 
					 | 
				
			||||||
		if (bufsize != NULL)
 | 
					 | 
				
			||||||
			setvbuf(stdin, (char *)NULL, _IONBF, 0);
 | 
					 | 
				
			||||||
		BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
				
			||||||
	        }
 | 
					 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (BIO_read_filename(in,inf) <= 0)
 | 
							if (BIO_read_filename(in,inf) <= 0)
 | 
				
			||||||
@@ -404,9 +363,9 @@ bad:
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			char buf[200];
 | 
								char buf[200];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			BIO_snprintf(buf,sizeof buf,"enter %s %s password:",
 | 
								sprintf(buf,"enter %s %s password:",
 | 
				
			||||||
				     OBJ_nid2ln(EVP_CIPHER_nid(cipher)),
 | 
									OBJ_nid2ln(EVP_CIPHER_nid(cipher)),
 | 
				
			||||||
				     (enc)?"encryption":"decryption");
 | 
									(enc)?"encryption":"decryption");
 | 
				
			||||||
			strbuf[0]='\0';
 | 
								strbuf[0]='\0';
 | 
				
			||||||
			i=EVP_read_pw_string((char *)strbuf,SIZE,buf,enc);
 | 
								i=EVP_read_pw_string((char *)strbuf,SIZE,buf,enc);
 | 
				
			||||||
			if (i == 0)
 | 
								if (i == 0)
 | 
				
			||||||
@@ -431,8 +390,6 @@ bad:
 | 
				
			|||||||
	if (outf == NULL)
 | 
						if (outf == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_set_fp(out,stdout,BIO_NOCLOSE);
 | 
							BIO_set_fp(out,stdout,BIO_NOCLOSE);
 | 
				
			||||||
		if (bufsize != NULL)
 | 
					 | 
				
			||||||
			setvbuf(stdout, (char *)NULL, _IONBF, 0);
 | 
					 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					#ifdef OPENSSL_SYS_VMS
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
							BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
				
			||||||
@@ -485,12 +442,12 @@ bad:
 | 
				
			|||||||
			else {
 | 
								else {
 | 
				
			||||||
				if(enc) {
 | 
									if(enc) {
 | 
				
			||||||
					if(hsalt) {
 | 
										if(hsalt) {
 | 
				
			||||||
						if(!set_hex(hsalt,salt,sizeof salt)) {
 | 
											if(!set_hex(hsalt,salt,PKCS5_SALT_LEN)) {
 | 
				
			||||||
							BIO_printf(bio_err,
 | 
												BIO_printf(bio_err,
 | 
				
			||||||
								"invalid hex salt value\n");
 | 
													"invalid hex salt value\n");
 | 
				
			||||||
							goto end;
 | 
												goto end;
 | 
				
			||||||
						}
 | 
											}
 | 
				
			||||||
					} else if (RAND_pseudo_bytes(salt, sizeof salt) < 0)
 | 
										} else if (RAND_pseudo_bytes(salt, PKCS5_SALT_LEN) < 0)
 | 
				
			||||||
						goto end;
 | 
											goto end;
 | 
				
			||||||
					/* If -P option then don't bother writing */
 | 
										/* If -P option then don't bother writing */
 | 
				
			||||||
					if((printkey != 2)
 | 
										if((printkey != 2)
 | 
				
			||||||
@@ -498,14 +455,14 @@ bad:
 | 
				
			|||||||
							 sizeof magic-1) != sizeof magic-1
 | 
												 sizeof magic-1) != sizeof magic-1
 | 
				
			||||||
					       || BIO_write(wbio,
 | 
										       || BIO_write(wbio,
 | 
				
			||||||
							    (char *)salt,
 | 
												    (char *)salt,
 | 
				
			||||||
							    sizeof salt) != sizeof salt)) {
 | 
												    PKCS5_SALT_LEN) != PKCS5_SALT_LEN)) {
 | 
				
			||||||
						BIO_printf(bio_err,"error writing output file\n");
 | 
											BIO_printf(bio_err,"error writing output file\n");
 | 
				
			||||||
						goto end;
 | 
											goto end;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
				} else if(BIO_read(rbio,mbuf,sizeof mbuf) != sizeof mbuf
 | 
									} else if(BIO_read(rbio,mbuf,sizeof mbuf) != sizeof mbuf
 | 
				
			||||||
					  || BIO_read(rbio,
 | 
										  || BIO_read(rbio,
 | 
				
			||||||
						      (unsigned char *)salt,
 | 
											      (unsigned char *)salt,
 | 
				
			||||||
				    sizeof salt) != sizeof salt) {
 | 
									    PKCS5_SALT_LEN) != PKCS5_SALT_LEN) {
 | 
				
			||||||
					BIO_printf(bio_err,"error reading input file\n");
 | 
										BIO_printf(bio_err,"error reading input file\n");
 | 
				
			||||||
					goto end;
 | 
										goto end;
 | 
				
			||||||
				} else if(memcmp(mbuf,magic,sizeof magic-1)) {
 | 
									} else if(memcmp(mbuf,magic,sizeof magic-1)) {
 | 
				
			||||||
@@ -516,7 +473,7 @@ bad:
 | 
				
			|||||||
				sptr = salt;
 | 
									sptr = salt;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			EVP_BytesToKey(cipher,dgst,sptr,
 | 
								EVP_BytesToKey(cipher,EVP_md5(),sptr,
 | 
				
			||||||
				(unsigned char *)str,
 | 
									(unsigned char *)str,
 | 
				
			||||||
				strlen(str),1,key,iv);
 | 
									strlen(str),1,key,iv);
 | 
				
			||||||
			/* zero the complete buffer or the string
 | 
								/* zero the complete buffer or the string
 | 
				
			||||||
@@ -524,9 +481,9 @@ bad:
 | 
				
			|||||||
			 * bug picked up by
 | 
								 * bug picked up by
 | 
				
			||||||
			 * Larry J. Hughes Jr. <hughes@indiana.edu> */
 | 
								 * Larry J. Hughes Jr. <hughes@indiana.edu> */
 | 
				
			||||||
			if (str == strbuf)
 | 
								if (str == strbuf)
 | 
				
			||||||
				OPENSSL_cleanse(str,SIZE);
 | 
									memset(str,0,SIZE);
 | 
				
			||||||
			else
 | 
								else
 | 
				
			||||||
				OPENSSL_cleanse(str,strlen(str));
 | 
									memset(str,0,strlen(str));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if ((hiv != NULL) && !set_hex(hiv,iv,sizeof iv))
 | 
							if ((hiv != NULL) && !set_hex(hiv,iv,sizeof iv))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -549,43 +506,13 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if ((benc=BIO_new(BIO_f_cipher())) == NULL)
 | 
							if ((benc=BIO_new(BIO_f_cipher())) == NULL)
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
 | 
							BIO_set_cipher(benc,cipher,key,iv,enc);
 | 
				
			||||||
		/* Since we may be changing parameters work on the encryption
 | 
					 | 
				
			||||||
		 * context rather than calling BIO_set_cipher().
 | 
					 | 
				
			||||||
		 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		BIO_get_cipher_ctx(benc, &ctx);
 | 
					 | 
				
			||||||
		if (!EVP_CipherInit_ex(ctx, cipher, NULL, NULL, NULL, enc))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Error setting cipher %s\n",
 | 
					 | 
				
			||||||
					EVP_CIPHER_name(cipher));
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (non_fips_allow)
 | 
					 | 
				
			||||||
			EVP_CIPHER_CTX_set_flags(ctx,
 | 
					 | 
				
			||||||
				EVP_CIPH_FLAG_NON_FIPS_ALLOW);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (!EVP_CipherInit_ex(ctx, NULL, NULL, key, iv, enc))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Error setting cipher %s\n",
 | 
					 | 
				
			||||||
					EVP_CIPHER_name(cipher));
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (nopad)
 | 
							if (nopad)
 | 
				
			||||||
			EVP_CIPHER_CTX_set_padding(ctx, 0);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (!EVP_CipherInit_ex(ctx, NULL, NULL, key, iv, enc))
 | 
					 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error setting cipher %s\n",
 | 
								EVP_CIPHER_CTX *ctx;
 | 
				
			||||||
					EVP_CIPHER_name(cipher));
 | 
								BIO_get_cipher_ctx(benc, &ctx);
 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								EVP_CIPHER_CTX_set_padding(ctx, 0);
 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (debug)
 | 
							if (debug)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_set_callback(benc,BIO_debug_callback);
 | 
								BIO_set_callback(benc,BIO_debug_callback);
 | 
				
			||||||
@@ -597,7 +524,7 @@ bad:
 | 
				
			|||||||
			if (!nosalt)
 | 
								if (!nosalt)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				printf("salt=");
 | 
									printf("salt=");
 | 
				
			||||||
				for (i=0; i<sizeof salt; i++)
 | 
									for (i=0; i<PKCS5_SALT_LEN; i++)
 | 
				
			||||||
					printf("%02X",salt[i]);
 | 
										printf("%02X",salt[i]);
 | 
				
			||||||
				printf("\n");
 | 
									printf("\n");
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
@@ -659,7 +586,7 @@ end:
 | 
				
			|||||||
	if (b64 != NULL) BIO_free(b64);
 | 
						if (b64 != NULL) BIO_free(b64);
 | 
				
			||||||
	if(pass) OPENSSL_free(pass);
 | 
						if(pass) OPENSSL_free(pass);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int set_hex(char *in, unsigned char *out, int size)
 | 
					int set_hex(char *in, unsigned char *out, int size)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -56,8 +56,6 @@
 | 
				
			|||||||
 *
 | 
					 *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
@@ -122,8 +120,8 @@ static int append_buf(char **buf, const char *s, int *size, int step)
 | 
				
			|||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (**buf != '\0')
 | 
						if (**buf != '\0')
 | 
				
			||||||
		BUF_strlcat(*buf, ", ", *size);
 | 
							strcat(*buf, ", ");
 | 
				
			||||||
	BUF_strlcat(*buf, s, *size);
 | 
						strcat(*buf, s);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -387,15 +385,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (strcmp(*argv,"-pre") == 0)
 | 
							else if (strcmp(*argv,"-pre") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--; argv++;
 | 
								argc--; argv++;
 | 
				
			||||||
			if (argc == 0)
 | 
					 | 
				
			||||||
				goto skip_arg_loop;
 | 
					 | 
				
			||||||
			sk_push(pre_cmds,*argv);
 | 
								sk_push(pre_cmds,*argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-post") == 0)
 | 
							else if (strcmp(*argv,"-post") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--; argv++;
 | 
								argc--; argv++;
 | 
				
			||||||
			if (argc == 0)
 | 
					 | 
				
			||||||
				goto skip_arg_loop;
 | 
					 | 
				
			||||||
			sk_push(post_cmds,*argv);
 | 
								sk_push(post_cmds,*argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if ((strncmp(*argv,"-h",2) == 0) ||
 | 
							else if ((strncmp(*argv,"-h",2) == 0) ||
 | 
				
			||||||
@@ -522,12 +516,5 @@ end:
 | 
				
			|||||||
	sk_pop_free(post_cmds, identity);
 | 
						sk_pop_free(post_cmds, identity);
 | 
				
			||||||
	if (bio_out != NULL) BIO_free_all(bio_out);
 | 
						if (bio_out != NULL) BIO_free_all(bio_out);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# if PEDANTIC
 | 
					 | 
				
			||||||
static void *dummy=&dummy;
 | 
					 | 
				
			||||||
# endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -122,5 +122,5 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										12
									
								
								apps/gendh.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								apps/gendh.c
									
									
									
									
									
								
							@@ -81,17 +81,13 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	DH *dh=NULL;
 | 
						DH *dh=NULL;
 | 
				
			||||||
	int ret=1,num=DEFBITS;
 | 
						int ret=1,num=DEFBITS;
 | 
				
			||||||
	int g=2;
 | 
						int g=2;
 | 
				
			||||||
	char *outfile=NULL;
 | 
						char *outfile=NULL;
 | 
				
			||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	BIO *out=NULL;
 | 
						BIO *out=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
@@ -119,13 +115,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			g=3; */
 | 
								g=3; */
 | 
				
			||||||
		else if (strcmp(*argv,"-5") == 0)
 | 
							else if (strcmp(*argv,"-5") == 0)
 | 
				
			||||||
			g=5;
 | 
								g=5;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-rand") == 0)
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -144,18 +138,14 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -2        - use 2 as the generator value\n");
 | 
							BIO_printf(bio_err," -2        - use 2 as the generator value\n");
 | 
				
			||||||
	/*	BIO_printf(bio_err," -3        - use 3 as the generator value\n"); */
 | 
						/*	BIO_printf(bio_err," -3        - use 3 as the generator value\n"); */
 | 
				
			||||||
		BIO_printf(bio_err," -5        - use 5 as the generator value\n");
 | 
							BIO_printf(bio_err," -5        - use 5 as the generator value\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e - use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e - use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
							BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
		BIO_printf(bio_err,"           - load the file (or the files in the directory) into\n");
 | 
							BIO_printf(bio_err,"           - load the file (or the files in the directory) into\n");
 | 
				
			||||||
		BIO_printf(bio_err,"             the random number generator\n");
 | 
							BIO_printf(bio_err,"             the random number generator\n");
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		
 | 
							
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	out=BIO_new(BIO_s_file());
 | 
						out=BIO_new(BIO_s_file());
 | 
				
			||||||
	if (out == NULL)
 | 
						if (out == NULL)
 | 
				
			||||||
@@ -208,7 +198,7 @@ end:
 | 
				
			|||||||
	if (out != NULL) BIO_free_all(out);
 | 
						if (out != NULL) BIO_free_all(out);
 | 
				
			||||||
	if (dh != NULL) DH_free(dh);
 | 
						if (dh != NULL) DH_free(dh);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void MS_CALLBACK dh_cb(int p, int n, void *arg)
 | 
					static void MS_CALLBACK dh_cb(int p, int n, void *arg)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -77,9 +77,7 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	DSA *dsa=NULL;
 | 
						DSA *dsa=NULL;
 | 
				
			||||||
	int ret=1;
 | 
						int ret=1;
 | 
				
			||||||
	char *outfile=NULL;
 | 
						char *outfile=NULL;
 | 
				
			||||||
@@ -87,9 +85,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *passargout = NULL, *passout = NULL;
 | 
						char *passargout = NULL, *passout = NULL;
 | 
				
			||||||
	BIO *out=NULL,*in=NULL;
 | 
						BIO *out=NULL,*in=NULL;
 | 
				
			||||||
	const EVP_CIPHER *enc=NULL;
 | 
						const EVP_CIPHER *enc=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -115,13 +111,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			passargout= *(++argv);
 | 
								passargout= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-rand") == 0)
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -173,9 +167,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -aes128, -aes192, -aes256\n");
 | 
							BIO_printf(bio_err," -aes128, -aes192, -aes256\n");
 | 
				
			||||||
		BIO_printf(bio_err,"                 encrypt PEM output with cbc aes\n");
 | 
							BIO_printf(bio_err,"                 encrypt PEM output with cbc aes\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e - use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e - use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
							BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
		BIO_printf(bio_err,"           - load the file (or the files in the directory) into\n");
 | 
							BIO_printf(bio_err,"           - load the file (or the files in the directory) into\n");
 | 
				
			||||||
		BIO_printf(bio_err,"             the random number generator\n");
 | 
							BIO_printf(bio_err,"             the random number generator\n");
 | 
				
			||||||
@@ -184,9 +176,7 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, NULL, passargout, NULL, &passout)) {
 | 
						if(!app_passwd(bio_err, NULL, passargout, NULL, &passout)) {
 | 
				
			||||||
		BIO_printf(bio_err, "Error getting password\n");
 | 
							BIO_printf(bio_err, "Error getting password\n");
 | 
				
			||||||
@@ -256,6 +246,6 @@ end:
 | 
				
			|||||||
	if (dsa != NULL) DSA_free(dsa);
 | 
						if (dsa != NULL) DSA_free(dsa);
 | 
				
			||||||
	if(passout) OPENSSL_free(passout);
 | 
						if(passout) OPENSSL_free(passout);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -81,23 +81,16 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int ret=1;
 | 
						int ret=1;
 | 
				
			||||||
	RSA *rsa=NULL;
 | 
						RSA *rsa=NULL;
 | 
				
			||||||
	int i,num=DEFBITS;
 | 
						int i,num=DEFBITS;
 | 
				
			||||||
	long l;
 | 
						long l;
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
	int use_x931 = 0;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	const EVP_CIPHER *enc=NULL;
 | 
						const EVP_CIPHER *enc=NULL;
 | 
				
			||||||
	unsigned long f4=RSA_F4;
 | 
						unsigned long f4=RSA_F4;
 | 
				
			||||||
	char *outfile=NULL;
 | 
						char *outfile=NULL;
 | 
				
			||||||
	char *passargout = NULL, *passout = NULL;
 | 
						char *passargout = NULL, *passout = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL;
 | 
				
			||||||
	BIO *out=NULL;
 | 
						BIO *out=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -129,17 +122,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			f4=3;
 | 
								f4=3;
 | 
				
			||||||
		else if (strcmp(*argv,"-F4") == 0 || strcmp(*argv,"-f4") == 0)
 | 
							else if (strcmp(*argv,"-F4") == 0 || strcmp(*argv,"-f4") == 0)
 | 
				
			||||||
			f4=RSA_F4;
 | 
								f4=RSA_F4;
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-x931") == 0)
 | 
					 | 
				
			||||||
			use_x931 = 1;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-rand") == 0)
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -190,9 +177,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -passout arg    output file pass phrase source\n");
 | 
							BIO_printf(bio_err," -passout arg    output file pass phrase source\n");
 | 
				
			||||||
		BIO_printf(bio_err," -f4             use F4 (0x10001) for the E value\n");
 | 
							BIO_printf(bio_err," -f4             use F4 (0x10001) for the E value\n");
 | 
				
			||||||
		BIO_printf(bio_err," -3              use 3 for the E value\n");
 | 
							BIO_printf(bio_err," -3              use 3 for the E value\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
							BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
		BIO_printf(bio_err,"                 load the file (or the files in the directory) into\n");
 | 
							BIO_printf(bio_err,"                 load the file (or the files in the directory) into\n");
 | 
				
			||||||
		BIO_printf(bio_err,"                 the random number generator\n");
 | 
							BIO_printf(bio_err,"                 the random number generator\n");
 | 
				
			||||||
@@ -206,9 +191,7 @@ bad:
 | 
				
			|||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (outfile == NULL)
 | 
						if (outfile == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -240,27 +223,11 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	BIO_printf(bio_err,"Generating RSA private key, %d bit long modulus\n",
 | 
						BIO_printf(bio_err,"Generating RSA private key, %d bit long modulus\n",
 | 
				
			||||||
		num);
 | 
							num);
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
						rsa=RSA_generate_key(num,f4,genrsa_cb,bio_err);
 | 
				
			||||||
	if (use_x931)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIGNUM *pubexp;
 | 
					 | 
				
			||||||
		pubexp = BN_new();
 | 
					 | 
				
			||||||
		BN_set_word(pubexp, f4);
 | 
					 | 
				
			||||||
		rsa = RSA_X931_generate_key(num, pubexp, genrsa_cb, bio_err);
 | 
					 | 
				
			||||||
		BN_free(pubexp);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		rsa=RSA_generate_key(num,f4,genrsa_cb,bio_err);
 | 
					 | 
				
			||||||
		
 | 
							
 | 
				
			||||||
	app_RAND_write_file(NULL, bio_err);
 | 
						app_RAND_write_file(NULL, bio_err);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (rsa == NULL)
 | 
						if (rsa == NULL) goto err;
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Key Generation error\n");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		goto err;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	/* We need to do the following for when the base number size is <
 | 
						/* We need to do the following for when the base number size is <
 | 
				
			||||||
	 * long, esp windows 3.1 :-(. */
 | 
						 * long, esp windows 3.1 :-(. */
 | 
				
			||||||
@@ -291,7 +258,7 @@ err:
 | 
				
			|||||||
	if (ret != 0)
 | 
						if (ret != 0)
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void MS_CALLBACK genrsa_cb(int p, int n, void *arg)
 | 
					static void MS_CALLBACK genrsa_cb(int p, int n, void *arg)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -15,10 +15,22 @@ $!
 | 
				
			|||||||
$!  It was written so it would try to determine what "C" compiler to
 | 
					$!  It was written so it would try to determine what "C" compiler to
 | 
				
			||||||
$!  use or you can specify which "C" compiler to use.
 | 
					$!  use or you can specify which "C" compiler to use.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Specify DEBUG or NODEBUG as P1 to compile with or without debugger
 | 
					$!  Specify RSAREF as P1 to compile with the RSAREF library instead of
 | 
				
			||||||
 | 
					$!  the regular one.  If you specify NORSAREF it will compile with the
 | 
				
			||||||
 | 
					$!  regular RSAREF routines.  (Note: If you are in the United States
 | 
				
			||||||
 | 
					$!  you MUST compile with RSAREF unless you have a license from RSA).
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Note: The RSAREF libraries are NOT INCLUDED and you have to
 | 
				
			||||||
 | 
					$!        download it from "ftp://ftp.rsa.com/rsaref".  You have to
 | 
				
			||||||
 | 
					$!        get the ".tar-Z" file as the ".zip" file dosen't have the
 | 
				
			||||||
 | 
					$!        directory structure stored.  You have to extract the file
 | 
				
			||||||
 | 
					$!        into the [.RSAREF] directory under the root directory as that
 | 
				
			||||||
 | 
					$!        is where the scripts will look for the files.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Specify DEBUG or NODEBUG as P2 to compile with or without debugger
 | 
				
			||||||
$!  information.
 | 
					$!  information.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Specify which compiler at P2 to try to compile under.
 | 
					$!  Specify which compiler at P3 to try to compile under.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!	   VAXC	 For VAX C.
 | 
					$!	   VAXC	 For VAX C.
 | 
				
			||||||
$!	   DECC	 For DEC C.
 | 
					$!	   DECC	 For DEC C.
 | 
				
			||||||
@@ -27,16 +39,15 @@ $!
 | 
				
			|||||||
$!  If you don't speficy a compiler, it will try to determine which
 | 
					$!  If you don't speficy a compiler, it will try to determine which
 | 
				
			||||||
$!  "C" compiler to use.
 | 
					$!  "C" compiler to use.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P3, if defined, sets a TCP/IP library to use, through one of the following
 | 
					$!  P4, if defined, sets a TCP/IP library to use, through one of the following
 | 
				
			||||||
$!  keywords:
 | 
					$!  keywords:
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!	UCX		for UCX
 | 
					$!	UCX		for UCX
 | 
				
			||||||
$!	SOCKETSHR	for SOCKETSHR+NETLIB
 | 
					$!	SOCKETSHR	for SOCKETSHR+NETLIB
 | 
				
			||||||
$!	TCPIP		for TCPIP (post UCX)
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P4, if defined, sets a compiler thread NOT needed on OpenVMS 7.1 (and up)
 | 
					$!  P5, if defined, sets a compiler thread NOT needed on OpenVMS 7.1 (and up)
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  P5, if defined, sets a choice of programs to compile.
 | 
					$!  P6, if defined, sets a choice of programs to compile.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Define A TCP/IP Library That We Will Need To Link To.
 | 
					$! Define A TCP/IP Library That We Will Need To Link To.
 | 
				
			||||||
@@ -89,6 +100,10 @@ $! Define The CRYPTO Library.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ CRYPTO_LIB := SYS$DISK:[-.'ARCH'.EXE.CRYPTO]LIBCRYPTO.OLB
 | 
					$ CRYPTO_LIB := SYS$DISK:[-.'ARCH'.EXE.CRYPTO]LIBCRYPTO.OLB
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
 | 
					$! Define The RSAREF Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ RSAREF_LIB := SYS$DISK:[-.'ARCH'.EXE.RSAREF]LIBRSAGLUE.OLB
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
$! Define The SSL Library.
 | 
					$! Define The SSL Library.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ SSL_LIB := SYS$DISK:[-.'ARCH'.EXE.SSL]LIBSSL.OLB
 | 
					$ SSL_LIB := SYS$DISK:[-.'ARCH'.EXE.SSL]LIBSSL.OLB
 | 
				
			||||||
@@ -142,13 +157,13 @@ $ LIB_FILES = "VERIFY;ASN1PARS;REQ;DGST;DH;DHPARAM;ENC;PASSWD;GENDH;ERRSTR;"+-
 | 
				
			|||||||
	      "RSA;RSAUTL;DSA;DSAPARAM;"+-
 | 
						      "RSA;RSAUTL;DSA;DSAPARAM;"+-
 | 
				
			||||||
	      "X509;GENRSA;GENDSA;S_SERVER;S_CLIENT;SPEED;"+-
 | 
						      "X509;GENRSA;GENDSA;S_SERVER;S_CLIENT;SPEED;"+-
 | 
				
			||||||
	      "S_TIME;APPS;S_CB;S_SOCKET;APP_RAND;VERSION;SESS_ID;"+-
 | 
						      "S_TIME;APPS;S_CB;S_SOCKET;APP_RAND;VERSION;SESS_ID;"+-
 | 
				
			||||||
	      "CIPHERS;NSEQ;PKCS12;PKCS8;SPKAC;SMIME;RAND;ENGINE;OCSP;PRIME"
 | 
						      "CIPHERS;NSEQ;PKCS12;PKCS8;SPKAC;SMIME;RAND;ENGINE;OCSP"
 | 
				
			||||||
$ APP_FILES := OPENSSL,'OBJ_DIR'VERIFY.OBJ,ASN1PARS.OBJ,REQ.OBJ,DGST.OBJ,DH.OBJ,DHPARAM.OBJ,ENC.OBJ,PASSWD.OBJ,GENDH.OBJ,ERRSTR.OBJ,-
 | 
					$ APP_FILES := OPENSSL,'OBJ_DIR'VERIFY.OBJ,ASN1PARS.OBJ,REQ.OBJ,DGST.OBJ,DH.OBJ,DHPARAM.OBJ,ENC.OBJ,PASSWD.OBJ,GENDH.OBJ,ERRSTR.OBJ,-
 | 
				
			||||||
	       CA.OBJ,PKCS7.OBJ,CRL2P7.OBJ,CRL.OBJ,-
 | 
						       CA.OBJ,PKCS7.OBJ,CRL2P7.OBJ,CRL.OBJ,-
 | 
				
			||||||
	       RSA.OBJ,RSAUTL.OBJ,DSA.OBJ,DSAPARAM.OBJ,-
 | 
						       RSA.OBJ,RSAUTL.OBJ,DSA.OBJ,DSAPARAM.OBJ,-
 | 
				
			||||||
	       X509.OBJ,GENRSA.OBJ,GENDSA.OBJ,S_SERVER.OBJ,S_CLIENT.OBJ,SPEED.OBJ,-
 | 
						       X509.OBJ,GENRSA.OBJ,GENDSA.OBJ,S_SERVER.OBJ,S_CLIENT.OBJ,SPEED.OBJ,-
 | 
				
			||||||
	       S_TIME.OBJ,APPS.OBJ,S_CB.OBJ,S_SOCKET.OBJ,APP_RAND.OBJ,VERSION.OBJ,SESS_ID.OBJ,-
 | 
						       S_TIME.OBJ,APPS.OBJ,S_CB.OBJ,S_SOCKET.OBJ,APP_RAND.OBJ,VERSION.OBJ,SESS_ID.OBJ,-
 | 
				
			||||||
	       CIPHERS.OBJ,NSEQ.OBJ,PKCS12.OBJ,PKCS8.OBJ,SPKAC.OBJ,SMIME.OBJ,RAND.OBJ,ENGINE.OBJ,OCSP.OBJ,PRIME.OBJ
 | 
						       CIPHERS.OBJ,NSEQ.OBJ,PKCS12.OBJ,PKCS8.OBJ,SPKAC.OBJ,SMIME.OBJ,RAND.OBJ,ENGINE.OBJ,OCSP.OBJ
 | 
				
			||||||
$ TCPIP_PROGRAMS = ",,"
 | 
					$ TCPIP_PROGRAMS = ",,"
 | 
				
			||||||
$ IF COMPILER .EQS. "VAXC" THEN -
 | 
					$ IF COMPILER .EQS. "VAXC" THEN -
 | 
				
			||||||
     TCPIP_PROGRAMS = ",OPENSSL,"
 | 
					     TCPIP_PROGRAMS = ",OPENSSL,"
 | 
				
			||||||
@@ -166,7 +181,7 @@ $!     TCPIP_PROGRAMS = ",S_SERVER,S_CLIENT,SESS_ID,CIPHERS,S_TIME,"
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$! Setup exceptional compilations
 | 
					$! Setup exceptional compilations
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ COMPILEWITH_CC2 = ",S_SERVER,S_CLIENT,"
 | 
					$ COMPILEWITH_CC2 = ",S_SOCKET,S_SERVER,S_CLIENT,"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ PHASE := LIB
 | 
					$ PHASE := LIB
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -277,31 +292,73 @@ $   WRITE SYS$OUTPUT FILE_NAME," needs a TCP/IP library.  Can't link.  Skipping.
 | 
				
			|||||||
$   GOTO NEXT_FILE
 | 
					$   GOTO NEXT_FILE
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Link The Program.
 | 
					$! Link The Program, Check To See If We Need To Link With RSAREF Or Not.
 | 
				
			||||||
$! Check To See If We Are To Link With A Specific TCP/IP Library.
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (TCPIP_LIB.NES."")
 | 
					$ IF (RSAREF.EQS."TRUE")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Don't Link With The RSAREF Routines And TCP/IP Library.
 | 
					$!  Check To See If We Are To Link With A Specific TCP/IP Library.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
					$   IF (TCPIP_LIB.NES."")
 | 
				
			||||||
	'OBJECT_FILE''EXTRA_OBJ', -
 | 
					$   THEN
 | 
				
			||||||
        'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY, -
 | 
					$!
 | 
				
			||||||
        'TCPIP_LIB','OPT_FILE'/OPTION
 | 
					$!    Link With The RSAREF Library And A Specific TCP/IP Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
				
			||||||
 | 
						  'OBJECT_FILE''EXTRA_OBJ', -
 | 
				
			||||||
 | 
					          'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY,'RSAREF_LIB'/LIBRARY, -
 | 
				
			||||||
 | 
					          'TCPIP_LIB','OPT_FILE'/OPTION
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Else...
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ELSE
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Link With The RSAREF Library And NO TCP/IP Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
				
			||||||
 | 
						  'OBJECT_FILE''EXTRA_OBJ', -
 | 
				
			||||||
 | 
					          'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY,'RSAREF_LIB'/LIBRARY, -
 | 
				
			||||||
 | 
					          'OPT_FILE'/OPTION
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  End The TCP/IP Library Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Else...
 | 
					$! Else...
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ELSE
 | 
					$ ELSE
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Don't Link With The RSAREF Routines And Link With A TCP/IP Library.
 | 
					$!  Don't Link With The RSAREF Routines.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
					 | 
				
			||||||
	'OBJECT_FILE''EXTRA_OBJ', -
 | 
					 | 
				
			||||||
        'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY, -
 | 
					 | 
				
			||||||
        'OPT_FILE'/OPTION
 | 
					 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! End The TCP/IP Library Check.
 | 
					$!  Check To See If We Are To Link With A Specific TCP/IP Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   IF (TCPIP_LIB.NES."")
 | 
				
			||||||
 | 
					$   THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Don't Link With The RSAREF Routines And TCP/IP Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$       LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
				
			||||||
 | 
						    'OBJECT_FILE''EXTRA_OBJ', -
 | 
				
			||||||
 | 
					            'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY, -
 | 
				
			||||||
 | 
					            'TCPIP_LIB','OPT_FILE'/OPTION
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Else...
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ELSE
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Don't Link With The RSAREF Routines And Link With A TCP/IP Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$       LINK/'DEBUGGER'/'TRACEBACK' /EXE='EXE_FILE' -
 | 
				
			||||||
 | 
						    'OBJECT_FILE''EXTRA_OBJ', -
 | 
				
			||||||
 | 
					            'SSL_LIB'/LIBRARY,'CRYPTO_LIB'/LIBRARY, -
 | 
				
			||||||
 | 
					            'OPT_FILE'/OPTION
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  End The TCP/IP Library Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! End The RSAREF Link Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -468,6 +525,32 @@ $! End The Crypto Library Check.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
 | 
					$! See If We Need The RSAREF Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ IF (RSAREF.EQS."TRUE")
 | 
				
			||||||
 | 
					$ THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Look For The Library LIBRSAGLUE.OLB.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   IF (F$SEARCH(RSAREF_LIB).EQS."")
 | 
				
			||||||
 | 
					$   THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Tell The User We Can't Find The LIBRSAGLUE.OLB Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "Can't Find The Library ",RSAREF_LIB,"."
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "We Can't Link Without It."
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Since We Can't Link Without It, Exit.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     EXIT
 | 
				
			||||||
 | 
					$   ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! End The RSAREF Library Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
$! Look For The Library LIBSSL.OLB.
 | 
					$! Look For The Library LIBSSL.OLB.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (F$SEARCH(SSL_LIB).EQS."")
 | 
					$ IF (F$SEARCH(SSL_LIB).EQS."")
 | 
				
			||||||
@@ -498,10 +581,87 @@ $ CHECK_OPTIONS:
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check To See If P1 Is Blank.
 | 
					$! Check To See If P1 Is Blank.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P1.EQS."NODEBUG")
 | 
					$ P1 = "NORSAREF"
 | 
				
			||||||
 | 
					$ IF (P1.EQS."NORSAREF")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!   P1 Is NODEBUG, So Compile Without Debugger Information.
 | 
					$!   P1 Is NORSAREF, So Compile With The Regular RSA Libraries.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$    RSAREF = "FALSE"
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Else...
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ ELSE
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Check To See If We Are To Use The RSAREF Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   IF (P1.EQS."RSAREF")
 | 
				
			||||||
 | 
					$   THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Check To Make Sure We Have The RSAREF Source Code Directory.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     IF (F$SEARCH("SYS$DISK:[-.RSAREF]SOURCE.DIR").EQS."")
 | 
				
			||||||
 | 
					$     THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!      We Don't Have The RSAREF Souce Code Directory, So Tell The
 | 
				
			||||||
 | 
					$!      User This.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT "It appears that you don't have the RSAREF Souce Code."
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT "You need to go to 'ftp://ftp.rsa.com/rsaref'.  You have to"
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT "get the '.tar-Z' file as the '.zip' file dosen't have the"
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT "directory structure stored.  You have to extract the file"
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT "into the [.RSAREF] directory under the root directory"
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT "as that is where the scripts will look for the files."
 | 
				
			||||||
 | 
					$       WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!      Time To Exit.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$       EXIT
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Else...
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     ELSE
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!      Compile Using The RSAREF Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$       RSAREF = "TRUE"
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    End The RSAREF Soure Directory Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  Else...
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ELSE 
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    They Entered An Invalid Option..
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "The Option ",P1," Is Invalid.  The Valid Options Are:"
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "     RSAREF   :  Compile With The RSAREF Library."
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "     NORSAREF :  Compile With The Regular RSA Library."
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Time To EXIT.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     EXIT
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  End The Valid Arguement Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! End P1 Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$! Check To See If P2 Is Blank.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$ IF (P2.EQS."NODEBUG")
 | 
				
			||||||
 | 
					$ THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!   P2 Is NODEBUG, So Compile Without Debugger Information.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$    DEBUGGER  = "NODEBUG"
 | 
					$    DEBUGGER  = "NODEBUG"
 | 
				
			||||||
$    TRACEBACK = "NOTRACEBACK" 
 | 
					$    TRACEBACK = "NOTRACEBACK" 
 | 
				
			||||||
@@ -516,7 +676,7 @@ $ ELSE
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If We Are To Compile With Debugger Information.
 | 
					$!  Check To See If We Are To Compile With Debugger Information.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF (P1.EQS."DEBUG")
 | 
					$   IF (P2.EQS."DEBUG")
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Compile With Debugger Information.
 | 
					$!    Compile With Debugger Information.
 | 
				
			||||||
@@ -532,7 +692,7 @@ $!
 | 
				
			|||||||
$!    Tell The User Entered An Invalid Option..
 | 
					$!    Tell The User Entered An Invalid Option..
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     WRITE SYS$OUTPUT ""
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
$     WRITE SYS$OUTPUT "The Option ",P1," Is Invalid.  The Valid Options Are:"
 | 
					$     WRITE SYS$OUTPUT "The Option ",P2," Is Invalid.  The Valid Options Are:"
 | 
				
			||||||
$     WRITE SYS$OUTPUT ""
 | 
					$     WRITE SYS$OUTPUT ""
 | 
				
			||||||
$     WRITE SYS$OUTPUT "    DEBUG    :  Compile With The Debugger Information."
 | 
					$     WRITE SYS$OUTPUT "    DEBUG    :  Compile With The Debugger Information."
 | 
				
			||||||
$     WRITE SYS$OUTPUT "    NODEBUG  :  Compile Without The Debugger Information."
 | 
					$     WRITE SYS$OUTPUT "    NODEBUG  :  Compile Without The Debugger Information."
 | 
				
			||||||
@@ -546,13 +706,13 @@ $!  End The Valid Arguement Check.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! End The P1 Check.
 | 
					$! End The P2 Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check To See If P2 Is Blank.
 | 
					$! Check To See If P3 Is Blank.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P2.EQS."")
 | 
					$ IF (P3.EQS."")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  O.K., The User Didn't Specify A Compiler, Let's Try To
 | 
					$!  O.K., The User Didn't Specify A Compiler, Let's Try To
 | 
				
			||||||
@@ -565,7 +725,7 @@ $   THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Looks Like GNUC, Set To Use GNUC.
 | 
					$!    Looks Like GNUC, Set To Use GNUC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     P2 = "GNUC"
 | 
					$     P3 = "GNUC"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Else...
 | 
					$!  Else...
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -578,7 +738,7 @@ $     THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!      Looks Like DECC, Set To Use DECC.
 | 
					$!      Looks Like DECC, Set To Use DECC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$       P2 = "DECC"
 | 
					$       P3 = "DECC"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Else...
 | 
					$!    Else...
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -586,7 +746,7 @@ $     ELSE
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!      Looks Like VAXC, Set To Use VAXC.
 | 
					$!      Looks Like VAXC, Set To Use VAXC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$       P2 = "VAXC"
 | 
					$       P3 = "VAXC"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    End The VAXC Compiler Check.
 | 
					$!    End The VAXC Compiler Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -600,9 +760,9 @@ $!  End The Compiler Check.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check To See If We Have A Option For P3.
 | 
					$! Check To See If We Have A Option For P4.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P3.EQS."")
 | 
					$ IF (P4.EQS."")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Find out what socket library we have available
 | 
					$!  Find out what socket library we have available
 | 
				
			||||||
@@ -612,7 +772,7 @@ $   THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!    We have SOCKETSHR, and it is my opinion that it's the best to use.
 | 
					$!    We have SOCKETSHR, and it is my opinion that it's the best to use.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     P3 = "SOCKETSHR"
 | 
					$     P4 = "SOCKETSHR"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Tell the user
 | 
					$!    Tell the user
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -632,7 +792,7 @@ $     THEN
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!	Last resort: a UCX or UCX-compatible library
 | 
					$!	Last resort: a UCX or UCX-compatible library
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$	P3 = "UCX"
 | 
					$	P4 = "UCX"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!      Tell the user
 | 
					$!      Tell the user
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -650,18 +810,18 @@ $ CCDEFS = "MONOLITH"
 | 
				
			|||||||
$ IF F$TYPE(USER_CCDEFS) .NES. "" THEN CCDEFS = CCDEFS + "," + USER_CCDEFS
 | 
					$ IF F$TYPE(USER_CCDEFS) .NES. "" THEN CCDEFS = CCDEFS + "," + USER_CCDEFS
 | 
				
			||||||
$ CCEXTRAFLAGS = ""
 | 
					$ CCEXTRAFLAGS = ""
 | 
				
			||||||
$ IF F$TYPE(USER_CCFLAGS) .NES. "" THEN CCEXTRAFLAGS = USER_CCFLAGS
 | 
					$ IF F$TYPE(USER_CCFLAGS) .NES. "" THEN CCEXTRAFLAGS = USER_CCFLAGS
 | 
				
			||||||
$ CCDISABLEWARNINGS = "LONGLONGTYPE,LONGLONGSUFX,FOUNDCR"
 | 
					$ CCDISABLEWARNINGS = "LONGLONGTYPE,LONGLONGSUFX"
 | 
				
			||||||
$ IF F$TYPE(USER_CCDISABLEWARNINGS) .NES. "" THEN -
 | 
					$ IF F$TYPE(USER_CCDISABLEWARNINGS) .NES. "" THEN -
 | 
				
			||||||
	CCDISABLEWARNINGS = CCDISABLEWARNINGS + "," + USER_CCDISABLEWARNINGS
 | 
						CCDISABLEWARNINGS = CCDISABLEWARNINGS + "," + USER_CCDISABLEWARNINGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If The User Entered A Valid Paramter.
 | 
					$!  Check To See If The User Entered A Valid Paramter.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P2.EQS."VAXC").OR.(P2.EQS."DECC").OR.(P2.EQS."GNUC")
 | 
					$ IF (P3.EQS."VAXC").OR.(P3.EQS."DECC").OR.(P3.EQS."GNUC")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If The User Wanted DECC.
 | 
					$!  Check To See If The User Wanted DECC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF (P2.EQS."DECC")
 | 
					$   IF (P3.EQS."DECC")
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Looks Like DECC, Set To Use DECC.
 | 
					$!    Looks Like DECC, Set To Use DECC.
 | 
				
			||||||
@@ -679,7 +839,7 @@ $     IF ARCH.EQS."VAX" .AND. F$TRNLNM("DECC$CC_DEFAULT").NES."/DECC" -
 | 
				
			|||||||
	 THEN CC = "CC/DECC"
 | 
						 THEN CC = "CC/DECC"
 | 
				
			||||||
$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/STANDARD=ANSI89" + -
 | 
					$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/STANDARD=ANSI89" + -
 | 
				
			||||||
           "/NOLIST/PREFIX=ALL" + -
 | 
					           "/NOLIST/PREFIX=ALL" + -
 | 
				
			||||||
	   "/INCLUDE=(SYS$DISK:[-],SYS$DISK:[-.CRYPTO])" + CCEXTRAFLAGS
 | 
						   "/INCLUDE=(SYS$DISK:[-])" + CCEXTRAFLAGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define The Linker Options File Name.
 | 
					$!    Define The Linker Options File Name.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -691,7 +851,7 @@ $   ENDIF
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If We Are To Use VAXC.
 | 
					$!  Check To See If We Are To Use VAXC.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF (P2.EQS."VAXC")
 | 
					$   IF (P3.EQS."VAXC")
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Looks Like VAXC, Set To Use VAXC.
 | 
					$!    Looks Like VAXC, Set To Use VAXC.
 | 
				
			||||||
@@ -711,7 +871,7 @@ $	EXIT
 | 
				
			|||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
$     IF F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC" THEN CC = "CC/VAXC"
 | 
					$     IF F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC" THEN CC = "CC/VAXC"
 | 
				
			||||||
$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
					$     CC = CC + "/''CC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
				
			||||||
	   "/INCLUDE=(SYS$DISK:[-],SYS$DISK:[-.CRYPTO])" + CCEXTRAFLAGS
 | 
						   "/INCLUDE=(SYS$DISK:[-])" + CCEXTRAFLAGS
 | 
				
			||||||
$     CCDEFS = CCDEFS + ",""VAXC"""
 | 
					$     CCDEFS = CCDEFS + ",""VAXC"""
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define <sys> As SYS$COMMON:[SYSLIB]
 | 
					$!    Define <sys> As SYS$COMMON:[SYSLIB]
 | 
				
			||||||
@@ -728,7 +888,7 @@ $   ENDIF
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check To See If We Are To Use GNU C.
 | 
					$!  Check To See If We Are To Use GNU C.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF (P2.EQS."GNUC")
 | 
					$   IF (P3.EQS."GNUC")
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Looks Like GNUC, Set To Use GNUC.
 | 
					$!    Looks Like GNUC, Set To Use GNUC.
 | 
				
			||||||
@@ -743,7 +903,7 @@ $!    Use GNU C...
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$     IF F$TYPE(GCC) .EQS. "" THEN GCC := GCC
 | 
					$     IF F$TYPE(GCC) .EQS. "" THEN GCC := GCC
 | 
				
			||||||
$     CC = GCC+"/NOCASE_HACK/''GCC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
					$     CC = GCC+"/NOCASE_HACK/''GCC_OPTIMIZE'/''DEBUGGER'/NOLIST" + -
 | 
				
			||||||
	   "/INCLUDE=(SYS$DISK:[-],SYS$DISK:[-.CRYPTO])" + CCEXTRAFLAGS
 | 
						   "/INCLUDE=(SYS$DISK:[-])" + CCEXTRAFLAGS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Define The Linker Options File Name.
 | 
					$!    Define The Linker Options File Name.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -757,6 +917,31 @@ $!  Set up default defines
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$   CCDEFS = """FLAT_INC=1""," + CCDEFS
 | 
					$   CCDEFS = """FLAT_INC=1""," + CCDEFS
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
 | 
					$!  Check To See If We Are To Compile With RSAREF Routines.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   IF (RSAREF.EQS."TRUE")
 | 
				
			||||||
 | 
					$   THEN
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Compile With RSAREF.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     CCDEFS = CCDEFS + ",""RSAref=1"""
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Tell The User This.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "Compiling With RSAREF Routines."
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Else, We Don't Care.  Compile Without The RSAREF Library.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ELSE
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!    Tell The User We Are Compile Without The RSAREF Routines.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$     WRITE SYS$OUTPUT "Compiling Without The RSAREF Routines.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$!  End The RSAREF Check.
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
 | 
					$   ENDIF
 | 
				
			||||||
 | 
					$!
 | 
				
			||||||
$!  Else The User Entered An Invalid Arguement.
 | 
					$!  Else The User Entered An Invalid Arguement.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ELSE
 | 
					$ ELSE
 | 
				
			||||||
@@ -764,7 +949,7 @@ $!
 | 
				
			|||||||
$!  Tell The User We Don't Know What They Want.
 | 
					$!  Tell The User We Don't Know What They Want.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   WRITE SYS$OUTPUT ""
 | 
					$   WRITE SYS$OUTPUT ""
 | 
				
			||||||
$   WRITE SYS$OUTPUT "The Option ",P2," Is Invalid.  The Valid Options Are:"
 | 
					$   WRITE SYS$OUTPUT "The Option ",P3," Is Invalid.  The Valid Options Are:"
 | 
				
			||||||
$   WRITE SYS$OUTPUT ""
 | 
					$   WRITE SYS$OUTPUT ""
 | 
				
			||||||
$   WRITE SYS$OUTPUT "    VAXC  :  To Compile With VAX C."
 | 
					$   WRITE SYS$OUTPUT "    VAXC  :  To Compile With VAX C."
 | 
				
			||||||
$   WRITE SYS$OUTPUT "    DECC  :  To Compile With DEC C."
 | 
					$   WRITE SYS$OUTPUT "    DECC  :  To Compile With DEC C."
 | 
				
			||||||
@@ -778,18 +963,17 @@ $ ENDIF
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$! Time to check the contents, and to make sure we get the correct library.
 | 
					$! Time to check the contents, and to make sure we get the correct library.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF P3.EQS."SOCKETSHR" .OR. P3.EQS."MULTINET" .OR. P3.EQS."UCX" -
 | 
					$ IF P4.EQS."SOCKETSHR" .OR. P4.EQS."MULTINET" .OR. P4.EQS."UCX"
 | 
				
			||||||
     .OR. P3.EQS."TCPIP" .OR. P3.EQS."NONE"
 | 
					 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check to see if SOCKETSHR was chosen
 | 
					$!  Check to see if SOCKETSHR was chosen
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF P3.EQS."SOCKETSHR"
 | 
					$   IF P4.EQS."SOCKETSHR"
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Set the library to use SOCKETSHR
 | 
					$!    Set the library to use SOCKETSHR
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     TCPIP_LIB = "SYS$DISK:[-.VMS]SOCKETSHR_SHR.OPT/OPT"
 | 
					$     TCPIP_LIB = "[-.VMS]SOCKETSHR_SHR.OPT/OPT"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Done with SOCKETSHR
 | 
					$!    Done with SOCKETSHR
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -797,12 +981,12 @@ $   ENDIF
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check to see if MULTINET was chosen
 | 
					$!  Check to see if MULTINET was chosen
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF P3.EQS."MULTINET"
 | 
					$   IF P4.EQS."MULTINET"
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Set the library to use UCX emulation.
 | 
					$!    Set the library to use UCX emulation.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     P3 = "UCX"
 | 
					$     P4 = "UCX"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Done with MULTINET
 | 
					$!    Done with MULTINET
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -810,53 +994,27 @@ $   ENDIF
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check to see if UCX was chosen
 | 
					$!  Check to see if UCX was chosen
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   IF P3.EQS."UCX"
 | 
					$   IF P4.EQS."UCX"
 | 
				
			||||||
$   THEN
 | 
					$   THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Set the library to use UCX.
 | 
					$!    Set the library to use UCX.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$     TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_DECC.OPT/OPT"
 | 
					$     TCPIP_LIB = "[-.VMS]UCX_SHR_DECC.OPT/OPT"
 | 
				
			||||||
$     IF F$TRNLNM("UCX$IPC_SHR") .NES. ""
 | 
					$     IF F$TRNLNM("UCX$IPC_SHR") .NES. ""
 | 
				
			||||||
$     THEN
 | 
					$     THEN
 | 
				
			||||||
$       TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_DECC_LOG.OPT/OPT"
 | 
					$       TCPIP_LIB = "[-.VMS]UCX_SHR_DECC_LOG.OPT/OPT"
 | 
				
			||||||
$     ELSE
 | 
					$     ELSE
 | 
				
			||||||
$       IF COMPILER .NES. "DECC" .AND. ARCH .EQS. "VAX" THEN -
 | 
					$       IF COMPILER .NES. "DECC" .AND. ARCH .EQS. "VAX" THEN -
 | 
				
			||||||
	  TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_VAXC.OPT/OPT"
 | 
						  TCPIP_LIB = "[-.VMS]UCX_SHR_VAXC.OPT/OPT"
 | 
				
			||||||
$     ENDIF
 | 
					$     ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!    Done with UCX
 | 
					$!    Done with UCX
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Check to see if TCPIP (post UCX) was chosen
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   IF P3.EQS."TCPIP"
 | 
					 | 
				
			||||||
$   THEN
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!    Set the library to use TCPIP.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$     TCPIP_LIB = "SYS$DISK:[-.VMS]TCPIP_SHR_DECC.OPT/OPT"
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!    Done with TCPIP
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   ENDIF
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  Check to see if NONE was chosen
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   IF P3.EQS."NONE"
 | 
					 | 
				
			||||||
$   THEN
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!    Do not use TCPIP.
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$     TCPIP_LIB = ""
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!    Done with TCPIP
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$   ENDIF
 | 
					 | 
				
			||||||
$!
 | 
					 | 
				
			||||||
$!  Add TCP/IP type to CC definitions.
 | 
					$!  Add TCP/IP type to CC definitions.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   CCDEFS = CCDEFS + ",TCPIP_TYPE_''P3'"
 | 
					$   CCDEFS = CCDEFS + ",TCPIP_TYPE_''P4'"
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Print info
 | 
					$!  Print info
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -869,11 +1027,10 @@ $!
 | 
				
			|||||||
$!  Tell The User We Don't Know What They Want.
 | 
					$!  Tell The User We Don't Know What They Want.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$   WRITE SYS$OUTPUT ""
 | 
					$   WRITE SYS$OUTPUT ""
 | 
				
			||||||
$   WRITE SYS$OUTPUT "The Option ",P3," Is Invalid.  The Valid Options Are:"
 | 
					$   WRITE SYS$OUTPUT "The Option ",P4," Is Invalid.  The Valid Options Are:"
 | 
				
			||||||
$   WRITE SYS$OUTPUT ""
 | 
					$   WRITE SYS$OUTPUT ""
 | 
				
			||||||
$   WRITE SYS$OUTPUT "    SOCKETSHR  :  To link with SOCKETSHR TCP/IP library."
 | 
					$   WRITE SYS$OUTPUT "    SOCKETSHR  :  To link with SOCKETSHR TCP/IP library."
 | 
				
			||||||
$   WRITE SYS$OUTPUT "    UCX        :  To link with UCX TCP/IP library."
 | 
					$   WRITE SYS$OUTPUT "    UCX        :  To link with UCX TCP/IP library."
 | 
				
			||||||
$   WRITE SYS$OUTPUT "    TCPIP      :  To link with TCPIP (post UCX) TCP/IP library."
 | 
					 | 
				
			||||||
$   WRITE SYS$OUTPUT ""
 | 
					$   WRITE SYS$OUTPUT ""
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Time To EXIT.
 | 
					$!  Time To EXIT.
 | 
				
			||||||
@@ -900,7 +1057,7 @@ $ CC = CC + "/DEFINE=(" + CCDEFS + ")" + CCDISABLEWARNINGS
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$! Show user the result
 | 
					$! Show user the result
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ WRITE/SYMBOL SYS$OUTPUT "Main Compiling Command: ",CC
 | 
					$ WRITE SYS$OUTPUT "Main Compiling Command: ",CC
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Special Threads For OpenVMS v7.1 Or Later
 | 
					$! Special Threads For OpenVMS v7.1 Or Later
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
@@ -908,9 +1065,9 @@ $! Written By:  Richard Levitte
 | 
				
			|||||||
$!              richard@levitte.org
 | 
					$!              richard@levitte.org
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check To See If We Have A Option For P4.
 | 
					$! Check To See If We Have A Option For P5.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF (P4.EQS."")
 | 
					$ IF (P5.EQS."")
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Get The Version Of VMS We Are Using.
 | 
					$!  Get The Version Of VMS We Are Using.
 | 
				
			||||||
@@ -932,15 +1089,15 @@ $!  End The VMS Version Check.
 | 
				
			|||||||
$!
 | 
					$!
 | 
				
			||||||
$   ENDIF
 | 
					$   ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! End The P4 Check.
 | 
					$! End The P5 Check.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$! Check if the user wanted to compile just a subset of all the programs.
 | 
					$! Check if the user wanted to compile just a subset of all the programs.
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$ IF P5 .NES. ""
 | 
					$ IF P6 .NES. ""
 | 
				
			||||||
$ THEN
 | 
					$ THEN
 | 
				
			||||||
$   PROGRAMS = P5
 | 
					$   PROGRAMS = P6
 | 
				
			||||||
$ ENDIF
 | 
					$ ENDIF
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
$!  Time To RETURN...
 | 
					$!  Time To RETURN...
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -58,9 +58,9 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include "apps.h"
 | 
					 | 
				
			||||||
#include <openssl/pem.h>
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
#include <openssl/err.h>
 | 
					#include <openssl/err.h>
 | 
				
			||||||
 | 
					#include "apps.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#undef PROG
 | 
					#undef PROG
 | 
				
			||||||
#define PROG nseq_main
 | 
					#define PROG nseq_main
 | 
				
			||||||
@@ -102,7 +102,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf (bio_err, "-in file  input file\n");
 | 
							BIO_printf (bio_err, "-in file  input file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-out file output file\n");
 | 
							BIO_printf (bio_err, "-out file output file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-toseq    output NS Sequence file\n");
 | 
							BIO_printf (bio_err, "-toseq    output NS Sequence file\n");
 | 
				
			||||||
		OPENSSL_EXIT(1);
 | 
							EXIT(1);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (infile) {
 | 
						if (infile) {
 | 
				
			||||||
@@ -162,6 +162,6 @@ end:
 | 
				
			|||||||
	BIO_free_all(out);
 | 
						BIO_free_all(out);
 | 
				
			||||||
	NETSCAPE_CERT_SEQUENCE_free(seq);
 | 
						NETSCAPE_CERT_SEQUENCE_free(seq);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										114
									
								
								apps/ocsp.c
									
									
									
									
									
								
							
							
						
						
									
										114
									
								
								apps/ocsp.c
									
									
									
									
									
								
							@@ -55,19 +55,31 @@
 | 
				
			|||||||
 * Hudson (tjh@cryptsoft.com).
 | 
					 * Hudson (tjh@cryptsoft.com).
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
#ifndef OPENSSL_NO_OCSP
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include "apps.h"
 | 
					 | 
				
			||||||
#include <openssl/pem.h>
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
#include <openssl/ocsp.h>
 | 
					#include <openssl/ocsp.h>
 | 
				
			||||||
#include <openssl/err.h>
 | 
					#include <openssl/err.h>
 | 
				
			||||||
#include <openssl/ssl.h>
 | 
					#include <openssl/ssl.h>
 | 
				
			||||||
 | 
					#include "apps.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Maximum leeway in validity period: default 5 minutes */
 | 
					/* Maximum leeway in validity period: default 5 minutes */
 | 
				
			||||||
#define MAX_VALIDITY_PERIOD	(5 * 60)
 | 
					#define MAX_VALIDITY_PERIOD	(5 * 60)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* CA index.txt definitions */
 | 
				
			||||||
 | 
					#define DB_type         0
 | 
				
			||||||
 | 
					#define DB_exp_date     1
 | 
				
			||||||
 | 
					#define DB_rev_date     2
 | 
				
			||||||
 | 
					#define DB_serial       3       /* index - unique */
 | 
				
			||||||
 | 
					#define DB_file         4       
 | 
				
			||||||
 | 
					#define DB_name         5       /* index - unique for active */
 | 
				
			||||||
 | 
					#define DB_NUMBER       6
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define DB_TYPE_REV	'R'
 | 
				
			||||||
 | 
					#define DB_TYPE_EXP	'E'
 | 
				
			||||||
 | 
					#define DB_TYPE_VAL	'V'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int add_ocsp_cert(OCSP_REQUEST **req, X509 *cert, X509 *issuer,
 | 
					static int add_ocsp_cert(OCSP_REQUEST **req, X509 *cert, X509 *issuer,
 | 
				
			||||||
				STACK_OF(OCSP_CERTID) *ids);
 | 
									STACK_OF(OCSP_CERTID) *ids);
 | 
				
			||||||
static int add_ocsp_serial(OCSP_REQUEST **req, char *serial, X509 *issuer,
 | 
					static int add_ocsp_serial(OCSP_REQUEST **req, char *serial, X509 *issuer,
 | 
				
			||||||
@@ -76,12 +88,12 @@ static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
				
			|||||||
				STACK *names, STACK_OF(OCSP_CERTID) *ids,
 | 
									STACK *names, STACK_OF(OCSP_CERTID) *ids,
 | 
				
			||||||
				long nsec, long maxage);
 | 
									long nsec, long maxage);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int make_ocsp_response(OCSP_RESPONSE **resp, OCSP_REQUEST *req, CA_DB *db,
 | 
					static int make_ocsp_response(OCSP_RESPONSE **resp, OCSP_REQUEST *req, TXT_DB *db,
 | 
				
			||||||
			X509 *ca, X509 *rcert, EVP_PKEY *rkey,
 | 
								X509 *ca, X509 *rcert, EVP_PKEY *rkey,
 | 
				
			||||||
			STACK_OF(X509) *rother, unsigned long flags,
 | 
								STACK_OF(X509) *rother, unsigned long flags,
 | 
				
			||||||
			int nmin, int ndays);
 | 
								int nmin, int ndays);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static char **lookup_serial(CA_DB *db, ASN1_INTEGER *ser);
 | 
					static char **lookup_serial(TXT_DB *db, ASN1_INTEGER *ser);
 | 
				
			||||||
static BIO *init_responder(char *port);
 | 
					static BIO *init_responder(char *port);
 | 
				
			||||||
static int do_responder(OCSP_REQUEST **preq, BIO **pcbio, BIO *acbio, char *port);
 | 
					static int do_responder(OCSP_REQUEST **preq, BIO **pcbio, BIO *acbio, char *port);
 | 
				
			||||||
static int send_ocsp_response(BIO *cbio, OCSP_RESPONSE *resp);
 | 
					static int send_ocsp_response(BIO *cbio, OCSP_RESPONSE *resp);
 | 
				
			||||||
@@ -123,14 +135,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int accept_count = -1;
 | 
						int accept_count = -1;
 | 
				
			||||||
	int badarg = 0;
 | 
						int badarg = 0;
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	int ignore_err = 0;
 | 
					 | 
				
			||||||
	STACK *reqnames = NULL;
 | 
						STACK *reqnames = NULL;
 | 
				
			||||||
	STACK_OF(OCSP_CERTID) *ids = NULL;
 | 
						STACK_OF(OCSP_CERTID) *ids = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	X509 *rca_cert = NULL;
 | 
						X509 *rca_cert = NULL;
 | 
				
			||||||
	char *ridx_filename = NULL;
 | 
						char *ridx_filename = NULL;
 | 
				
			||||||
	char *rca_filename = NULL;
 | 
						char *rca_filename = NULL;
 | 
				
			||||||
	CA_DB *rdb = NULL;
 | 
						TXT_DB *rdb = NULL;
 | 
				
			||||||
	int nmin = 0, ndays = -1;
 | 
						int nmin = 0, ndays = -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (bio_err == NULL) bio_err = BIO_new_fp(stderr, BIO_NOCLOSE);
 | 
						if (bio_err == NULL) bio_err = BIO_new_fp(stderr, BIO_NOCLOSE);
 | 
				
			||||||
@@ -183,8 +194,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			else badarg = 1;
 | 
								else badarg = 1;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!strcmp(*args, "-ignore_err"))
 | 
					 | 
				
			||||||
			ignore_err = 1;
 | 
					 | 
				
			||||||
		else if (!strcmp(*args, "-noverify"))
 | 
							else if (!strcmp(*args, "-noverify"))
 | 
				
			||||||
			noverify = 1;
 | 
								noverify = 1;
 | 
				
			||||||
		else if (!strcmp(*args, "-nonce"))
 | 
							else if (!strcmp(*args, "-nonce"))
 | 
				
			||||||
@@ -514,7 +523,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf (bio_err, "-serial n          serial number to check\n");
 | 
							BIO_printf (bio_err, "-serial n          serial number to check\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-signer file       certificate to sign OCSP request with\n");
 | 
							BIO_printf (bio_err, "-signer file       certificate to sign OCSP request with\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-signkey file      private key to sign OCSP request with\n");
 | 
							BIO_printf (bio_err, "-signkey file      private key to sign OCSP request with\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-sign_other file   additional certificates to include in signed request\n");
 | 
							BIO_printf (bio_err, "-sign_certs file   additional certificates to include in signed request\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-no_certs          don't include any certificates in signed request\n");
 | 
							BIO_printf (bio_err, "-no_certs          don't include any certificates in signed request\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-req_text          print text form of request\n");
 | 
							BIO_printf (bio_err, "-req_text          print text form of request\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-resp_text         print text form of response\n");
 | 
							BIO_printf (bio_err, "-resp_text         print text form of response\n");
 | 
				
			||||||
@@ -534,18 +543,18 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf (bio_err, "-validity_period n maximum validity discrepancy in seconds\n");
 | 
							BIO_printf (bio_err, "-validity_period n maximum validity discrepancy in seconds\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-status_age n      maximum status age in seconds\n");
 | 
							BIO_printf (bio_err, "-status_age n      maximum status age in seconds\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-noverify          don't verify response at all\n");
 | 
							BIO_printf (bio_err, "-noverify          don't verify response at all\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-verify_other file additional certificates to search for signer\n");
 | 
							BIO_printf (bio_err, "-verify_certs file additional certificates to search for signer\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-trust_other       don't verify additional certificates\n");
 | 
							BIO_printf (bio_err, "-trust_other       don't verify additional certificates\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-no_intern         don't search certificates contained in response for signer\n");
 | 
							BIO_printf (bio_err, "-no_intern         don't search certificates contained in response for signer\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-no_signature_verify don't check signature on response\n");
 | 
							BIO_printf (bio_err, "-no_sig_verify     don't check signature on response\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-no_cert_verify    don't check signing certificate\n");
 | 
							BIO_printf (bio_err, "-no_cert_verify    don't check signing certificate\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-no_chain          don't chain verify response\n");
 | 
							BIO_printf (bio_err, "-no_chain          don't chain verify response\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-no_cert_checks    don't do additional checks on signing certificate\n");
 | 
							BIO_printf (bio_err, "-no_cert_checks    don't do additional checks on signing certificate\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-port num		 port to run responder on\n");
 | 
							BIO_printf (bio_err, "-port num		 port to run responder on\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-index file	 certificate status index file\n");
 | 
							BIO_printf (bio_err, "-index file	 certificate status index file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-CA file		 CA certificate\n");
 | 
							BIO_printf (bio_err, "-CA file		 CA certificate\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-rsigner file	 responder certificate to sign responses with\n");
 | 
							BIO_printf (bio_err, "-rsigner file	 responder certificate to sign requests with\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-rkey file	 responder key to sign responses with\n");
 | 
							BIO_printf (bio_err, "-rkey file	 responder key to sign requests with\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-rother file	 other certificates to include in response\n");
 | 
							BIO_printf (bio_err, "-rother file	 other certificates to include in response\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-resp_no_certs     don't include any certificates in response\n");
 | 
							BIO_printf (bio_err, "-resp_no_certs     don't include any certificates in response\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-nmin n	 	 number of minutes before next update\n");
 | 
							BIO_printf (bio_err, "-nmin n	 	 number of minutes before next update\n");
 | 
				
			||||||
@@ -604,11 +613,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			NULL, e, "CA certificate");
 | 
								NULL, e, "CA certificate");
 | 
				
			||||||
		if (rcertfile)
 | 
							if (rcertfile)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			rother = load_certs(bio_err, rcertfile, FORMAT_PEM,
 | 
								rother = load_certs(bio_err, sign_certfile, FORMAT_PEM,
 | 
				
			||||||
				NULL, e, "responder other certificates");
 | 
									NULL, e, "responder other certificates");
 | 
				
			||||||
			if (!rother) goto end;
 | 
								if (!sign_other) goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		rkey = load_key(bio_err, rkeyfile, FORMAT_PEM, 0, NULL, NULL,
 | 
							rkey = load_key(bio_err, rkeyfile, FORMAT_PEM, NULL, NULL,
 | 
				
			||||||
			"responder private key");
 | 
								"responder private key");
 | 
				
			||||||
		if (!rkey)
 | 
							if (!rkey)
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
@@ -654,7 +663,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				NULL, e, "signer certificates");
 | 
									NULL, e, "signer certificates");
 | 
				
			||||||
			if (!sign_other) goto end;
 | 
								if (!sign_other) goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		key = load_key(bio_err, keyfile, FORMAT_PEM, 0, NULL, NULL,
 | 
							key = load_key(bio_err, keyfile, FORMAT_PEM, NULL, NULL,
 | 
				
			||||||
			"signer private key");
 | 
								"signer private key");
 | 
				
			||||||
		if (!key)
 | 
							if (!key)
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
@@ -667,18 +676,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (req_text && req) OCSP_REQUEST_print(out, req, 0);
 | 
						if (req_text && req) OCSP_REQUEST_print(out, req, 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (reqout)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		derbio = BIO_new_file(reqout, "wb");
 | 
					 | 
				
			||||||
		if(!derbio)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Error opening file %s\n", reqout);
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		i2d_OCSP_REQUEST_bio(derbio, req);
 | 
					 | 
				
			||||||
		BIO_free(derbio);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (ridx_filename && (!rkey || !rsigner || !rca_cert))
 | 
						if (ridx_filename && (!rkey || !rsigner || !rca_cert))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_err, "Need a responder certificate, key and CA for this operation!\n");
 | 
							BIO_printf(bio_err, "Need a responder certificate, key and CA for this operation!\n");
 | 
				
			||||||
@@ -687,9 +684,22 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (ridx_filename && !rdb)
 | 
						if (ridx_filename && !rdb)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		rdb = load_index(ridx_filename, NULL);
 | 
							BIO *db_bio = NULL;
 | 
				
			||||||
		if (!rdb) goto end;
 | 
							db_bio = BIO_new_file(ridx_filename, "r");
 | 
				
			||||||
		if (!index_index(rdb)) goto end;
 | 
							if (!db_bio)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "Error opening index file %s\n", ridx_filename);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							rdb = TXT_DB_read(db_bio, DB_NUMBER);
 | 
				
			||||||
 | 
							BIO_free(db_bio);
 | 
				
			||||||
 | 
							if (!rdb)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "Error reading index file %s\n", ridx_filename);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							if (!make_serial_index(rdb))
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (rdb)
 | 
						if (rdb)
 | 
				
			||||||
@@ -700,12 +710,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	else if (host)
 | 
						else if (host)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
#ifndef OPENSSL_NO_SOCK
 | 
					 | 
				
			||||||
		cbio = BIO_new_connect(host);
 | 
							cbio = BIO_new_connect(host);
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error creating connect BIO - sockets not supported.\n");
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		if (!cbio)
 | 
							if (!cbio)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err, "Error creating connect BIO\n");
 | 
								BIO_printf(bio_err, "Error creating connect BIO\n");
 | 
				
			||||||
@@ -715,16 +720,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if (use_ssl == 1)
 | 
							if (use_ssl == 1)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO *sbio;
 | 
								BIO *sbio;
 | 
				
			||||||
#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
					 | 
				
			||||||
			ctx = SSL_CTX_new(SSLv23_client_method());
 | 
								ctx = SSL_CTX_new(SSLv23_client_method());
 | 
				
			||||||
#elif !defined(OPENSSL_NO_SSL3)
 | 
					 | 
				
			||||||
			ctx = SSL_CTX_new(SSLv3_client_method());
 | 
					 | 
				
			||||||
#elif !defined(OPENSSL_NO_SSL2)
 | 
					 | 
				
			||||||
			ctx = SSL_CTX_new(SSLv2_client_method());
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "SSL is disabled\n");
 | 
					 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
 | 
								SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
 | 
				
			||||||
			sbio = BIO_new_ssl(ctx, 1);
 | 
								sbio = BIO_new_ssl(ctx, 1);
 | 
				
			||||||
			cbio = BIO_push(sbio, cbio);
 | 
								cbio = BIO_push(sbio, cbio);
 | 
				
			||||||
@@ -786,8 +782,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(out, "Responder Error: %s (%ld)\n",
 | 
							BIO_printf(out, "Responder Error: %s (%ld)\n",
 | 
				
			||||||
				OCSP_response_status_str(i), i);
 | 
									OCSP_response_status_str(i), i);
 | 
				
			||||||
		if (ignore_err)
 | 
					 | 
				
			||||||
			goto redo_accept;
 | 
					 | 
				
			||||||
		ret = 0;
 | 
							ret = 0;
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -815,8 +809,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (!store)
 | 
						if (!store)
 | 
				
			||||||
		store = setup_verify(bio_err, CAfile, CApath);
 | 
							store = setup_verify(bio_err, CAfile, CApath);
 | 
				
			||||||
	if (!store)
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
	if (verify_certfile)
 | 
						if (verify_certfile)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		verify_other = load_certs(bio_err, verify_certfile, FORMAT_PEM,
 | 
							verify_other = load_certs(bio_err, verify_certfile, FORMAT_PEM,
 | 
				
			||||||
@@ -873,7 +865,7 @@ end:
 | 
				
			|||||||
	X509_free(cert);
 | 
						X509_free(cert);
 | 
				
			||||||
	X509_free(rsigner);
 | 
						X509_free(rsigner);
 | 
				
			||||||
	X509_free(rca_cert);
 | 
						X509_free(rca_cert);
 | 
				
			||||||
	free_index(rdb);
 | 
						TXT_DB_free(rdb);
 | 
				
			||||||
	BIO_free_all(cbio);
 | 
						BIO_free_all(cbio);
 | 
				
			||||||
	BIO_free_all(acbio);
 | 
						BIO_free_all(acbio);
 | 
				
			||||||
	BIO_free(out);
 | 
						BIO_free(out);
 | 
				
			||||||
@@ -893,7 +885,7 @@ end:
 | 
				
			|||||||
		SSL_CTX_free(ctx);
 | 
							SSL_CTX_free(ctx);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int add_ocsp_cert(OCSP_REQUEST **req, X509 *cert, X509 *issuer,
 | 
					static int add_ocsp_cert(OCSP_REQUEST **req, X509 *cert, X509 *issuer,
 | 
				
			||||||
@@ -1015,7 +1007,7 @@ static int print_ocsp_summary(BIO *out, OCSP_BASICRESP *bs, OCSP_REQUEST *req,
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int make_ocsp_response(OCSP_RESPONSE **resp, OCSP_REQUEST *req, CA_DB *db,
 | 
					static int make_ocsp_response(OCSP_RESPONSE **resp, OCSP_REQUEST *req, TXT_DB *db,
 | 
				
			||||||
			X509 *ca, X509 *rcert, EVP_PKEY *rkey,
 | 
								X509 *ca, X509 *rcert, EVP_PKEY *rkey,
 | 
				
			||||||
			STACK_OF(X509) *rother, unsigned long flags,
 | 
								STACK_OF(X509) *rother, unsigned long flags,
 | 
				
			||||||
			int nmin, int ndays)
 | 
								int nmin, int ndays)
 | 
				
			||||||
@@ -1107,20 +1099,17 @@ static int make_ocsp_response(OCSP_RESPONSE **resp, OCSP_REQUEST *req, CA_DB *db
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static char **lookup_serial(CA_DB *db, ASN1_INTEGER *ser)
 | 
					static char **lookup_serial(TXT_DB *db, ASN1_INTEGER *ser)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	BIGNUM *bn = NULL;
 | 
						BIGNUM *bn = NULL;
 | 
				
			||||||
	char *itmp, *row[DB_NUMBER],**rrow;
 | 
						char *itmp, *row[DB_NUMBER],**rrow;
 | 
				
			||||||
	for (i = 0; i < DB_NUMBER; i++) row[i] = NULL;
 | 
						for (i = 0; i < DB_NUMBER; i++) row[i] = NULL;
 | 
				
			||||||
	bn = ASN1_INTEGER_to_BN(ser,NULL);
 | 
						bn = ASN1_INTEGER_to_BN(ser,NULL);
 | 
				
			||||||
	if (BN_is_zero(bn))
 | 
						itmp = BN_bn2hex(bn);
 | 
				
			||||||
		itmp = BUF_strdup("00");
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		itmp = BN_bn2hex(bn);
 | 
					 | 
				
			||||||
	row[DB_serial] = itmp;
 | 
						row[DB_serial] = itmp;
 | 
				
			||||||
	BN_free(bn);
 | 
						BN_free(bn);
 | 
				
			||||||
	rrow=TXT_DB_get_by_index(db->db,DB_serial,row);
 | 
						rrow=TXT_DB_get_by_index(db,DB_serial,row);
 | 
				
			||||||
	OPENSSL_free(itmp);
 | 
						OPENSSL_free(itmp);
 | 
				
			||||||
	return rrow;
 | 
						return rrow;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -1133,11 +1122,7 @@ static BIO *init_responder(char *port)
 | 
				
			|||||||
	bufbio = BIO_new(BIO_f_buffer());
 | 
						bufbio = BIO_new(BIO_f_buffer());
 | 
				
			||||||
	if (!bufbio) 
 | 
						if (!bufbio) 
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
#ifndef OPENSSL_NO_SOCK
 | 
					 | 
				
			||||||
	acbio = BIO_new_accept(port);
 | 
						acbio = BIO_new_accept(port);
 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
	BIO_printf(bio_err, "Error setting up accept BIO - sockets not supported.\n");
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if (!acbio)
 | 
						if (!acbio)
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
	BIO_set_accept_bios(acbio, bufbio);
 | 
						BIO_set_accept_bios(acbio, bufbio);
 | 
				
			||||||
@@ -1177,7 +1162,7 @@ static int do_responder(OCSP_REQUEST **preq, BIO **pcbio, BIO *acbio, char *port
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	for(;;)
 | 
						for(;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		len = BIO_gets(cbio, inbuf, sizeof inbuf);
 | 
							len = BIO_gets(cbio, inbuf, 1024);
 | 
				
			||||||
		if (len <= 0)
 | 
							if (len <= 0)
 | 
				
			||||||
			return 1;
 | 
								return 1;
 | 
				
			||||||
		/* Look for "POST" signalling start of query */
 | 
							/* Look for "POST" signalling start of query */
 | 
				
			||||||
@@ -1224,4 +1209,3 @@ static int send_ocsp_response(BIO *cbio, OCSP_RESPONSE *resp)
 | 
				
			|||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,13 +3,8 @@
 | 
				
			|||||||
# This is mostly being used for generation of certificate requests.
 | 
					# This is mostly being used for generation of certificate requests.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This definition stops the following lines choking if HOME isn't
 | 
					 | 
				
			||||||
# defined.
 | 
					 | 
				
			||||||
HOME			= .
 | 
					 | 
				
			||||||
RANDFILE		= $ENV::HOME/.rnd
 | 
					RANDFILE		= $ENV::HOME/.rnd
 | 
				
			||||||
 | 
					oid_file		= $ENV::HOME/.oid
 | 
				
			||||||
# Extra OBJECT IDENTIFIER info:
 | 
					 | 
				
			||||||
#oid_file		= $ENV::HOME/.oid
 | 
					 | 
				
			||||||
oid_section		= new_oids
 | 
					oid_section		= new_oids
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# To use this configuration file with the "-extfile" option of the
 | 
					# To use this configuration file with the "-extfile" option of the
 | 
				
			||||||
@@ -34,35 +29,22 @@ default_ca	= CA_default		# The default ca section
 | 
				
			|||||||
####################################################################
 | 
					####################################################################
 | 
				
			||||||
[ CA_default ]
 | 
					[ CA_default ]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
dir		= sys\$disk:[.demoCA		# Where everything is kept
 | 
					dir		= sys\$disk:[.demoCA	# Where everything is kept
 | 
				
			||||||
certs		= $dir.certs]		# Where the issued certs are kept
 | 
					certs		= $dir.certs]		# Where the issued certs are kept
 | 
				
			||||||
crl_dir		= $dir.crl]		# Where the issued crl are kept
 | 
					crl_dir		= $dir.crl]		# Where the issued crl are kept
 | 
				
			||||||
database	= $dir]index.txt	# database index file.
 | 
					database	= $dir]index.txt	# database index file.
 | 
				
			||||||
#unique_subject	= no			# Set to 'no' to allow creation of
 | 
					new_certs_dir	= $dir.newcerts]	# default place for new certs.
 | 
				
			||||||
					# several ctificates with same subject.
 | 
					 | 
				
			||||||
new_certs_dir	= $dir.newcerts]		# default place for new certs.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
certificate	= $dir]cacert.pem 	# The CA certificate
 | 
					certificate	= $dir]cacert.pem 	# The CA certificate
 | 
				
			||||||
serial		= $dir]serial. 		# The current serial number
 | 
					serial		= $dir]serial.		# The current serial number
 | 
				
			||||||
#crlnumber	= $dir]crlnumber.	# the current crl number must be
 | 
					 | 
				
			||||||
					# commented out to leave a V1 CRL
 | 
					 | 
				
			||||||
crl		= $dir]crl.pem 		# The current CRL
 | 
					crl		= $dir]crl.pem 		# The current CRL
 | 
				
			||||||
private_key	= $dir.private]cakey.pem# The private key
 | 
					private_key	= $dir.private]cakey.pem# The private key
 | 
				
			||||||
RANDFILE	= $dir.private].rand	# private random number file
 | 
					RANDFILE	= $dir.private].rand	# private random number file
 | 
				
			||||||
 | 
					
 | 
				
			||||||
x509_extensions	= usr_cert		# The extentions to add to the cert
 | 
					x509_extensions	= usr_cert		# The extentions to add to the cert
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Comment out the following two lines for the "traditional"
 | 
					 | 
				
			||||||
# (and highly broken) format.
 | 
					 | 
				
			||||||
name_opt 	= ca_default		# Subject Name options
 | 
					 | 
				
			||||||
cert_opt 	= ca_default		# Certificate field options
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Extension copying option: use with caution.
 | 
					 | 
				
			||||||
# copy_extensions = copy
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Extensions to add to a CRL. Note: Netscape communicator chokes on V2 CRLs
 | 
					# Extensions to add to a CRL. Note: Netscape communicator chokes on V2 CRLs
 | 
				
			||||||
# so this is commented out by default to leave a V1 CRL.
 | 
					# so this is commented out by default to leave a V1 CRL.
 | 
				
			||||||
# crlnumber must also be commented out to leave a V1 CRL.
 | 
					 | 
				
			||||||
# crl_extensions	= crl_ext
 | 
					# crl_extensions	= crl_ext
 | 
				
			||||||
 | 
					
 | 
				
			||||||
default_days	= 365			# how long to certify for
 | 
					default_days	= 365			# how long to certify for
 | 
				
			||||||
@@ -104,19 +86,16 @@ distinguished_name	= req_distinguished_name
 | 
				
			|||||||
attributes		= req_attributes
 | 
					attributes		= req_attributes
 | 
				
			||||||
x509_extensions	= v3_ca	# The extentions to add to the self signed cert
 | 
					x509_extensions	= v3_ca	# The extentions to add to the self signed cert
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Passwords for private keys if not present they will be prompted for
 | 
					# This sets the permitted types in a DirectoryString. There are several
 | 
				
			||||||
# input_password = secret
 | 
					# options. 
 | 
				
			||||||
# output_password = secret
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This sets a mask for permitted string types. There are several options. 
 | 
					 | 
				
			||||||
# default: PrintableString, T61String, BMPString.
 | 
					# default: PrintableString, T61String, BMPString.
 | 
				
			||||||
# pkix	 : PrintableString, BMPString.
 | 
					# pkix	 : PrintableString, BMPString.
 | 
				
			||||||
# utf8only: only UTF8Strings.
 | 
					# utf8only: only UTF8Strings.
 | 
				
			||||||
# nombstr : PrintableString, T61String (no BMPStrings or UTF8Strings).
 | 
					# nobmp : PrintableString, T61String (no BMPStrings).
 | 
				
			||||||
# MASK:XXXX a literal mask value.
 | 
					# MASK:XXXX a literal mask value.
 | 
				
			||||||
# WARNING: current versions of Netscape crash on BMPStrings or UTF8Strings
 | 
					# WARNING: current versions of Netscape crash on BMPStrings or UTF8Strings
 | 
				
			||||||
# so use this option with caution!
 | 
					# so use this option with caution!
 | 
				
			||||||
string_mask = nombstr
 | 
					dirstring_type = nobmp
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# req_extensions = v3_req # The extensions to add to a certificate request
 | 
					# req_extensions = v3_req # The extensions to add to a certificate request
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -145,7 +124,7 @@ commonName			= Common Name (eg, YOUR name)
 | 
				
			|||||||
commonName_max			= 64
 | 
					commonName_max			= 64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
emailAddress			= Email Address
 | 
					emailAddress			= Email Address
 | 
				
			||||||
emailAddress_max		= 64
 | 
					emailAddress_max		= 40
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# SET-ex3			= SET extension number 3
 | 
					# SET-ex3			= SET extension number 3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -193,9 +172,6 @@ authorityKeyIdentifier=keyid,issuer:always
 | 
				
			|||||||
# This stuff is for subjectAltName and issuerAltname.
 | 
					# This stuff is for subjectAltName and issuerAltname.
 | 
				
			||||||
# Import the email address.
 | 
					# Import the email address.
 | 
				
			||||||
# subjectAltName=email:copy
 | 
					# subjectAltName=email:copy
 | 
				
			||||||
# An alternative to produce certificates that aren't
 | 
					 | 
				
			||||||
# deprecated according to PKIX.
 | 
					 | 
				
			||||||
# subjectAltName=email:move
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Copy subject details
 | 
					# Copy subject details
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
@@ -258,56 +234,3 @@ basicConstraints = CA:true
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
authorityKeyIdentifier=keyid:always,issuer:always
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					 | 
				
			||||||
[ proxy_cert_ext ]
 | 
					 | 
				
			||||||
# These extensions should be added when creating a proxy certificate
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This goes against PKIX guidelines but some CAs do it and some software
 | 
					 | 
				
			||||||
# requires this to avoid interpreting an end user certificate as a CA.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
basicConstraints=CA:FALSE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Here are some examples of the usage of nsCertType. If it is omitted
 | 
					 | 
				
			||||||
# the certificate can be used for anything *except* object signing.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is OK for an SSL server.
 | 
					 | 
				
			||||||
# nsCertType			= server
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# For an object signing certificate this would be used.
 | 
					 | 
				
			||||||
# nsCertType = objsign
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# For normal client use this is typical
 | 
					 | 
				
			||||||
# nsCertType = client, email
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# and for everything including object signing:
 | 
					 | 
				
			||||||
# nsCertType = client, email, objsign
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is typical in keyUsage for a client certificate.
 | 
					 | 
				
			||||||
# keyUsage = nonRepudiation, digitalSignature, keyEncipherment
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This will be displayed in Netscape's comment listbox.
 | 
					 | 
				
			||||||
nsComment			= "OpenSSL Generated Certificate"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# PKIX recommendations harmless if included in all certificates.
 | 
					 | 
				
			||||||
subjectKeyIdentifier=hash
 | 
					 | 
				
			||||||
authorityKeyIdentifier=keyid,issuer:always
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This stuff is for subjectAltName and issuerAltname.
 | 
					 | 
				
			||||||
# Import the email address.
 | 
					 | 
				
			||||||
# subjectAltName=email:copy
 | 
					 | 
				
			||||||
# An alternative to produce certificates that aren't
 | 
					 | 
				
			||||||
# deprecated according to PKIX.
 | 
					 | 
				
			||||||
# subjectAltName=email:move
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Copy subject details
 | 
					 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#nsCaRevocationUrl		= http://www.domain.dom/ca-crl.pem
 | 
					 | 
				
			||||||
#nsBaseUrl
 | 
					 | 
				
			||||||
#nsRevocationUrl
 | 
					 | 
				
			||||||
#nsRenewalUrl
 | 
					 | 
				
			||||||
#nsCaPolicyUrl
 | 
					 | 
				
			||||||
#nsSslServerName
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This really needs to be in place for it to be a proxy certificate.
 | 
					 | 
				
			||||||
proxyCertInfo=critical,language:id-ppl-anyLanguage,pathlen:3,policy:foo
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -114,7 +114,6 @@
 | 
				
			|||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#define OPENSSL_C /* tells apps.h to use complete apps_startup() */
 | 
					#define OPENSSL_C /* tells apps.h to use complete apps_startup() */
 | 
				
			||||||
#include "apps.h"
 | 
					 | 
				
			||||||
#include <openssl/bio.h>
 | 
					#include <openssl/bio.h>
 | 
				
			||||||
#include <openssl/crypto.h>
 | 
					#include <openssl/crypto.h>
 | 
				
			||||||
#include <openssl/lhash.h>
 | 
					#include <openssl/lhash.h>
 | 
				
			||||||
@@ -122,14 +121,12 @@
 | 
				
			|||||||
#include <openssl/x509.h>
 | 
					#include <openssl/x509.h>
 | 
				
			||||||
#include <openssl/pem.h>
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
#include <openssl/ssl.h>
 | 
					#include <openssl/ssl.h>
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
#include <openssl/engine.h>
 | 
					#include <openssl/engine.h>
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#define USE_SOCKETS /* needed for the _O_BINARY defs in the MS world */
 | 
					#define USE_SOCKETS /* needed for the _O_BINARY defs in the MS world */
 | 
				
			||||||
 | 
					#include "apps.h"
 | 
				
			||||||
#include "progs.h"
 | 
					#include "progs.h"
 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
#include <openssl/err.h>
 | 
					#include <openssl/err.h>
 | 
				
			||||||
#include <openssl/fips.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* The LHASH callbacks ("hash" & "cmp") have been replaced by functions with the
 | 
					/* The LHASH callbacks ("hash" & "cmp") have been replaced by functions with the
 | 
				
			||||||
 * base prototypes (we cast each variable inside the function to the required
 | 
					 * base prototypes (we cast each variable inside the function to the required
 | 
				
			||||||
@@ -142,13 +139,12 @@ static unsigned long MS_CALLBACK hash(const void *a_void);
 | 
				
			|||||||
static int MS_CALLBACK cmp(const void *a_void,const void *b_void);
 | 
					static int MS_CALLBACK cmp(const void *a_void,const void *b_void);
 | 
				
			||||||
static LHASH *prog_init(void );
 | 
					static LHASH *prog_init(void );
 | 
				
			||||||
static int do_cmd(LHASH *prog,int argc,char *argv[]);
 | 
					static int do_cmd(LHASH *prog,int argc,char *argv[]);
 | 
				
			||||||
 | 
					CONF *config=NULL;
 | 
				
			||||||
char *default_config_file=NULL;
 | 
					char *default_config_file=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Make sure there is only one when MONOLITH is defined */
 | 
					/* Make sure there is only one when MONOLITH is defined */
 | 
				
			||||||
#ifdef MONOLITH
 | 
					#ifdef MONOLITH
 | 
				
			||||||
CONF *config=NULL;
 | 
					 | 
				
			||||||
BIO *bio_err=NULL;
 | 
					BIO *bio_err=NULL;
 | 
				
			||||||
int in_FIPS_mode=0;
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -165,7 +161,7 @@ static void lock_dbg_cb(int mode, int type, const char *file, int line)
 | 
				
			|||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (type < 0 || type >= CRYPTO_NUM_LOCKS)
 | 
						if (type < 0 || type > CRYPTO_NUM_LOCKS)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		errstr = "type out of bounds";
 | 
							errstr = "type out of bounds";
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
@@ -222,33 +218,16 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
#define PROG_NAME_SIZE	39
 | 
					#define PROG_NAME_SIZE	39
 | 
				
			||||||
	char pname[PROG_NAME_SIZE+1];
 | 
						char pname[PROG_NAME_SIZE+1];
 | 
				
			||||||
	FUNCTION f,*fp;
 | 
						FUNCTION f,*fp;
 | 
				
			||||||
	MS_STATIC char *prompt,buf[1024];
 | 
						MS_STATIC char *prompt,buf[1024],config_name[256];
 | 
				
			||||||
	char *to_free=NULL;
 | 
					 | 
				
			||||||
	int n,i,ret=0;
 | 
						int n,i,ret=0;
 | 
				
			||||||
	int argc;
 | 
						int argc;
 | 
				
			||||||
	char **argv,*p;
 | 
						char **argv,*p;
 | 
				
			||||||
	LHASH *prog=NULL;
 | 
						LHASH *prog=NULL;
 | 
				
			||||||
	long errline;
 | 
						long errline;
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
	arg.data=NULL;
 | 
						arg.data=NULL;
 | 
				
			||||||
	arg.count=0;
 | 
						arg.count=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	in_FIPS_mode = 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
	if(getenv("OPENSSL_FIPS")) {
 | 
					 | 
				
			||||||
		if (!FIPS_mode_set(1)) {
 | 
					 | 
				
			||||||
			ERR_load_crypto_strings();
 | 
					 | 
				
			||||||
			ERR_print_errors(BIO_new_fp(stderr,BIO_NOCLOSE));
 | 
					 | 
				
			||||||
			EXIT(1);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
		in_FIPS_mode = 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if (bio_err == NULL)
 | 
					 | 
				
			||||||
		if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
					 | 
				
			||||||
			BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (getenv("OPENSSL_DEBUG_MEMORY") != NULL) /* if not defined, use compiled-in library defaults */
 | 
						if (getenv("OPENSSL_DEBUG_MEMORY") != NULL) /* if not defined, use compiled-in library defaults */
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (!(0 == strcmp(getenv("OPENSSL_DEBUG_MEMORY"), "off")))
 | 
							if (!(0 == strcmp(getenv("OPENSSL_DEBUG_MEMORY"), "off")))
 | 
				
			||||||
@@ -273,12 +252,23 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (bio_err == NULL)
 | 
				
			||||||
 | 
							if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
				
			||||||
 | 
								BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Lets load up our environment a little */
 | 
						/* Lets load up our environment a little */
 | 
				
			||||||
	p=getenv("OPENSSL_CONF");
 | 
						p=getenv("OPENSSL_CONF");
 | 
				
			||||||
	if (p == NULL)
 | 
						if (p == NULL)
 | 
				
			||||||
		p=getenv("SSLEAY_CONF");
 | 
							p=getenv("SSLEAY_CONF");
 | 
				
			||||||
	if (p == NULL)
 | 
						if (p == NULL)
 | 
				
			||||||
		p=to_free=make_config_name();
 | 
							{
 | 
				
			||||||
 | 
							strcpy(config_name,X509_get_default_cert_area());
 | 
				
			||||||
 | 
					#ifndef OPENSSL_SYS_VMS
 | 
				
			||||||
 | 
							strcat(config_name,"/");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							strcat(config_name,OPENSSL_CONF);
 | 
				
			||||||
 | 
							p=config_name;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	default_config_file=p;
 | 
						default_config_file=p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -294,7 +284,7 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
	prog=prog_init();
 | 
						prog=prog_init();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* first check the program name */
 | 
						/* first check the program name */
 | 
				
			||||||
	program_name(Argv[0],pname,sizeof pname);
 | 
						program_name(Argv[0],pname,PROG_NAME_SIZE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	f.name=pname;
 | 
						f.name=pname;
 | 
				
			||||||
	fp=(FUNCTION *)lh_retrieve(prog,&f);
 | 
						fp=(FUNCTION *)lh_retrieve(prog,&f);
 | 
				
			||||||
@@ -322,7 +312,7 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		ret=0;
 | 
							ret=0;
 | 
				
			||||||
		p=buf;
 | 
							p=buf;
 | 
				
			||||||
		n=sizeof buf;
 | 
							n=1024;
 | 
				
			||||||
		i=0;
 | 
							i=0;
 | 
				
			||||||
		for (;;)
 | 
							for (;;)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -356,8 +346,6 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
	BIO_printf(bio_err,"bad exit\n");
 | 
						BIO_printf(bio_err,"bad exit\n");
 | 
				
			||||||
	ret=1;
 | 
						ret=1;
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
	if (to_free)
 | 
					 | 
				
			||||||
		OPENSSL_free(to_free);
 | 
					 | 
				
			||||||
	if (config != NULL)
 | 
						if (config != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		NCONF_free(config);
 | 
							NCONF_free(config);
 | 
				
			||||||
@@ -374,7 +362,7 @@ end:
 | 
				
			|||||||
		BIO_free(bio_err);
 | 
							BIO_free(bio_err);
 | 
				
			||||||
		bio_err=NULL;
 | 
							bio_err=NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define LIST_STANDARD_COMMANDS "list-standard-commands"
 | 
					#define LIST_STANDARD_COMMANDS "list-standard-commands"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -8,9 +8,6 @@
 | 
				
			|||||||
HOME			= .
 | 
					HOME			= .
 | 
				
			||||||
RANDFILE		= $ENV::HOME/.rnd
 | 
					RANDFILE		= $ENV::HOME/.rnd
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Uncomment out to enable OpenSSL configuration see config(3)
 | 
					 | 
				
			||||||
# openssl_conf = openssl_init
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Extra OBJECT IDENTIFIER info:
 | 
					# Extra OBJECT IDENTIFIER info:
 | 
				
			||||||
#oid_file		= $ENV::HOME/.oid
 | 
					#oid_file		= $ENV::HOME/.oid
 | 
				
			||||||
oid_section		= new_oids
 | 
					oid_section		= new_oids
 | 
				
			||||||
@@ -22,11 +19,6 @@ oid_section		= new_oids
 | 
				
			|||||||
# (Alternatively, use a configuration file that has only
 | 
					# (Alternatively, use a configuration file that has only
 | 
				
			||||||
# X.509v3 extensions in its main [= default] section.)
 | 
					# X.509v3 extensions in its main [= default] section.)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[openssl_init]
 | 
					 | 
				
			||||||
# Extra OBJECT IDENTIFIER info:
 | 
					 | 
				
			||||||
oid_section = new_oids
 | 
					 | 
				
			||||||
alg_section = algs
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
[ new_oids ]
 | 
					[ new_oids ]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# We can add new OIDs in here for use by 'ca' and 'req'.
 | 
					# We can add new OIDs in here for use by 'ca' and 'req'.
 | 
				
			||||||
@@ -34,9 +26,6 @@ alg_section = algs
 | 
				
			|||||||
# testoid1=1.2.3.4
 | 
					# testoid1=1.2.3.4
 | 
				
			||||||
# Or use config file substitution like this:
 | 
					# Or use config file substitution like this:
 | 
				
			||||||
# testoid2=${testoid1}.5.6
 | 
					# testoid2=${testoid1}.5.6
 | 
				
			||||||
[ algs ]
 | 
					 | 
				
			||||||
# Algorithm configuration options. Currently just fips_mode
 | 
					 | 
				
			||||||
fips_mode = no
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
####################################################################
 | 
					####################################################################
 | 
				
			||||||
[ ca ]
 | 
					[ ca ]
 | 
				
			||||||
@@ -49,14 +38,10 @@ dir		= ./demoCA		# Where everything is kept
 | 
				
			|||||||
certs		= $dir/certs		# Where the issued certs are kept
 | 
					certs		= $dir/certs		# Where the issued certs are kept
 | 
				
			||||||
crl_dir		= $dir/crl		# Where the issued crl are kept
 | 
					crl_dir		= $dir/crl		# Where the issued crl are kept
 | 
				
			||||||
database	= $dir/index.txt	# database index file.
 | 
					database	= $dir/index.txt	# database index file.
 | 
				
			||||||
#unique_subject	= no			# Set to 'no' to allow creation of
 | 
					 | 
				
			||||||
					# several ctificates with same subject.
 | 
					 | 
				
			||||||
new_certs_dir	= $dir/newcerts		# default place for new certs.
 | 
					new_certs_dir	= $dir/newcerts		# default place for new certs.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
certificate	= $dir/cacert.pem 	# The CA certificate
 | 
					certificate	= $dir/cacert.pem 	# The CA certificate
 | 
				
			||||||
serial		= $dir/serial 		# The current serial number
 | 
					serial		= $dir/serial 		# The current serial number
 | 
				
			||||||
#crlnumber	= $dir/crlnumber	# the current crl number must be
 | 
					 | 
				
			||||||
					# commented out to leave a V1 CRL
 | 
					 | 
				
			||||||
crl		= $dir/crl.pem 		# The current CRL
 | 
					crl		= $dir/crl.pem 		# The current CRL
 | 
				
			||||||
private_key	= $dir/private/cakey.pem# The private key
 | 
					private_key	= $dir/private/cakey.pem# The private key
 | 
				
			||||||
RANDFILE	= $dir/private/.rand	# private random number file
 | 
					RANDFILE	= $dir/private/.rand	# private random number file
 | 
				
			||||||
@@ -73,7 +58,6 @@ cert_opt 	= ca_default		# Certificate field options
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Extensions to add to a CRL. Note: Netscape communicator chokes on V2 CRLs
 | 
					# Extensions to add to a CRL. Note: Netscape communicator chokes on V2 CRLs
 | 
				
			||||||
# so this is commented out by default to leave a V1 CRL.
 | 
					# so this is commented out by default to leave a V1 CRL.
 | 
				
			||||||
# crlnumber must also be commented out to leave a V1 CRL.
 | 
					 | 
				
			||||||
# crl_extensions	= crl_ext
 | 
					# crl_extensions	= crl_ext
 | 
				
			||||||
 | 
					
 | 
				
			||||||
default_days	= 365			# how long to certify for
 | 
					default_days	= 365			# how long to certify for
 | 
				
			||||||
@@ -269,56 +253,3 @@ basicConstraints = CA:true
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
authorityKeyIdentifier=keyid:always,issuer:always
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					 | 
				
			||||||
[ proxy_cert_ext ]
 | 
					 | 
				
			||||||
# These extensions should be added when creating a proxy certificate
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This goes against PKIX guidelines but some CAs do it and some software
 | 
					 | 
				
			||||||
# requires this to avoid interpreting an end user certificate as a CA.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
basicConstraints=CA:FALSE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Here are some examples of the usage of nsCertType. If it is omitted
 | 
					 | 
				
			||||||
# the certificate can be used for anything *except* object signing.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is OK for an SSL server.
 | 
					 | 
				
			||||||
# nsCertType			= server
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# For an object signing certificate this would be used.
 | 
					 | 
				
			||||||
# nsCertType = objsign
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# For normal client use this is typical
 | 
					 | 
				
			||||||
# nsCertType = client, email
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# and for everything including object signing:
 | 
					 | 
				
			||||||
# nsCertType = client, email, objsign
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This is typical in keyUsage for a client certificate.
 | 
					 | 
				
			||||||
# keyUsage = nonRepudiation, digitalSignature, keyEncipherment
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This will be displayed in Netscape's comment listbox.
 | 
					 | 
				
			||||||
nsComment			= "OpenSSL Generated Certificate"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# PKIX recommendations harmless if included in all certificates.
 | 
					 | 
				
			||||||
subjectKeyIdentifier=hash
 | 
					 | 
				
			||||||
authorityKeyIdentifier=keyid,issuer:always
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This stuff is for subjectAltName and issuerAltname.
 | 
					 | 
				
			||||||
# Import the email address.
 | 
					 | 
				
			||||||
# subjectAltName=email:copy
 | 
					 | 
				
			||||||
# An alternative to produce certificates that aren't
 | 
					 | 
				
			||||||
# deprecated according to PKIX.
 | 
					 | 
				
			||||||
# subjectAltName=email:move
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Copy subject details
 | 
					 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#nsCaRevocationUrl		= http://www.domain.dom/ca-crl.pem
 | 
					 | 
				
			||||||
#nsBaseUrl
 | 
					 | 
				
			||||||
#nsRevocationUrl
 | 
					 | 
				
			||||||
#nsRenewalUrl
 | 
					 | 
				
			||||||
#nsCaPolicyUrl
 | 
					 | 
				
			||||||
#nsSslServerName
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This really needs to be in place for it to be a proxy certificate.
 | 
					 | 
				
			||||||
proxyCertInfo=critical,language:id-ppl-anyLanguage,pathlen:3,policy:foo
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,7 @@
 | 
				
			|||||||
# include <openssl/des.h>
 | 
					# include <openssl/des.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef NO_MD5CRYPT_1
 | 
					#ifndef NO_MD5CRYPT_1
 | 
				
			||||||
 | 
					# include <openssl/evp.h>
 | 
				
			||||||
# include <openssl/md5.h>
 | 
					# include <openssl/md5.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -292,7 +293,7 @@ err:
 | 
				
			|||||||
	if (out)
 | 
						if (out)
 | 
				
			||||||
		BIO_free_all(out);
 | 
							BIO_free_all(out);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -505,6 +506,6 @@ err:
 | 
				
			|||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	fputs("Program not available.\n", stderr)
 | 
						fputs("Program not available.\n", stderr)
 | 
				
			||||||
	OPENSSL_EXIT(1);
 | 
						EXIT(1);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -109,7 +109,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    int maciter = PKCS12_DEFAULT_ITER;
 | 
					    int maciter = PKCS12_DEFAULT_ITER;
 | 
				
			||||||
    int twopass = 0;
 | 
					    int twopass = 0;
 | 
				
			||||||
    int keytype = 0;
 | 
					    int keytype = 0;
 | 
				
			||||||
    int cert_pbe;
 | 
					    int cert_pbe = NID_pbe_WithSHA1And40BitRC2_CBC;
 | 
				
			||||||
    int key_pbe = NID_pbe_WithSHA1And3_Key_TripleDES_CBC;
 | 
					    int key_pbe = NID_pbe_WithSHA1And3_Key_TripleDES_CBC;
 | 
				
			||||||
    int ret = 1;
 | 
					    int ret = 1;
 | 
				
			||||||
    int macver = 1;
 | 
					    int macver = 1;
 | 
				
			||||||
@@ -120,19 +120,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    char *passin = NULL, *passout = NULL;
 | 
					    char *passin = NULL, *passout = NULL;
 | 
				
			||||||
    char *inrand = NULL;
 | 
					    char *inrand = NULL;
 | 
				
			||||||
    char *CApath = NULL, *CAfile = NULL;
 | 
					    char *CApath = NULL, *CAfile = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
    char *engine=NULL;
 | 
					    char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    apps_startup();
 | 
					    apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_FIPS
 | 
					 | 
				
			||||||
    if (FIPS_mode())
 | 
					 | 
				
			||||||
	cert_pbe = NID_pbe_WithSHA1And3_Key_TripleDES_CBC;
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
    cert_pbe = NID_pbe_WithSHA1And40BitRC2_CBC;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    enc = EVP_des_ede3_cbc();
 | 
					    enc = EVP_des_ede3_cbc();
 | 
				
			||||||
    if (bio_err == NULL ) bio_err = BIO_new_fp (stderr, BIO_NOCLOSE);
 | 
					    if (bio_err == NULL ) bio_err = BIO_new_fp (stderr, BIO_NOCLOSE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -261,13 +252,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			args++;	
 | 
								args++;	
 | 
				
			||||||
			CAfile = *args;
 | 
								CAfile = *args;
 | 
				
			||||||
		    } else badarg = 1;
 | 
							    } else badarg = 1;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		} else if (!strcmp(*args,"-engine")) {
 | 
							} else if (!strcmp(*args,"-engine")) {
 | 
				
			||||||
		    if (args[1]) {
 | 
							    if (args[1]) {
 | 
				
			||||||
			args++;	
 | 
								args++;	
 | 
				
			||||||
			engine = *args;
 | 
								engine = *args;
 | 
				
			||||||
		    } else badarg = 1;
 | 
							    } else badarg = 1;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		} else badarg = 1;
 | 
							} else badarg = 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	} else badarg = 1;
 | 
						} else badarg = 1;
 | 
				
			||||||
@@ -315,18 +304,14 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	BIO_printf (bio_err, "-password p   set import/export password source\n");
 | 
						BIO_printf (bio_err, "-password p   set import/export password source\n");
 | 
				
			||||||
	BIO_printf (bio_err, "-passin p     input file pass phrase source\n");
 | 
						BIO_printf (bio_err, "-passin p     input file pass phrase source\n");
 | 
				
			||||||
	BIO_printf (bio_err, "-passout p    output file pass phrase source\n");
 | 
						BIO_printf (bio_err, "-passout p    output file pass phrase source\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	BIO_printf (bio_err, "-engine e     use engine e, possibly a hardware device.\n");
 | 
						BIO_printf (bio_err, "-engine e     use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	BIO_printf(bio_err,  "-rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
						BIO_printf(bio_err,  "-rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
	BIO_printf(bio_err,  "              load the file (or the files in the directory) into\n");
 | 
						BIO_printf(bio_err,  "              load the file (or the files in the directory) into\n");
 | 
				
			||||||
	BIO_printf(bio_err,  "              the random number generator\n");
 | 
						BIO_printf(bio_err,  "              the random number generator\n");
 | 
				
			||||||
    	goto end;
 | 
					    	goto end;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
    e = setup_engine(bio_err, engine, 0);
 | 
					    e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if(passarg) {
 | 
					    if(passarg) {
 | 
				
			||||||
	if(export_cert) passargout = passarg;
 | 
						if(export_cert) passargout = passarg;
 | 
				
			||||||
@@ -414,7 +399,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#ifdef CRYPTO_MDEBUG
 | 
					#ifdef CRYPTO_MDEBUG
 | 
				
			||||||
    CRYPTO_push_info("read MAC password");
 | 
					    CRYPTO_push_info("read MAC password");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	if(EVP_read_pw_string (macpass, sizeof macpass, "Enter MAC Password:", export_cert))
 | 
						if(EVP_read_pw_string (macpass, 50, "Enter MAC Password:", export_cert))
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
    	    BIO_printf (bio_err, "Can't read Password\n");
 | 
					    	    BIO_printf (bio_err, "Can't read Password\n");
 | 
				
			||||||
    	    goto end;
 | 
					    	    goto end;
 | 
				
			||||||
@@ -442,7 +427,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	CRYPTO_push_info("process -export_cert");
 | 
						CRYPTO_push_info("process -export_cert");
 | 
				
			||||||
	CRYPTO_push_info("reading private key");
 | 
						CRYPTO_push_info("reading private key");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	key = load_key(bio_err, keyname ? keyname : infile, FORMAT_PEM, 1,
 | 
						key = load_key(bio_err, keyname ? keyname : infile, FORMAT_PEM,
 | 
				
			||||||
		passin, e, "private key");
 | 
							passin, e, "private key");
 | 
				
			||||||
	if (!key) {
 | 
						if (!key) {
 | 
				
			||||||
		goto export_end;
 | 
							goto export_end;
 | 
				
			||||||
@@ -523,10 +508,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		    /* Exclude verified certificate */
 | 
							    /* Exclude verified certificate */
 | 
				
			||||||
		    for (i = 1; i < sk_X509_num (chain2) ; i++) 
 | 
							    for (i = 1; i < sk_X509_num (chain2) ; i++) 
 | 
				
			||||||
			sk_X509_push(certs, sk_X509_value (chain2, i));
 | 
								sk_X509_push(certs, sk_X509_value (chain2, i));
 | 
				
			||||||
		    /* Free first certificate */
 | 
							}
 | 
				
			||||||
		    X509_free(sk_X509_value(chain2, 0));
 | 
							sk_X509_free(chain2);
 | 
				
			||||||
		    sk_X509_free(chain2);
 | 
							if (vret) {
 | 
				
			||||||
		} else {
 | 
					 | 
				
			||||||
			BIO_printf (bio_err, "Error %s getting chain.\n",
 | 
								BIO_printf (bio_err, "Error %s getting chain.\n",
 | 
				
			||||||
					X509_verify_cert_error_string(vret));
 | 
										X509_verify_cert_error_string(vret));
 | 
				
			||||||
			goto export_end;
 | 
								goto export_end;
 | 
				
			||||||
@@ -553,6 +537,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	sk_X509_pop_free(certs, X509_free);
 | 
						sk_X509_pop_free(certs, X509_free);
 | 
				
			||||||
	certs = NULL;
 | 
						certs = NULL;
 | 
				
			||||||
 | 
						/* ucert is part of certs so it is already freed */
 | 
				
			||||||
 | 
						ucert = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CRYPTO_MDEBUG
 | 
					#ifdef CRYPTO_MDEBUG
 | 
				
			||||||
	CRYPTO_pop_info();
 | 
						CRYPTO_pop_info();
 | 
				
			||||||
@@ -560,11 +546,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!noprompt &&
 | 
						if(!noprompt &&
 | 
				
			||||||
		EVP_read_pw_string(pass, sizeof pass, "Enter Export Password:", 1)) {
 | 
							EVP_read_pw_string(pass, 50, "Enter Export Password:", 1)) {
 | 
				
			||||||
	    BIO_printf (bio_err, "Can't read Password\n");
 | 
						    BIO_printf (bio_err, "Can't read Password\n");
 | 
				
			||||||
	    goto export_end;
 | 
						    goto export_end;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
	if (!twopass) BUF_strlcpy(macpass, pass, sizeof macpass);
 | 
						if (!twopass) strcpy(macpass, pass);
 | 
				
			||||||
	/* Turn certbags into encrypted authsafe */
 | 
						/* Turn certbags into encrypted authsafe */
 | 
				
			||||||
	authsafe = PKCS12_pack_p7encdata(cert_pbe, cpass, -1, NULL, 0,
 | 
						authsafe = PKCS12_pack_p7encdata(cert_pbe, cpass, -1, NULL, 0,
 | 
				
			||||||
								 iter, bags);
 | 
													 iter, bags);
 | 
				
			||||||
@@ -641,6 +627,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if (certs) sk_X509_pop_free(certs, X509_free);
 | 
						if (certs) sk_X509_pop_free(certs, X509_free);
 | 
				
			||||||
	if (safes) sk_PKCS7_pop_free(safes, PKCS7_free);
 | 
						if (safes) sk_PKCS7_pop_free(safes, PKCS7_free);
 | 
				
			||||||
	if (bags) sk_PKCS12_SAFEBAG_pop_free(bags, PKCS12_SAFEBAG_free);
 | 
						if (bags) sk_PKCS12_SAFEBAG_pop_free(bags, PKCS12_SAFEBAG_free);
 | 
				
			||||||
 | 
						if (ucert) X509_free(ucert);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CRYPTO_MDEBUG
 | 
					#ifdef CRYPTO_MDEBUG
 | 
				
			||||||
	CRYPTO_pop_info();
 | 
						CRYPTO_pop_info();
 | 
				
			||||||
@@ -657,7 +644,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#ifdef CRYPTO_MDEBUG
 | 
					#ifdef CRYPTO_MDEBUG
 | 
				
			||||||
    CRYPTO_push_info("read import password");
 | 
					    CRYPTO_push_info("read import password");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
    if(!noprompt && EVP_read_pw_string(pass, sizeof pass, "Enter Import Password:", 0)) {
 | 
					    if(!noprompt && EVP_read_pw_string(pass, 50, "Enter Import Password:", 0)) {
 | 
				
			||||||
	BIO_printf (bio_err, "Can't read Password\n");
 | 
						BIO_printf (bio_err, "Can't read Password\n");
 | 
				
			||||||
	goto end;
 | 
						goto end;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -665,7 +652,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    CRYPTO_pop_info();
 | 
					    CRYPTO_pop_info();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!twopass) BUF_strlcpy(macpass, pass, sizeof macpass);
 | 
					    if (!twopass) strcpy(macpass, pass);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (options & INFO) BIO_printf (bio_err, "MAC Iteration %ld\n", p12->mac->iter ? ASN1_INTEGER_get (p12->mac->iter) : 1);
 | 
					    if (options & INFO) BIO_printf (bio_err, "MAC Iteration %ld\n", p12->mac->iter ? ASN1_INTEGER_get (p12->mac->iter) : 1);
 | 
				
			||||||
    if(macver) {
 | 
					    if(macver) {
 | 
				
			||||||
@@ -673,7 +660,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    CRYPTO_push_info("verify MAC");
 | 
					    CRYPTO_push_info("verify MAC");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	/* If we enter empty password try no password first */
 | 
						/* If we enter empty password try no password first */
 | 
				
			||||||
	if(!mpass[0] && PKCS12_verify_mac(p12, NULL, 0)) {
 | 
						if(!macpass[0] && PKCS12_verify_mac(p12, NULL, 0)) {
 | 
				
			||||||
		/* If mac and crypto pass the same set it to NULL too */
 | 
							/* If mac and crypto pass the same set it to NULL too */
 | 
				
			||||||
		if(!twopass) cpass = NULL;
 | 
							if(!twopass) cpass = NULL;
 | 
				
			||||||
	} else if (!PKCS12_verify_mac(p12, mpass, -1)) {
 | 
						} else if (!PKCS12_verify_mac(p12, mpass, -1)) {
 | 
				
			||||||
@@ -711,16 +698,15 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    if(passin) OPENSSL_free(passin);
 | 
					    if(passin) OPENSSL_free(passin);
 | 
				
			||||||
    if(passout) OPENSSL_free(passout);
 | 
					    if(passout) OPENSSL_free(passout);
 | 
				
			||||||
    apps_shutdown();
 | 
					    apps_shutdown();
 | 
				
			||||||
    OPENSSL_EXIT(ret);
 | 
					    EXIT(ret);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int dump_certs_keys_p12 (BIO *out, PKCS12 *p12, char *pass,
 | 
					int dump_certs_keys_p12 (BIO *out, PKCS12 *p12, char *pass,
 | 
				
			||||||
	     int passlen, int options, char *pempass)
 | 
						     int passlen, int options, char *pempass)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	STACK_OF(PKCS7) *asafes = NULL;
 | 
						STACK_OF(PKCS7) *asafes;
 | 
				
			||||||
	STACK_OF(PKCS12_SAFEBAG) *bags;
 | 
						STACK_OF(PKCS12_SAFEBAG) *bags;
 | 
				
			||||||
	int i, bagnid;
 | 
						int i, bagnid;
 | 
				
			||||||
	int ret = 0;
 | 
					 | 
				
			||||||
	PKCS7 *p7;
 | 
						PKCS7 *p7;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!( asafes = PKCS12_unpack_authsafes(p12))) return 0;
 | 
						if (!( asafes = PKCS12_unpack_authsafes(p12))) return 0;
 | 
				
			||||||
@@ -738,22 +724,16 @@ int dump_certs_keys_p12 (BIO *out, PKCS12 *p12, char *pass,
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
			bags = PKCS12_unpack_p7encdata(p7, pass, passlen);
 | 
								bags = PKCS12_unpack_p7encdata(p7, pass, passlen);
 | 
				
			||||||
		} else continue;
 | 
							} else continue;
 | 
				
			||||||
		if (!bags) goto err;
 | 
							if (!bags) return 0;
 | 
				
			||||||
	    	if (!dump_certs_pkeys_bags (out, bags, pass, passlen, 
 | 
						    	if (!dump_certs_pkeys_bags (out, bags, pass, passlen, 
 | 
				
			||||||
						 options, pempass)) {
 | 
											 options, pempass)) {
 | 
				
			||||||
			sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
								sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
				
			||||||
			goto err;
 | 
								return 0;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
							sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
				
			||||||
		bags = NULL;
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	ret = 1;
 | 
						sk_PKCS7_pop_free (asafes, PKCS7_free);
 | 
				
			||||||
 | 
						return 1;
 | 
				
			||||||
	err:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (asafes)
 | 
					 | 
				
			||||||
		sk_PKCS7_pop_free (asafes, PKCS7_free);
 | 
					 | 
				
			||||||
	return ret;
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int dump_certs_pkeys_bags (BIO *out, STACK_OF(PKCS12_SAFEBAG) *bags,
 | 
					int dump_certs_pkeys_bags (BIO *out, STACK_OF(PKCS12_SAFEBAG) *bags,
 | 
				
			||||||
@@ -873,12 +853,10 @@ int alg_print (BIO *x, X509_ALGOR *alg)
 | 
				
			|||||||
	unsigned char *p;
 | 
						unsigned char *p;
 | 
				
			||||||
	p = alg->parameter->value.sequence->data;
 | 
						p = alg->parameter->value.sequence->data;
 | 
				
			||||||
	pbe = d2i_PBEPARAM (NULL, &p, alg->parameter->value.sequence->length);
 | 
						pbe = d2i_PBEPARAM (NULL, &p, alg->parameter->value.sequence->length);
 | 
				
			||||||
	if (!pbe)
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
	BIO_printf (bio_err, "%s, Iteration %d\n", 
 | 
						BIO_printf (bio_err, "%s, Iteration %d\n", 
 | 
				
			||||||
	OBJ_nid2ln(OBJ_obj2nid(alg->algorithm)), ASN1_INTEGER_get(pbe->iter));
 | 
						OBJ_nid2ln(OBJ_obj2nid(alg->algorithm)), ASN1_INTEGER_get(pbe->iter));
 | 
				
			||||||
	PBEPARAM_free (pbe);
 | 
						PBEPARAM_free (pbe);
 | 
				
			||||||
	return 1;
 | 
						return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Load all certificates from a given file */
 | 
					/* Load all certificates from a given file */
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										17
									
								
								apps/pkcs7.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								apps/pkcs7.c
									
									
									
									
									
								
							@@ -82,19 +82,15 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	PKCS7 *p7=NULL;
 | 
						PKCS7 *p7=NULL;
 | 
				
			||||||
	int i,badops=0;
 | 
						int i,badops=0;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL;
 | 
						BIO *in=NULL,*out=NULL;
 | 
				
			||||||
	int informat,outformat;
 | 
						int informat,outformat;
 | 
				
			||||||
	char *infile,*outfile,*prog;
 | 
						char *infile,*outfile,*prog;
 | 
				
			||||||
	int print_certs=0,text=0,noout=0;
 | 
						int print_certs=0,text=0,noout=0;
 | 
				
			||||||
	int ret=1;
 | 
						int ret=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -102,9 +98,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
							if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
				
			||||||
			BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
								BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!load_config(bio_err, NULL))
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	infile=NULL;
 | 
						infile=NULL;
 | 
				
			||||||
	outfile=NULL;
 | 
						outfile=NULL;
 | 
				
			||||||
	informat=FORMAT_PEM;
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
@@ -141,13 +134,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			text=1;
 | 
								text=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-print_certs") == 0)
 | 
							else if (strcmp(*argv,"-print_certs") == 0)
 | 
				
			||||||
			print_certs=1;
 | 
								print_certs=1;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
								BIO_printf(bio_err,"unknown option %s\n",*argv);
 | 
				
			||||||
@@ -170,18 +161,14 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -print_certs  print any certs or crl in the input\n");
 | 
							BIO_printf(bio_err," -print_certs  print any certs or crl in the input\n");
 | 
				
			||||||
		BIO_printf(bio_err," -text         print full details of certificates\n");
 | 
							BIO_printf(bio_err," -text         print full details of certificates\n");
 | 
				
			||||||
		BIO_printf(bio_err," -noout        don't output encoded data\n");
 | 
							BIO_printf(bio_err," -noout        don't output encoded data\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e     use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		ret = 1;
 | 
							ret = 1;
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	in=BIO_new(BIO_s_file());
 | 
						in=BIO_new(BIO_s_file());
 | 
				
			||||||
	out=BIO_new(BIO_s_file());
 | 
						out=BIO_new(BIO_s_file());
 | 
				
			||||||
@@ -314,5 +301,5 @@ end:
 | 
				
			|||||||
	if (in != NULL) BIO_free(in);
 | 
						if (in != NULL) BIO_free(in);
 | 
				
			||||||
	if (out != NULL) BIO_free_all(out);
 | 
						if (out != NULL) BIO_free_all(out);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										327
									
								
								apps/pkcs8.c
									
									
									
									
									
								
							
							
						
						
									
										327
									
								
								apps/pkcs8.c
									
									
									
									
									
								
							@@ -1,6 +1,6 @@
 | 
				
			|||||||
/* pkcs8.c */
 | 
					/* pkcs8.c */
 | 
				
			||||||
/* Written by Dr Stephen N Henson (shenson@bigfoot.com) for the OpenSSL
 | 
					/* Written by Dr Stephen N Henson (shenson@bigfoot.com) for the OpenSSL
 | 
				
			||||||
 * project 1999-2004.
 | 
					 * project 1999.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 1999 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1999 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
@@ -63,12 +63,13 @@
 | 
				
			|||||||
#include <openssl/evp.h>
 | 
					#include <openssl/evp.h>
 | 
				
			||||||
#include <openssl/pkcs12.h>
 | 
					#include <openssl/pkcs12.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "apps.h"
 | 
				
			||||||
#define PROG pkcs8_main
 | 
					#define PROG pkcs8_main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
					{
 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
	char **args, *infile = NULL, *outfile = NULL;
 | 
						char **args, *infile = NULL, *outfile = NULL;
 | 
				
			||||||
	char *passargin = NULL, *passargout = NULL;
 | 
						char *passargin = NULL, *passargout = NULL;
 | 
				
			||||||
@@ -85,9 +86,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	EVP_PKEY *pkey=NULL;
 | 
						EVP_PKEY *pkey=NULL;
 | 
				
			||||||
	char pass[50], *passin = NULL, *passout = NULL, *p8pass = NULL;
 | 
						char pass[50], *passin = NULL, *passout = NULL, *p8pass = NULL;
 | 
				
			||||||
	int badarg = 0;
 | 
						int badarg = 0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (bio_err == NULL) bio_err = BIO_new_fp (stderr, BIO_NOCLOSE);
 | 
						if (bio_err == NULL) bio_err = BIO_new_fp (stderr, BIO_NOCLOSE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -100,70 +99,43 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
	OpenSSL_add_all_algorithms();
 | 
						OpenSSL_add_all_algorithms();
 | 
				
			||||||
	args = argv + 1;
 | 
						args = argv + 1;
 | 
				
			||||||
	while (!badarg && *args && *args[0] == '-')
 | 
						while (!badarg && *args && *args[0] == '-') {
 | 
				
			||||||
		{
 | 
							if (!strcmp(*args,"-v2")) {
 | 
				
			||||||
		if (!strcmp(*args,"-v2"))
 | 
								if (args[1]) {
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				cipher=EVP_get_cipherbyname(*args);
 | 
									cipher=EVP_get_cipherbyname(*args);
 | 
				
			||||||
				if (!cipher)
 | 
									if(!cipher) {
 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					BIO_printf(bio_err,
 | 
										BIO_printf(bio_err,
 | 
				
			||||||
						 "Unknown cipher %s\n", *args);
 | 
											 "Unknown cipher %s\n", *args);
 | 
				
			||||||
					badarg = 1;
 | 
										badarg = 1;
 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else
 | 
								} else badarg = 1;
 | 
				
			||||||
				badarg = 1;
 | 
							} else if (!strcmp(*args,"-v1")) {
 | 
				
			||||||
			}
 | 
								if (args[1]) {
 | 
				
			||||||
		else if (!strcmp(*args,"-v1"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				pbe_nid=OBJ_txt2nid(*args);
 | 
									pbe_nid=OBJ_txt2nid(*args);
 | 
				
			||||||
				if (pbe_nid == NID_undef)
 | 
									if(pbe_nid == NID_undef) {
 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
					BIO_printf(bio_err,
 | 
										BIO_printf(bio_err,
 | 
				
			||||||
						 "Unknown PBE algorithm %s\n", *args);
 | 
											 "Unknown PBE algorithm %s\n", *args);
 | 
				
			||||||
					badarg = 1;
 | 
										badarg = 1;
 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else
 | 
								} else badarg = 1;
 | 
				
			||||||
				badarg = 1;
 | 
							} else if (!strcmp(*args,"-inform")) {
 | 
				
			||||||
			}
 | 
								if (args[1]) {
 | 
				
			||||||
		else if (!strcmp(*args,"-inform"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				informat=str2fmt(*args);
 | 
									informat=str2fmt(*args);
 | 
				
			||||||
				}
 | 
								} else badarg = 1;
 | 
				
			||||||
			else badarg = 1;
 | 
							} else if (!strcmp(*args,"-outform")) {
 | 
				
			||||||
			}
 | 
								if (args[1]) {
 | 
				
			||||||
		else if (!strcmp(*args,"-outform"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				outformat=str2fmt(*args);
 | 
									outformat=str2fmt(*args);
 | 
				
			||||||
				}
 | 
								} else badarg = 1;
 | 
				
			||||||
			else badarg = 1;
 | 
							} else if (!strcmp (*args, "-topk8")) topk8 = 1;
 | 
				
			||||||
			}
 | 
							else if (!strcmp (*args, "-noiter")) iter = 1;
 | 
				
			||||||
		else if (!strcmp (*args, "-topk8"))
 | 
							else if (!strcmp (*args, "-nocrypt")) nocrypt = 1;
 | 
				
			||||||
			topk8 = 1;
 | 
							else if (!strcmp (*args, "-nooct")) p8_broken = PKCS8_NO_OCTET;
 | 
				
			||||||
		else if (!strcmp (*args, "-noiter"))
 | 
							else if (!strcmp (*args, "-nsdb")) p8_broken = PKCS8_NS_DB;
 | 
				
			||||||
			iter = 1;
 | 
							else if (!strcmp (*args, "-embed")) p8_broken = PKCS8_EMBEDDED_PARAM;
 | 
				
			||||||
		else if (!strcmp (*args, "-nocrypt"))
 | 
					 | 
				
			||||||
			nocrypt = 1;
 | 
					 | 
				
			||||||
		else if (!strcmp (*args, "-nooct"))
 | 
					 | 
				
			||||||
			p8_broken = PKCS8_NO_OCTET;
 | 
					 | 
				
			||||||
		else if (!strcmp (*args, "-nsdb"))
 | 
					 | 
				
			||||||
			p8_broken = PKCS8_NS_DB;
 | 
					 | 
				
			||||||
		else if (!strcmp (*args, "-embed"))
 | 
					 | 
				
			||||||
			p8_broken = PKCS8_EMBEDDED_PARAM;
 | 
					 | 
				
			||||||
		else if (!strcmp(*args,"-passin"))
 | 
							else if (!strcmp(*args,"-passin"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!args[1]) goto bad;
 | 
								if (!args[1]) goto bad;
 | 
				
			||||||
@@ -174,37 +146,26 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (!args[1]) goto bad;
 | 
								if (!args[1]) goto bad;
 | 
				
			||||||
			passargout= *(++args);
 | 
								passargout= *(++args);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*args,"-engine") == 0)
 | 
							else if (strcmp(*args,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (!args[1]) goto bad;
 | 
								if (!args[1]) goto bad;
 | 
				
			||||||
			engine= *(++args);
 | 
								engine= *(++args);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
							else if (!strcmp (*args, "-in")) {
 | 
				
			||||||
		else if (!strcmp (*args, "-in"))
 | 
								if (args[1]) {
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				infile = *args;
 | 
									infile = *args;
 | 
				
			||||||
				}
 | 
								} else badarg = 1;
 | 
				
			||||||
			else badarg = 1;
 | 
							} else if (!strcmp (*args, "-out")) {
 | 
				
			||||||
			}
 | 
								if (args[1]) {
 | 
				
			||||||
		else if (!strcmp (*args, "-out"))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (args[1])
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				outfile = *args;
 | 
									outfile = *args;
 | 
				
			||||||
				}
 | 
								} else badarg = 1;
 | 
				
			||||||
			else badarg = 1;
 | 
							} else badarg = 1;
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else badarg = 1;
 | 
					 | 
				
			||||||
		args++;
 | 
							args++;
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (badarg)
 | 
						if (badarg) {
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		bad:
 | 
							bad:
 | 
				
			||||||
		BIO_printf(bio_err, "Usage pkcs8 [options]\n");
 | 
							BIO_printf(bio_err, "Usage pkcs8 [options]\n");
 | 
				
			||||||
		BIO_printf(bio_err, "where options are\n");
 | 
							BIO_printf(bio_err, "where options are\n");
 | 
				
			||||||
@@ -222,202 +183,145 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf(bio_err, "-nocrypt        use or expect unencrypted private key\n");
 | 
							BIO_printf(bio_err, "-nocrypt        use or expect unencrypted private key\n");
 | 
				
			||||||
		BIO_printf(bio_err, "-v2 alg         use PKCS#5 v2.0 and cipher \"alg\"\n");
 | 
							BIO_printf(bio_err, "-v2 alg         use PKCS#5 v2.0 and cipher \"alg\"\n");
 | 
				
			||||||
		BIO_printf(bio_err, "-v1 obj         use PKCS#5 v1.5 and cipher \"alg\"\n");
 | 
							BIO_printf(bio_err, "-v1 obj         use PKCS#5 v1.5 and cipher \"alg\"\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
							return (1);
 | 
				
			||||||
		return 1;
 | 
						}
 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!app_passwd(bio_err, passargin, passargout, &passin, &passout))
 | 
						if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) {
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error getting passwords\n");
 | 
							BIO_printf(bio_err, "Error getting passwords\n");
 | 
				
			||||||
		return 1;
 | 
							return (1);
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((pbe_nid == -1) && !cipher)
 | 
						if ((pbe_nid == -1) && !cipher) pbe_nid = NID_pbeWithMD5AndDES_CBC;
 | 
				
			||||||
		pbe_nid = NID_pbeWithMD5AndDES_CBC;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (infile)
 | 
						if (infile) {
 | 
				
			||||||
		{
 | 
							if (!(in = BIO_new_file(infile, "rb"))) {
 | 
				
			||||||
		if (!(in = BIO_new_file(infile, "rb")))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,
 | 
								BIO_printf(bio_err,
 | 
				
			||||||
				 "Can't open input file %s\n", infile);
 | 
									 "Can't open input file %s\n", infile);
 | 
				
			||||||
			return (1);
 | 
								return (1);
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						} else in = BIO_new_fp (stdin, BIO_NOCLOSE);
 | 
				
			||||||
		in = BIO_new_fp (stdin, BIO_NOCLOSE);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (outfile)
 | 
						if (outfile) {
 | 
				
			||||||
		{
 | 
							if (!(out = BIO_new_file (outfile, "wb"))) {
 | 
				
			||||||
		if (!(out = BIO_new_file (outfile, "wb")))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,
 | 
								BIO_printf(bio_err,
 | 
				
			||||||
				 "Can't open output file %s\n", outfile);
 | 
									 "Can't open output file %s\n", outfile);
 | 
				
			||||||
			return (1);
 | 
								return (1);
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						} else {
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		out = BIO_new_fp (stdout, BIO_NOCLOSE);
 | 
							out = BIO_new_fp (stdout, BIO_NOCLOSE);
 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					#ifdef OPENSSL_SYS_VMS
 | 
				
			||||||
			{
 | 
							{
 | 
				
			||||||
			BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
								BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
				
			||||||
			out = BIO_push(tmpbio, out);
 | 
								out = BIO_push(tmpbio, out);
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	if (topk8)
 | 
						if (topk8)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_free(in); /* Not needed in this section */
 | 
							BIO_free(in); /* Not needed in this section */
 | 
				
			||||||
		pkey = load_key(bio_err, infile, informat, 1,
 | 
							pkey = load_key(bio_err, infile, informat, passin, e, "key");
 | 
				
			||||||
			passin, e, "key");
 | 
							if (!pkey) {
 | 
				
			||||||
		if (!pkey)
 | 
								return (1);
 | 
				
			||||||
			{
 | 
							}
 | 
				
			||||||
			BIO_free_all(out);
 | 
							if (!(p8inf = EVP_PKEY2PKCS8_broken(pkey, p8_broken))) {
 | 
				
			||||||
			return 1;
 | 
								BIO_printf(bio_err, "Error converting key\n", outfile);
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (!(p8inf = EVP_PKEY2PKCS8_broken(pkey, p8_broken)))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Error converting key\n");
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
			EVP_PKEY_free(pkey);
 | 
								return (1);
 | 
				
			||||||
			BIO_free_all(out);
 | 
							}
 | 
				
			||||||
			return 1;
 | 
							if(nocrypt) {
 | 
				
			||||||
			}
 | 
								if(outformat == FORMAT_PEM) 
 | 
				
			||||||
		if (nocrypt)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (outformat == FORMAT_PEM) 
 | 
					 | 
				
			||||||
				PEM_write_bio_PKCS8_PRIV_KEY_INFO(out, p8inf);
 | 
									PEM_write_bio_PKCS8_PRIV_KEY_INFO(out, p8inf);
 | 
				
			||||||
			else if (outformat == FORMAT_ASN1)
 | 
								else if(outformat == FORMAT_ASN1)
 | 
				
			||||||
				i2d_PKCS8_PRIV_KEY_INFO_bio(out, p8inf);
 | 
									i2d_PKCS8_PRIV_KEY_INFO_bio(out, p8inf);
 | 
				
			||||||
			else
 | 
								else {
 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err, "Bad format specified for key\n");
 | 
									BIO_printf(bio_err, "Bad format specified for key\n");
 | 
				
			||||||
				PKCS8_PRIV_KEY_INFO_free(p8inf);
 | 
					 | 
				
			||||||
				EVP_PKEY_free(pkey);
 | 
					 | 
				
			||||||
				BIO_free_all(out);
 | 
					 | 
				
			||||||
				return (1);
 | 
									return (1);
 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							} else {
 | 
				
			||||||
			{
 | 
								if(passout) p8pass = passout;
 | 
				
			||||||
			if (passout)
 | 
								else {
 | 
				
			||||||
				p8pass = passout;
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				p8pass = pass;
 | 
									p8pass = pass;
 | 
				
			||||||
				if (EVP_read_pw_string(pass, sizeof pass, "Enter Encryption Password:", 1))
 | 
									EVP_read_pw_string(pass, 50, "Enter Encryption Password:", 1);
 | 
				
			||||||
					{
 | 
								}
 | 
				
			||||||
					PKCS8_PRIV_KEY_INFO_free(p8inf);
 | 
					 | 
				
			||||||
					EVP_PKEY_free(pkey);
 | 
					 | 
				
			||||||
					BIO_free_all(out);
 | 
					 | 
				
			||||||
					return (1);
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			app_RAND_load_file(NULL, bio_err, 0);
 | 
								app_RAND_load_file(NULL, bio_err, 0);
 | 
				
			||||||
			if (!(p8 = PKCS8_encrypt(pbe_nid, cipher,
 | 
								if (!(p8 = PKCS8_encrypt(pbe_nid, cipher,
 | 
				
			||||||
					p8pass, strlen(p8pass),
 | 
										p8pass, strlen(p8pass),
 | 
				
			||||||
					NULL, 0, iter, p8inf)))
 | 
										NULL, 0, iter, p8inf))) {
 | 
				
			||||||
				{
 | 
									BIO_printf(bio_err, "Error encrypting key\n",
 | 
				
			||||||
				BIO_printf(bio_err, "Error encrypting key\n");
 | 
													 outfile);
 | 
				
			||||||
				ERR_print_errors(bio_err);
 | 
									ERR_print_errors(bio_err);
 | 
				
			||||||
				PKCS8_PRIV_KEY_INFO_free(p8inf);
 | 
					 | 
				
			||||||
				EVP_PKEY_free(pkey);
 | 
					 | 
				
			||||||
				BIO_free_all(out);
 | 
					 | 
				
			||||||
				return (1);
 | 
									return (1);
 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			app_RAND_write_file(NULL, bio_err);
 | 
					 | 
				
			||||||
			if (outformat == FORMAT_PEM) 
 | 
					 | 
				
			||||||
				PEM_write_bio_PKCS8(out, p8);
 | 
					 | 
				
			||||||
			else if (outformat == FORMAT_ASN1)
 | 
					 | 
				
			||||||
				i2d_PKCS8_bio(out, p8);
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err, "Bad format specified for key\n");
 | 
					 | 
				
			||||||
				PKCS8_PRIV_KEY_INFO_free(p8inf);
 | 
					 | 
				
			||||||
				EVP_PKEY_free(pkey);
 | 
					 | 
				
			||||||
				BIO_free_all(out);
 | 
					 | 
				
			||||||
				return (1);
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			X509_SIG_free(p8);
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
								app_RAND_write_file(NULL, bio_err);
 | 
				
			||||||
 | 
								if(outformat == FORMAT_PEM) 
 | 
				
			||||||
 | 
									PEM_write_bio_PKCS8(out, p8);
 | 
				
			||||||
 | 
								else if(outformat == FORMAT_ASN1)
 | 
				
			||||||
 | 
									i2d_PKCS8_bio(out, p8);
 | 
				
			||||||
 | 
								else {
 | 
				
			||||||
 | 
									BIO_printf(bio_err, "Bad format specified for key\n");
 | 
				
			||||||
 | 
									return (1);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								X509_SIG_free(p8);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
		PKCS8_PRIV_KEY_INFO_free (p8inf);
 | 
							PKCS8_PRIV_KEY_INFO_free (p8inf);
 | 
				
			||||||
		EVP_PKEY_free(pkey);
 | 
							EVP_PKEY_free(pkey);
 | 
				
			||||||
		BIO_free_all(out);
 | 
							BIO_free_all(out);
 | 
				
			||||||
		if (passin)
 | 
							if(passin) OPENSSL_free(passin);
 | 
				
			||||||
			OPENSSL_free(passin);
 | 
							if(passout) OPENSSL_free(passout);
 | 
				
			||||||
		if (passout)
 | 
					 | 
				
			||||||
			OPENSSL_free(passout);
 | 
					 | 
				
			||||||
		return (0);
 | 
							return (0);
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (nocrypt)
 | 
						if(nocrypt) {
 | 
				
			||||||
		{
 | 
							if(informat == FORMAT_PEM) 
 | 
				
			||||||
		if (informat == FORMAT_PEM) 
 | 
					 | 
				
			||||||
			p8inf = PEM_read_bio_PKCS8_PRIV_KEY_INFO(in,NULL,NULL, NULL);
 | 
								p8inf = PEM_read_bio_PKCS8_PRIV_KEY_INFO(in,NULL,NULL, NULL);
 | 
				
			||||||
		else if (informat == FORMAT_ASN1)
 | 
							else if(informat == FORMAT_ASN1)
 | 
				
			||||||
			p8inf = d2i_PKCS8_PRIV_KEY_INFO_bio(in, NULL);
 | 
								p8inf = d2i_PKCS8_PRIV_KEY_INFO_bio(in, NULL);
 | 
				
			||||||
		else
 | 
							else {
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Bad format specified for key\n");
 | 
								BIO_printf(bio_err, "Bad format specified for key\n");
 | 
				
			||||||
			return (1);
 | 
								return (1);
 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						} else {
 | 
				
			||||||
		{
 | 
							if(informat == FORMAT_PEM) 
 | 
				
			||||||
		if (informat == FORMAT_PEM) 
 | 
					 | 
				
			||||||
			p8 = PEM_read_bio_PKCS8(in, NULL, NULL, NULL);
 | 
								p8 = PEM_read_bio_PKCS8(in, NULL, NULL, NULL);
 | 
				
			||||||
		else if (informat == FORMAT_ASN1)
 | 
							else if(informat == FORMAT_ASN1)
 | 
				
			||||||
			p8 = d2i_PKCS8_bio(in, NULL);
 | 
								p8 = d2i_PKCS8_bio(in, NULL);
 | 
				
			||||||
		else
 | 
							else {
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err, "Bad format specified for key\n");
 | 
								BIO_printf(bio_err, "Bad format specified for key\n");
 | 
				
			||||||
			return (1);
 | 
								return (1);
 | 
				
			||||||
			}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!p8)
 | 
							if (!p8) {
 | 
				
			||||||
			{
 | 
								BIO_printf (bio_err, "Error reading key\n", outfile);
 | 
				
			||||||
			BIO_printf (bio_err, "Error reading key\n");
 | 
					 | 
				
			||||||
			ERR_print_errors(bio_err);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
			return (1);
 | 
								return (1);
 | 
				
			||||||
			}
 | 
							}
 | 
				
			||||||
		if (passin)
 | 
							if(passin) p8pass = passin;
 | 
				
			||||||
			p8pass = passin;
 | 
							else {
 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			p8pass = pass;
 | 
								p8pass = pass;
 | 
				
			||||||
			EVP_read_pw_string(pass, sizeof pass, "Enter Password:", 0);
 | 
								EVP_read_pw_string(pass, 50, "Enter Password:", 0);
 | 
				
			||||||
			}
 | 
							}
 | 
				
			||||||
		p8inf = PKCS8_decrypt(p8, p8pass, strlen(p8pass));
 | 
							p8inf = PKCS8_decrypt(p8, p8pass, strlen(p8pass));
 | 
				
			||||||
		X509_SIG_free(p8);
 | 
							X509_SIG_free(p8);
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!p8inf)
 | 
						if (!p8inf) {
 | 
				
			||||||
		{
 | 
							BIO_printf(bio_err, "Error decrypting key\n", outfile);
 | 
				
			||||||
		BIO_printf(bio_err, "Error decrypting key\n");
 | 
					 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
		return (1);
 | 
							return (1);
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!(pkey = EVP_PKCS82PKEY(p8inf)))
 | 
						if (!(pkey = EVP_PKCS82PKEY(p8inf))) {
 | 
				
			||||||
		{
 | 
							BIO_printf(bio_err, "Error converting key\n", outfile);
 | 
				
			||||||
		BIO_printf(bio_err, "Error converting key\n");
 | 
					 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
		return (1);
 | 
							return (1);
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	if (p8inf->broken)
 | 
						if (p8inf->broken) {
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Warning: broken key encoding: ");
 | 
							BIO_printf(bio_err, "Warning: broken key encoding: ");
 | 
				
			||||||
		switch (p8inf->broken)
 | 
							switch (p8inf->broken) {
 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			case PKCS8_NO_OCTET:
 | 
								case PKCS8_NO_OCTET:
 | 
				
			||||||
			BIO_printf(bio_err, "No Octet String in PrivateKey\n");
 | 
								BIO_printf(bio_err, "No Octet String in PrivateKey\n");
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
@@ -437,24 +341,21 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	PKCS8_PRIV_KEY_INFO_free(p8inf);
 | 
						PKCS8_PRIV_KEY_INFO_free(p8inf);
 | 
				
			||||||
	if (outformat == FORMAT_PEM) 
 | 
						if(outformat == FORMAT_PEM) 
 | 
				
			||||||
		PEM_write_bio_PrivateKey(out, pkey, NULL, NULL, 0, NULL, passout);
 | 
							PEM_write_bio_PrivateKey(out, pkey, NULL, NULL, 0, NULL, passout);
 | 
				
			||||||
	else if (outformat == FORMAT_ASN1)
 | 
						else if(outformat == FORMAT_ASN1)
 | 
				
			||||||
		i2d_PrivateKey_bio(out, pkey);
 | 
							i2d_PrivateKey_bio(out, pkey);
 | 
				
			||||||
	else
 | 
						else {
 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Bad format specified for key\n");
 | 
							BIO_printf(bio_err, "Bad format specified for key\n");
 | 
				
			||||||
			return (1);
 | 
								return (1);
 | 
				
			||||||
		}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	end:
 | 
						end:
 | 
				
			||||||
	EVP_PKEY_free(pkey);
 | 
						EVP_PKEY_free(pkey);
 | 
				
			||||||
	BIO_free_all(out);
 | 
						BIO_free_all(out);
 | 
				
			||||||
	BIO_free(in);
 | 
						BIO_free(in);
 | 
				
			||||||
	if (passin)
 | 
						if(passin) OPENSSL_free(passin);
 | 
				
			||||||
		OPENSSL_free(passin);
 | 
						if(passout) OPENSSL_free(passout);
 | 
				
			||||||
	if (passout)
 | 
					 | 
				
			||||||
		OPENSSL_free(passout);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return (0);
 | 
						return (0);
 | 
				
			||||||
	}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										128
									
								
								apps/prime.c
									
									
									
									
									
								
							
							
						
						
									
										128
									
								
								apps/prime.c
									
									
									
									
									
								
							@@ -1,128 +0,0 @@
 | 
				
			|||||||
/* ====================================================================
 | 
					 | 
				
			||||||
 * Copyright (c) 2004 The OpenSSL Project.  All rights reserved.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * Redistribution and use in source and binary forms, with or without
 | 
					 | 
				
			||||||
 * modification, are permitted provided that the following conditions
 | 
					 | 
				
			||||||
 * are met:
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 1. Redistributions of source code must retain the above copyright
 | 
					 | 
				
			||||||
 *    notice, this list of conditions and the following disclaimer. 
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 2. Redistributions in binary form must reproduce the above copyright
 | 
					 | 
				
			||||||
 *    notice, this list of conditions and the following disclaimer in
 | 
					 | 
				
			||||||
 *    the documentation and/or other materials provided with the
 | 
					 | 
				
			||||||
 *    distribution.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 3. All advertising materials mentioning features or use of this
 | 
					 | 
				
			||||||
 *    software must display the following acknowledgment:
 | 
					 | 
				
			||||||
 *    "This product includes software developed by the OpenSSL Project
 | 
					 | 
				
			||||||
 *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
 | 
					 | 
				
			||||||
 *    endorse or promote products derived from this software without
 | 
					 | 
				
			||||||
 *    prior written permission. For written permission, please contact
 | 
					 | 
				
			||||||
 *    openssl-core@openssl.org.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 5. Products derived from this software may not be called "OpenSSL"
 | 
					 | 
				
			||||||
 *    nor may "OpenSSL" appear in their names without prior written
 | 
					 | 
				
			||||||
 *    permission of the OpenSSL Project.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * 6. Redistributions of any form whatsoever must retain the following
 | 
					 | 
				
			||||||
 *    acknowledgment:
 | 
					 | 
				
			||||||
 *    "This product includes software developed by the OpenSSL Project
 | 
					 | 
				
			||||||
 *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
 | 
					 | 
				
			||||||
 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
					 | 
				
			||||||
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 | 
					 | 
				
			||||||
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
 | 
					 | 
				
			||||||
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 | 
					 | 
				
			||||||
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 | 
					 | 
				
			||||||
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | 
					 | 
				
			||||||
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 | 
					 | 
				
			||||||
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 | 
					 | 
				
			||||||
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 | 
					 | 
				
			||||||
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 | 
					 | 
				
			||||||
 * OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include <string.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "apps.h"
 | 
					 | 
				
			||||||
#include <openssl/bn.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#undef PROG
 | 
					 | 
				
			||||||
#define PROG prime_main
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
    int hex=0;
 | 
					 | 
				
			||||||
    int checks=20;
 | 
					 | 
				
			||||||
    BIGNUM *bn=NULL;
 | 
					 | 
				
			||||||
    BIO *bio_out;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    apps_startup();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if (bio_err == NULL)
 | 
					 | 
				
			||||||
	if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
					 | 
				
			||||||
	    BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    --argc;
 | 
					 | 
				
			||||||
    ++argv;
 | 
					 | 
				
			||||||
    while (argc >= 1 && **argv == '-')
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	if(!strcmp(*argv,"-hex"))
 | 
					 | 
				
			||||||
	    hex=1;
 | 
					 | 
				
			||||||
	else if(!strcmp(*argv,"-checks"))
 | 
					 | 
				
			||||||
	    if(--argc < 1)
 | 
					 | 
				
			||||||
		goto bad;
 | 
					 | 
				
			||||||
	    else
 | 
					 | 
				
			||||||
		checks=atoi(*++argv);
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
	    {
 | 
					 | 
				
			||||||
	    BIO_printf(bio_err,"Unknown option '%s'\n",*argv);
 | 
					 | 
				
			||||||
	    goto bad;
 | 
					 | 
				
			||||||
	    }
 | 
					 | 
				
			||||||
	--argc;
 | 
					 | 
				
			||||||
	++argv;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if (argv[0] == NULL)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	BIO_printf(bio_err,"No prime specified\n");
 | 
					 | 
				
			||||||
	goto bad;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
   if ((bio_out=BIO_new(BIO_s_file())) != NULL)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	BIO_set_fp(bio_out,stdout,BIO_NOCLOSE);
 | 
					 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					 | 
				
			||||||
	    {
 | 
					 | 
				
			||||||
	    BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
					 | 
				
			||||||
	    bio_out = BIO_push(tmpbio, bio_out);
 | 
					 | 
				
			||||||
	    }
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    if(hex)
 | 
					 | 
				
			||||||
	BN_hex2bn(&bn,argv[0]);
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
	BN_dec2bn(&bn,argv[0]);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    BN_print(bio_out,bn);
 | 
					 | 
				
			||||||
    BIO_printf(bio_out," is %sprime\n",
 | 
					 | 
				
			||||||
	       BN_is_prime(bn,checks,NULL,NULL,NULL) ? "" : "not ");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    BN_free(bn);
 | 
					 | 
				
			||||||
    BIO_free_all(bio_out);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    return 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    bad:
 | 
					 | 
				
			||||||
    BIO_printf(bio_err,"options are\n");
 | 
					 | 
				
			||||||
    BIO_printf(bio_err,"%-14s hex\n","-hex");
 | 
					 | 
				
			||||||
    BIO_printf(bio_err,"%-14s number of checks\n","-checks <n>");
 | 
					 | 
				
			||||||
    return 1;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
							
								
								
									
										16
									
								
								apps/progs.h
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								apps/progs.h
									
									
									
									
									
								
							@@ -17,6 +17,8 @@ extern int rsa_main(int argc,char *argv[]);
 | 
				
			|||||||
extern int rsautl_main(int argc,char *argv[]);
 | 
					extern int rsautl_main(int argc,char *argv[]);
 | 
				
			||||||
extern int dsa_main(int argc,char *argv[]);
 | 
					extern int dsa_main(int argc,char *argv[]);
 | 
				
			||||||
extern int dsaparam_main(int argc,char *argv[]);
 | 
					extern int dsaparam_main(int argc,char *argv[]);
 | 
				
			||||||
 | 
					extern int ecdsa_main(int argc,char *argv[]);
 | 
				
			||||||
 | 
					extern int ecdsaparam_main(int argc,char *argv[]);
 | 
				
			||||||
extern int x509_main(int argc,char *argv[]);
 | 
					extern int x509_main(int argc,char *argv[]);
 | 
				
			||||||
extern int genrsa_main(int argc,char *argv[]);
 | 
					extern int genrsa_main(int argc,char *argv[]);
 | 
				
			||||||
extern int gendsa_main(int argc,char *argv[]);
 | 
					extern int gendsa_main(int argc,char *argv[]);
 | 
				
			||||||
@@ -35,10 +37,7 @@ extern int pkcs8_main(int argc,char *argv[]);
 | 
				
			|||||||
extern int spkac_main(int argc,char *argv[]);
 | 
					extern int spkac_main(int argc,char *argv[]);
 | 
				
			||||||
extern int smime_main(int argc,char *argv[]);
 | 
					extern int smime_main(int argc,char *argv[]);
 | 
				
			||||||
extern int rand_main(int argc,char *argv[]);
 | 
					extern int rand_main(int argc,char *argv[]);
 | 
				
			||||||
extern int prime_main(int argc,char *argv[]);
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
extern int engine_main(int argc,char *argv[]);
 | 
					extern int engine_main(int argc,char *argv[]);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
extern int ocsp_main(int argc,char *argv[]);
 | 
					extern int ocsp_main(int argc,char *argv[]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define FUNC_TYPE_GENERAL	1
 | 
					#define FUNC_TYPE_GENERAL	1
 | 
				
			||||||
@@ -81,6 +80,12 @@ FUNCTION functions[] = {
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"dsaparam",dsaparam_main},
 | 
						{FUNC_TYPE_GENERAL,"dsaparam",dsaparam_main},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
						{FUNC_TYPE_GENERAL,"ecdsa",ecdsa_main},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
						{FUNC_TYPE_GENERAL,"ecdsaparam",ecdsaparam_main},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"x509",x509_main},
 | 
						{FUNC_TYPE_GENERAL,"x509",x509_main},
 | 
				
			||||||
#ifndef OPENSSL_NO_RSA
 | 
					#ifndef OPENSSL_NO_RSA
 | 
				
			||||||
@@ -95,9 +100,7 @@ FUNCTION functions[] = {
 | 
				
			|||||||
#if !defined(OPENSSL_NO_SOCK) && !(defined(OPENSSL_NO_SSL2) && defined(OPENSSL_NO_SSL3))
 | 
					#if !defined(OPENSSL_NO_SOCK) && !(defined(OPENSSL_NO_SSL2) && defined(OPENSSL_NO_SSL3))
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"s_client",s_client_main},
 | 
						{FUNC_TYPE_GENERAL,"s_client",s_client_main},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_SPEED
 | 
					 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"speed",speed_main},
 | 
						{FUNC_TYPE_GENERAL,"speed",speed_main},
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#if !defined(OPENSSL_NO_SOCK) && !(defined(OPENSSL_NO_SSL2) && defined(OPENSSL_NO_SSL3))
 | 
					#if !defined(OPENSSL_NO_SOCK) && !(defined(OPENSSL_NO_SSL2) && defined(OPENSSL_NO_SSL3))
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"s_time",s_time_main},
 | 
						{FUNC_TYPE_GENERAL,"s_time",s_time_main},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -116,10 +119,7 @@ FUNCTION functions[] = {
 | 
				
			|||||||
	{FUNC_TYPE_GENERAL,"spkac",spkac_main},
 | 
						{FUNC_TYPE_GENERAL,"spkac",spkac_main},
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"smime",smime_main},
 | 
						{FUNC_TYPE_GENERAL,"smime",smime_main},
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"rand",rand_main},
 | 
						{FUNC_TYPE_GENERAL,"rand",rand_main},
 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"prime",prime_main},
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"engine",engine_main},
 | 
						{FUNC_TYPE_GENERAL,"engine",engine_main},
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	{FUNC_TYPE_GENERAL,"ocsp",ocsp_main},
 | 
						{FUNC_TYPE_GENERAL,"ocsp",ocsp_main},
 | 
				
			||||||
#ifndef OPENSSL_NO_MD2
 | 
					#ifndef OPENSSL_NO_MD2
 | 
				
			||||||
	{FUNC_TYPE_MD,"md2",dgst_main},
 | 
						{FUNC_TYPE_MD,"md2",dgst_main},
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,6 +33,8 @@ foreach (@ARGV)
 | 
				
			|||||||
		{ print "#ifndef OPENSSL_NO_RSA\n${str}#endif\n";  }
 | 
							{ print "#ifndef OPENSSL_NO_RSA\n${str}#endif\n";  }
 | 
				
			||||||
	elsif ( ($_ =~ /^dsa$/) || ($_ =~ /^gendsa$/) || ($_ =~ /^dsaparam$/))
 | 
						elsif ( ($_ =~ /^dsa$/) || ($_ =~ /^gendsa$/) || ($_ =~ /^dsaparam$/))
 | 
				
			||||||
		{ print "#ifndef OPENSSL_NO_DSA\n${str}#endif\n"; }
 | 
							{ print "#ifndef OPENSSL_NO_DSA\n${str}#endif\n"; }
 | 
				
			||||||
 | 
						elsif ( ($_ =~ /^ecdsa$/) || ($_ =~ /^ecdsaparam$/))
 | 
				
			||||||
 | 
							{ print "#ifndef OPENSSL_NO_ECDSA\n${str}#endif\n";}
 | 
				
			||||||
	elsif ( ($_ =~ /^dh$/) || ($_ =~ /^gendh$/) || ($_ =~ /^dhparam$/))
 | 
						elsif ( ($_ =~ /^dh$/) || ($_ =~ /^gendh$/) || ($_ =~ /^dhparam$/))
 | 
				
			||||||
		{ print "#ifndef OPENSSL_NO_DH\n${str}#endif\n"; }
 | 
							{ print "#ifndef OPENSSL_NO_DH\n${str}#endif\n"; }
 | 
				
			||||||
	elsif ( ($_ =~ /^pkcs12$/))
 | 
						elsif ( ($_ =~ /^pkcs12$/))
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										12
									
								
								apps/rand.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								apps/rand.c
									
									
									
									
									
								
							@@ -76,9 +76,7 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int i, r, ret = 1;
 | 
						int i, r, ret = 1;
 | 
				
			||||||
	int badopt;
 | 
						int badopt;
 | 
				
			||||||
	char *outfile = NULL;
 | 
						char *outfile = NULL;
 | 
				
			||||||
@@ -86,9 +84,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int base64 = 0;
 | 
						int base64 = 0;
 | 
				
			||||||
	BIO *out = NULL;
 | 
						BIO *out = NULL;
 | 
				
			||||||
	int num = -1;
 | 
						int num = -1;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -110,7 +106,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			else
 | 
								else
 | 
				
			||||||
				badopt = 1;
 | 
									badopt = 1;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(argv[i], "-engine") == 0)
 | 
							else if (strcmp(argv[i], "-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if ((argv[i+1] != NULL) && (engine == NULL))
 | 
								if ((argv[i+1] != NULL) && (engine == NULL))
 | 
				
			||||||
@@ -118,7 +113,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			else
 | 
								else
 | 
				
			||||||
				badopt = 1;
 | 
									badopt = 1;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(argv[i], "-rand") == 0)
 | 
							else if (strcmp(argv[i], "-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if ((argv[i+1] != NULL) && (inrand == NULL))
 | 
								if ((argv[i+1] != NULL) && (inrand == NULL))
 | 
				
			||||||
@@ -156,17 +150,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf(bio_err, "Usage: rand [options] num\n");
 | 
							BIO_printf(bio_err, "Usage: rand [options] num\n");
 | 
				
			||||||
		BIO_printf(bio_err, "where options are\n");
 | 
							BIO_printf(bio_err, "where options are\n");
 | 
				
			||||||
		BIO_printf(bio_err, "-out file             - write to file\n");
 | 
							BIO_printf(bio_err, "-out file             - write to file\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "-engine e             - use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err, "-engine e             - use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "-rand file%cfile%c... - seed PRNG from files\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
							BIO_printf(bio_err, "-rand file%cfile%c... - seed PRNG from files\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
		BIO_printf(bio_err, "-base64               - encode output\n");
 | 
							BIO_printf(bio_err, "-base64               - encode output\n");
 | 
				
			||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	app_RAND_load_file(NULL, bio_err, (inrand != NULL));
 | 
						app_RAND_load_file(NULL, bio_err, (inrand != NULL));
 | 
				
			||||||
	if (inrand != NULL)
 | 
						if (inrand != NULL)
 | 
				
			||||||
@@ -223,5 +213,5 @@ err:
 | 
				
			|||||||
	if (out)
 | 
						if (out)
 | 
				
			||||||
		BIO_free_all(out);
 | 
							BIO_free_all(out);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										206
									
								
								apps/req.c
									
									
									
									
									
								
							
							
						
						
									
										206
									
								
								apps/req.c
									
									
									
									
									
								
							@@ -73,7 +73,6 @@
 | 
				
			|||||||
#include <openssl/x509v3.h>
 | 
					#include <openssl/x509v3.h>
 | 
				
			||||||
#include <openssl/objects.h>
 | 
					#include <openssl/objects.h>
 | 
				
			||||||
#include <openssl/pem.h>
 | 
					#include <openssl/pem.h>
 | 
				
			||||||
#include "../crypto/cryptlib.h"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define SECTION		"req"
 | 
					#define SECTION		"req"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -135,6 +134,7 @@ static int req_check_len(int len,int n_min,int n_max);
 | 
				
			|||||||
static int check_end(char *str, char *end);
 | 
					static int check_end(char *str, char *end);
 | 
				
			||||||
#ifndef MONOLITH
 | 
					#ifndef MONOLITH
 | 
				
			||||||
static char *default_config_file=NULL;
 | 
					static char *default_config_file=NULL;
 | 
				
			||||||
 | 
					static CONF *config=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
static CONF *req_conf=NULL;
 | 
					static CONF *req_conf=NULL;
 | 
				
			||||||
static int batch=0;
 | 
					static int batch=0;
 | 
				
			||||||
@@ -142,6 +142,7 @@ static int batch=0;
 | 
				
			|||||||
#define TYPE_RSA	1
 | 
					#define TYPE_RSA	1
 | 
				
			||||||
#define TYPE_DSA	2
 | 
					#define TYPE_DSA	2
 | 
				
			||||||
#define TYPE_DH		3
 | 
					#define TYPE_DH		3
 | 
				
			||||||
 | 
					#define TYPE_ECDSA	4
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -151,7 +152,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
	DSA *dsa_params=NULL;
 | 
						DSA *dsa_params=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	unsigned long nmflag = 0, reqflag = 0;
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
						ECDSA *ecdsa_params = NULL;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						unsigned long nmflag = 0;
 | 
				
			||||||
	int ex=1,x509=0,days=30;
 | 
						int ex=1,x509=0,days=30;
 | 
				
			||||||
	X509 *x509ss=NULL;
 | 
						X509 *x509ss=NULL;
 | 
				
			||||||
	X509_REQ *req=NULL;
 | 
						X509_REQ *req=NULL;
 | 
				
			||||||
@@ -162,9 +166,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int informat,outformat,verify=0,noout=0,text=0,keyform=FORMAT_PEM;
 | 
						int informat,outformat,verify=0,noout=0,text=0,keyform=FORMAT_PEM;
 | 
				
			||||||
	int nodes=0,kludge=0,newhdr=0,subject=0,pubkey=0;
 | 
						int nodes=0,kludge=0,newhdr=0,subject=0,pubkey=0;
 | 
				
			||||||
	char *infile,*outfile,*prog,*keyfile=NULL,*template=NULL,*keyout=NULL;
 | 
						char *infile,*outfile,*prog,*keyfile=NULL,*template=NULL,*keyout=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *extensions = NULL;
 | 
						char *extensions = NULL;
 | 
				
			||||||
	char *req_exts = NULL;
 | 
						char *req_exts = NULL;
 | 
				
			||||||
	const EVP_CIPHER *cipher=NULL;
 | 
						const EVP_CIPHER *cipher=NULL;
 | 
				
			||||||
@@ -175,10 +177,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *passin = NULL, *passout = NULL;
 | 
						char *passin = NULL, *passout = NULL;
 | 
				
			||||||
	char *p;
 | 
						char *p;
 | 
				
			||||||
	char *subj = NULL;
 | 
						char *subj = NULL;
 | 
				
			||||||
	const EVP_MD *md_alg=NULL,*digest;
 | 
						const EVP_MD *md_alg=NULL,*digest=EVP_md5();
 | 
				
			||||||
	unsigned long chtype = MBSTRING_ASC;
 | 
						unsigned long chtype = MBSTRING_ASC;
 | 
				
			||||||
#ifndef MONOLITH
 | 
					#ifndef MONOLITH
 | 
				
			||||||
	char *to_free;
 | 
						MS_STATIC char config_name[256];
 | 
				
			||||||
	long errline;
 | 
						long errline;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -197,13 +199,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	informat=FORMAT_PEM;
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
	outformat=FORMAT_PEM;
 | 
						outformat=FORMAT_PEM;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef  OPENSSL_FIPS
 | 
					 | 
				
			||||||
	if (FIPS_mode())
 | 
					 | 
				
			||||||
		digest = EVP_sha1();
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		digest = EVP_md5();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	prog=argv[0];
 | 
						prog=argv[0];
 | 
				
			||||||
	argc--;
 | 
						argc--;
 | 
				
			||||||
	argv++;
 | 
						argv++;
 | 
				
			||||||
@@ -219,13 +214,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			outformat=str2fmt(*(++argv));
 | 
								outformat=str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-key") == 0)
 | 
							else if (strcmp(*argv,"-key") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -329,11 +322,63 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
						}
 | 
											}
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
				BIO_free(in);
 | 
									BIO_free(in);
 | 
				
			||||||
				newkey=BN_num_bits(dsa_params->p);
 | 
					 | 
				
			||||||
				in=NULL;
 | 
									in=NULL;
 | 
				
			||||||
 | 
									newkey=BN_num_bits(dsa_params->p);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else 
 | 
								else 
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
									if (strncmp("ecdsa:",p,4) == 0)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
									X509 *xtmp=NULL;
 | 
				
			||||||
 | 
									EVP_PKEY *dtmp;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									pkey_type=TYPE_ECDSA;
 | 
				
			||||||
 | 
									p+=6;
 | 
				
			||||||
 | 
									if ((in=BIO_new_file(p,"r")) == NULL)
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
										perror(p);
 | 
				
			||||||
 | 
										goto end;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
									if ((ecdsa_params = PEM_read_bio_ECDSAParameters(in, NULL, NULL, NULL)) == NULL)
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
										ERR_clear_error();
 | 
				
			||||||
 | 
										(void)BIO_reset(in);
 | 
				
			||||||
 | 
										if ((xtmp=PEM_read_bio_X509(in,NULL,NULL,NULL)) == NULL)
 | 
				
			||||||
 | 
											{	
 | 
				
			||||||
 | 
											BIO_printf(bio_err,"unable to load ECDSA parameters from file\n");
 | 
				
			||||||
 | 
											goto end;
 | 
				
			||||||
 | 
											}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										if ((dtmp=X509_get_pubkey(xtmp)) == NULL) goto end;
 | 
				
			||||||
 | 
										if (dtmp->type == EVP_PKEY_ECDSA)
 | 
				
			||||||
 | 
											ecdsa_params = ECDSAParameters_dup(dtmp->pkey.ecdsa);
 | 
				
			||||||
 | 
										EVP_PKEY_free(dtmp);
 | 
				
			||||||
 | 
										X509_free(xtmp);
 | 
				
			||||||
 | 
										if (ecdsa_params == NULL)
 | 
				
			||||||
 | 
											{
 | 
				
			||||||
 | 
											BIO_printf(bio_err,"Certificate does not contain ECDSA parameters\n");
 | 
				
			||||||
 | 
											goto end;
 | 
				
			||||||
 | 
											}
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									BIO_free(in);
 | 
				
			||||||
 | 
									in=NULL;
 | 
				
			||||||
 | 
									
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
									BIGNUM *order = BN_new();
 | 
				
			||||||
 | 
									
 | 
				
			||||||
 | 
									if (!order)
 | 
				
			||||||
 | 
										goto end;
 | 
				
			||||||
 | 
									if (!EC_GROUP_get_order(ecdsa_params->group, order, NULL))
 | 
				
			||||||
 | 
										goto end;
 | 
				
			||||||
 | 
									newkey = BN_num_bits(order);
 | 
				
			||||||
 | 
									BN_free(order);
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								else
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_DH
 | 
					#ifndef OPENSSL_NO_DH
 | 
				
			||||||
				if (strncmp("dh:",p,4) == 0)
 | 
									if (strncmp("dh:",p,4) == 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
@@ -367,11 +412,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			if (!set_name_ex(&nmflag, *(++argv))) goto bad;
 | 
								if (!set_name_ex(&nmflag, *(++argv))) goto bad;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-reqopt") == 0)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
					 | 
				
			||||||
			if (!set_cert_ex(&reqflag, *(++argv))) goto bad;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-subject") == 0)
 | 
							else if (strcmp(*argv,"-subject") == 0)
 | 
				
			||||||
			subject=1;
 | 
								subject=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-text") == 0)
 | 
							else if (strcmp(*argv,"-text") == 0)
 | 
				
			||||||
@@ -439,9 +479,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -verify        verify signature on REQ\n");
 | 
							BIO_printf(bio_err," -verify        verify signature on REQ\n");
 | 
				
			||||||
		BIO_printf(bio_err," -modulus       RSA modulus\n");
 | 
							BIO_printf(bio_err," -modulus       RSA modulus\n");
 | 
				
			||||||
		BIO_printf(bio_err," -nodes         don't encrypt the output key\n");
 | 
							BIO_printf(bio_err," -nodes         don't encrypt the output key\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e      use engine e, possibly a hardware device\n");
 | 
							BIO_printf(bio_err," -engine e      use engine e, possibly a hardware device\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -subject       output the request's subject\n");
 | 
							BIO_printf(bio_err," -subject       output the request's subject\n");
 | 
				
			||||||
		BIO_printf(bio_err," -passin        private key password source\n");
 | 
							BIO_printf(bio_err," -passin        private key password source\n");
 | 
				
			||||||
		BIO_printf(bio_err," -key file      use the private key contained in file\n");
 | 
							BIO_printf(bio_err," -key file      use the private key contained in file\n");
 | 
				
			||||||
@@ -452,6 +490,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err,"                the random number generator\n");
 | 
							BIO_printf(bio_err,"                the random number generator\n");
 | 
				
			||||||
		BIO_printf(bio_err," -newkey rsa:bits generate a new RSA key of 'bits' in size\n");
 | 
							BIO_printf(bio_err," -newkey rsa:bits generate a new RSA key of 'bits' in size\n");
 | 
				
			||||||
		BIO_printf(bio_err," -newkey dsa:file generate a new DSA key, parameters taken from CA in 'file'\n");
 | 
							BIO_printf(bio_err," -newkey dsa:file generate a new DSA key, parameters taken from CA in 'file'\n");
 | 
				
			||||||
 | 
							BIO_printf(bio_err," -newkey ecdsa:file generate a new ECDSA key, parameters taken from CA in 'file'\n");
 | 
				
			||||||
		BIO_printf(bio_err," -[digest]      Digest to sign with (md5, sha1, md2, mdc2, md4)\n");
 | 
							BIO_printf(bio_err," -[digest]      Digest to sign with (md5, sha1, md2, mdc2, md4)\n");
 | 
				
			||||||
		BIO_printf(bio_err," -config file   request template file.\n");
 | 
							BIO_printf(bio_err," -config file   request template file.\n");
 | 
				
			||||||
		BIO_printf(bio_err," -subj arg      set or modify request subject\n");
 | 
							BIO_printf(bio_err," -subj arg      set or modify request subject\n");
 | 
				
			||||||
@@ -467,7 +506,6 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -reqexts ..    specify request extension section (override value in config file)\n");
 | 
							BIO_printf(bio_err," -reqexts ..    specify request extension section (override value in config file)\n");
 | 
				
			||||||
		BIO_printf(bio_err," -utf8          input characters are UTF8 (default ASCII)\n");
 | 
							BIO_printf(bio_err," -utf8          input characters are UTF8 (default ASCII)\n");
 | 
				
			||||||
		BIO_printf(bio_err," -nameopt arg    - various certificate name options\n");
 | 
							BIO_printf(bio_err," -nameopt arg    - various certificate name options\n");
 | 
				
			||||||
		BIO_printf(bio_err," -reqopt arg    - various request text options\n\n");
 | 
					 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -483,7 +521,14 @@ bad:
 | 
				
			|||||||
	if (p == NULL)
 | 
						if (p == NULL)
 | 
				
			||||||
		p=getenv("SSLEAY_CONF");
 | 
							p=getenv("SSLEAY_CONF");
 | 
				
			||||||
	if (p == NULL)
 | 
						if (p == NULL)
 | 
				
			||||||
		p=to_free=make_config_name();
 | 
							{
 | 
				
			||||||
 | 
							strcpy(config_name,X509_get_default_cert_area());
 | 
				
			||||||
 | 
					#ifndef OPENSSL_SYS_VMS
 | 
				
			||||||
 | 
							strcat(config_name,"/");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							strcat(config_name,OPENSSL_CONF);
 | 
				
			||||||
 | 
							p=config_name;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	default_config_file=p;
 | 
						default_config_file=p;
 | 
				
			||||||
	config=NCONF_new(NULL);
 | 
						config=NCONF_new(NULL);
 | 
				
			||||||
	i=NCONF_load(config, p, &errline);
 | 
						i=NCONF_load(config, p, &errline);
 | 
				
			||||||
@@ -491,7 +536,7 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (template != NULL)
 | 
						if (template != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		long errline = -1;
 | 
							long errline;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if( verbose )
 | 
							if( verbose )
 | 
				
			||||||
			BIO_printf(bio_err,"Using configuration from %s\n",template);
 | 
								BIO_printf(bio_err,"Using configuration from %s\n",template);
 | 
				
			||||||
@@ -506,16 +551,13 @@ bad:
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		req_conf=config;
 | 
							req_conf=config;
 | 
				
			||||||
 | 
							if( verbose )
 | 
				
			||||||
		if (req_conf == NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"Unable to load config info from %s\n", default_config_file);
 | 
					 | 
				
			||||||
			if (newreq)
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else if( verbose )
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"Using configuration from %s\n",
 | 
								BIO_printf(bio_err,"Using configuration from %s\n",
 | 
				
			||||||
			default_config_file);
 | 
								default_config_file);
 | 
				
			||||||
 | 
							if (req_conf == NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"Unable to load config info\n");
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (req_conf != NULL)
 | 
						if (req_conf != NULL)
 | 
				
			||||||
@@ -633,13 +675,11 @@ bad:
 | 
				
			|||||||
	if ((in == NULL) || (out == NULL))
 | 
						if ((in == NULL) || (out == NULL))
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (keyfile != NULL)
 | 
						if (keyfile != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		pkey = load_key(bio_err, keyfile, keyform, 0, passin, e,
 | 
							pkey = load_key(bio_err, keyfile, keyform, passin, e,
 | 
				
			||||||
			"Private Key");
 | 
								"Private Key");
 | 
				
			||||||
		if (!pkey)
 | 
							if (!pkey)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -647,7 +687,7 @@ bad:
 | 
				
			|||||||
			   message */
 | 
								   message */
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if (EVP_PKEY_type(pkey->type) == EVP_PKEY_DSA)
 | 
							if (EVP_PKEY_type(pkey->type) == EVP_PKEY_DSA || EVP_PKEY_type(pkey->type) == EVP_PKEY_ECDSA)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			char *randfile = NCONF_get_string(req_conf,SECTION,"RANDFILE");
 | 
								char *randfile = NCONF_get_string(req_conf,SECTION,"RANDFILE");
 | 
				
			||||||
			if (randfile == NULL)
 | 
								if (randfile == NULL)
 | 
				
			||||||
@@ -671,14 +711,15 @@ bad:
 | 
				
			|||||||
				newkey=DEFAULT_KEY_LENGTH;
 | 
									newkey=DEFAULT_KEY_LENGTH;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (newkey < MIN_KEY_LENGTH)
 | 
							if (newkey < MIN_KEY_LENGTH && (pkey_type == TYPE_RSA || pkey_type == TYPE_DSA))
 | 
				
			||||||
 | 
							/* TODO: appropriate minimal keylength for the different algorithm (esp. ECDSA) */
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err,"private key length is too short,\n");
 | 
								BIO_printf(bio_err,"private key length is too short,\n");
 | 
				
			||||||
			BIO_printf(bio_err,"it needs to be at least %d bits, not %d\n",MIN_KEY_LENGTH,newkey);
 | 
								BIO_printf(bio_err,"it needs to be at least %d bits, not %d\n",MIN_KEY_LENGTH,newkey);
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		BIO_printf(bio_err,"Generating a %d bit %s private key\n",
 | 
							BIO_printf(bio_err,"Generating a %d bit %s private key\n",
 | 
				
			||||||
			newkey,(pkey_type == TYPE_RSA)?"RSA":"DSA");
 | 
								newkey,(pkey_type == TYPE_RSA)?"RSA":(pkey_type == TYPE_DSA)?"DSA":"ECDSA");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((pkey=EVP_PKEY_new()) == NULL) goto end;
 | 
							if ((pkey=EVP_PKEY_new()) == NULL) goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -700,6 +741,14 @@ bad:
 | 
				
			|||||||
			dsa_params=NULL;
 | 
								dsa_params=NULL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
								if (pkey_type == TYPE_ECDSA)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								if (!ECDSA_generate_key(ecdsa_params)) goto end;
 | 
				
			||||||
 | 
								if (!EVP_PKEY_assign_ECDSA(pkey, ecdsa_params)) goto end;
 | 
				
			||||||
 | 
								ecdsa_params = NULL;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		app_RAND_write_file(randfile, bio_err);
 | 
							app_RAND_write_file(randfile, bio_err);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -805,6 +854,10 @@ loop:
 | 
				
			|||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
		if (pkey->type == EVP_PKEY_DSA)
 | 
							if (pkey->type == EVP_PKEY_DSA)
 | 
				
			||||||
			digest=EVP_dss1();
 | 
								digest=EVP_dss1();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
							if (pkey->type == EVP_PKEY_ECDSA)
 | 
				
			||||||
 | 
								digest=EVP_ecdsa();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		if (req == NULL)
 | 
							if (req == NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -834,16 +887,14 @@ loop:
 | 
				
			|||||||
			if ((x509ss=X509_new()) == NULL) goto end;
 | 
								if ((x509ss=X509_new()) == NULL) goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			/* Set version to V3 */
 | 
								/* Set version to V3 */
 | 
				
			||||||
			if(extensions && !X509_set_version(x509ss, 2)) goto end;
 | 
								if(!X509_set_version(x509ss, 2)) goto end;
 | 
				
			||||||
			if (serial)
 | 
								if (serial)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if (!X509_set_serialNumber(x509ss, serial)) goto end;
 | 
									if (!X509_set_serialNumber(x509ss, serial)) goto end;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else
 | 
								else
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if (!rand_serial(NULL,
 | 
									if (!ASN1_INTEGER_set(X509_get_serialNumber(x509ss),0L)) goto end;
 | 
				
			||||||
					X509_get_serialNumber(x509ss)))
 | 
					 | 
				
			||||||
						goto end;
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!X509_set_issuer_name(x509ss, X509_REQ_get_subject_name(req))) goto end;
 | 
								if (!X509_set_issuer_name(x509ss, X509_REQ_get_subject_name(req))) goto end;
 | 
				
			||||||
@@ -1000,9 +1051,9 @@ loop:
 | 
				
			|||||||
	if (text)
 | 
						if (text)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (x509)
 | 
							if (x509)
 | 
				
			||||||
			X509_print_ex(out, x509ss, nmflag, reqflag);
 | 
								X509_print(out,x509ss);
 | 
				
			||||||
		else	
 | 
							else	
 | 
				
			||||||
			X509_REQ_print_ex(out, req, nmflag, reqflag);
 | 
								X509_REQ_print(out,req);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(subject) 
 | 
						if(subject) 
 | 
				
			||||||
@@ -1072,10 +1123,6 @@ loop:
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	ex=0;
 | 
						ex=0;
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
#ifndef MONOLITH
 | 
					 | 
				
			||||||
	if(to_free)
 | 
					 | 
				
			||||||
		OPENSSL_free(to_free);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if (ex)
 | 
						if (ex)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
@@ -1092,9 +1139,12 @@ end:
 | 
				
			|||||||
	OBJ_cleanup();
 | 
						OBJ_cleanup();
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
	if (dsa_params != NULL) DSA_free(dsa_params);
 | 
						if (dsa_params != NULL) DSA_free(dsa_params);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
						if (ecdsa_params != NULL) ECDSA_free(ecdsa_params);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ex);
 | 
						EXIT(ex);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int make_REQ(X509_REQ *req, EVP_PKEY *pkey, char *subj, int attribs,
 | 
					static int make_REQ(X509_REQ *req, EVP_PKEY *pkey, char *subj, int attribs,
 | 
				
			||||||
@@ -1235,39 +1285,27 @@ start:		for (;;)
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			/* If OBJ not recognised ignore it */
 | 
								/* If OBJ not recognised ignore it */
 | 
				
			||||||
			if ((nid=OBJ_txt2nid(type)) == NID_undef) goto start;
 | 
								if ((nid=OBJ_txt2nid(type)) == NID_undef) goto start;
 | 
				
			||||||
			if (BIO_snprintf(buf,sizeof buf,"%s_default",v->name)
 | 
								sprintf(buf,"%s_default",v->name);
 | 
				
			||||||
				>= sizeof buf)
 | 
					 | 
				
			||||||
			   {
 | 
					 | 
				
			||||||
			   BIO_printf(bio_err,"Name '%s' too long\n",v->name);
 | 
					 | 
				
			||||||
			   return 0;
 | 
					 | 
				
			||||||
			   }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			if ((def=NCONF_get_string(req_conf,dn_sect,buf)) == NULL)
 | 
								if ((def=NCONF_get_string(req_conf,dn_sect,buf)) == NULL)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				ERR_clear_error();
 | 
									ERR_clear_error();
 | 
				
			||||||
				def="";
 | 
									def="";
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
				
 | 
									
 | 
				
			||||||
			BIO_snprintf(buf,sizeof buf,"%s_value",v->name);
 | 
								sprintf(buf,"%s_value",v->name);
 | 
				
			||||||
			if ((value=NCONF_get_string(req_conf,dn_sect,buf)) == NULL)
 | 
								if ((value=NCONF_get_string(req_conf,dn_sect,buf)) == NULL)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				ERR_clear_error();
 | 
									ERR_clear_error();
 | 
				
			||||||
				value=NULL;
 | 
									value=NULL;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			BIO_snprintf(buf,sizeof buf,"%s_min",v->name);
 | 
								sprintf(buf,"%s_min",v->name);
 | 
				
			||||||
			if (!NCONF_get_number(req_conf,dn_sect,buf, &n_min))
 | 
								if (!NCONF_get_number(req_conf,dn_sect,buf, &n_min))
 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				ERR_clear_error();
 | 
					 | 
				
			||||||
				n_min = -1;
 | 
									n_min = -1;
 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			BIO_snprintf(buf,sizeof buf,"%s_max",v->name);
 | 
								sprintf(buf,"%s_max",v->name);
 | 
				
			||||||
			if (!NCONF_get_number(req_conf,dn_sect,buf, &n_max))
 | 
								if (!NCONF_get_number(req_conf,dn_sect,buf, &n_max))
 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				ERR_clear_error();
 | 
					 | 
				
			||||||
				n_max = -1;
 | 
									n_max = -1;
 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!add_DN_object(subj,v->value,def,value,nid,
 | 
								if (!add_DN_object(subj,v->value,def,value,nid,
 | 
				
			||||||
				n_min,n_max, chtype))
 | 
									n_min,n_max, chtype))
 | 
				
			||||||
@@ -1300,13 +1338,7 @@ start2:			for (;;)
 | 
				
			|||||||
				if ((nid=OBJ_txt2nid(type)) == NID_undef)
 | 
									if ((nid=OBJ_txt2nid(type)) == NID_undef)
 | 
				
			||||||
					goto start2;
 | 
										goto start2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (BIO_snprintf(buf,sizeof buf,"%s_default",type)
 | 
									sprintf(buf,"%s_default",type);
 | 
				
			||||||
					>= sizeof buf)
 | 
					 | 
				
			||||||
				   {
 | 
					 | 
				
			||||||
				   BIO_printf(bio_err,"Name '%s' too long\n",v->name);
 | 
					 | 
				
			||||||
				   return 0;
 | 
					 | 
				
			||||||
				   }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				if ((def=NCONF_get_string(req_conf,attr_sect,buf))
 | 
									if ((def=NCONF_get_string(req_conf,attr_sect,buf))
 | 
				
			||||||
					== NULL)
 | 
										== NULL)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
@@ -1315,7 +1347,7 @@ start2:			for (;;)
 | 
				
			|||||||
					}
 | 
										}
 | 
				
			||||||
				
 | 
									
 | 
				
			||||||
				
 | 
									
 | 
				
			||||||
				BIO_snprintf(buf,sizeof buf,"%s_value",type);
 | 
									sprintf(buf,"%s_value",type);
 | 
				
			||||||
				if ((value=NCONF_get_string(req_conf,attr_sect,buf))
 | 
									if ((value=NCONF_get_string(req_conf,attr_sect,buf))
 | 
				
			||||||
					== NULL)
 | 
										== NULL)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
@@ -1323,11 +1355,11 @@ start2:			for (;;)
 | 
				
			|||||||
					value=NULL;
 | 
										value=NULL;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				BIO_snprintf(buf,sizeof buf,"%s_min",type);
 | 
									sprintf(buf,"%s_min",type);
 | 
				
			||||||
				if (!NCONF_get_number(req_conf,attr_sect,buf, &n_min))
 | 
									if (!NCONF_get_number(req_conf,attr_sect,buf, &n_min))
 | 
				
			||||||
					n_min = -1;
 | 
										n_min = -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				BIO_snprintf(buf,sizeof buf,"%s_max",type);
 | 
									sprintf(buf,"%s_max",type);
 | 
				
			||||||
				if (!NCONF_get_number(req_conf,attr_sect,buf, &n_max))
 | 
									if (!NCONF_get_number(req_conf,attr_sect,buf, &n_max))
 | 
				
			||||||
					n_max = -1;
 | 
										n_max = -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1409,8 +1441,8 @@ start:
 | 
				
			|||||||
	(void)BIO_flush(bio_err);
 | 
						(void)BIO_flush(bio_err);
 | 
				
			||||||
	if(value != NULL)
 | 
						if(value != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BUF_strlcpy(buf,value,sizeof buf);
 | 
							strcpy(buf,value);
 | 
				
			||||||
		BUF_strlcat(buf,"\n",sizeof buf);
 | 
							strcat(buf,"\n");
 | 
				
			||||||
		BIO_printf(bio_err,"%s\n",value);
 | 
							BIO_printf(bio_err,"%s\n",value);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -1418,7 +1450,7 @@ start:
 | 
				
			|||||||
		buf[0]='\0';
 | 
							buf[0]='\0';
 | 
				
			||||||
		if (!batch)
 | 
							if (!batch)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			fgets(buf,sizeof buf,stdin);
 | 
								fgets(buf,1024,stdin);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1432,8 +1464,8 @@ start:
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if ((def == NULL) || (def[0] == '\0'))
 | 
							if ((def == NULL) || (def[0] == '\0'))
 | 
				
			||||||
			return(1);
 | 
								return(1);
 | 
				
			||||||
		BUF_strlcpy(buf,def,sizeof buf);
 | 
							strcpy(buf,def);
 | 
				
			||||||
		BUF_strlcat(buf,"\n",sizeof buf);
 | 
							strcat(buf,"\n");
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else if ((buf[0] == '.') && (buf[1] == '\n')) return(1);
 | 
						else if ((buf[0] == '.') && (buf[1] == '\n')) return(1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1467,8 +1499,8 @@ start:
 | 
				
			|||||||
	(void)BIO_flush(bio_err);
 | 
						(void)BIO_flush(bio_err);
 | 
				
			||||||
	if (value != NULL)
 | 
						if (value != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BUF_strlcpy(buf,value,sizeof buf);
 | 
							strcpy(buf,value);
 | 
				
			||||||
		BUF_strlcat(buf,"\n",sizeof buf);
 | 
							strcat(buf,"\n");
 | 
				
			||||||
		BIO_printf(bio_err,"%s\n",value);
 | 
							BIO_printf(bio_err,"%s\n",value);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -1476,7 +1508,7 @@ start:
 | 
				
			|||||||
		buf[0]='\0';
 | 
							buf[0]='\0';
 | 
				
			||||||
		if (!batch)
 | 
							if (!batch)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			fgets(buf,sizeof buf,stdin);
 | 
								fgets(buf,1024,stdin);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -1490,8 +1522,8 @@ start:
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if ((def == NULL) || (def[0] == '\0'))
 | 
							if ((def == NULL) || (def[0] == '\0'))
 | 
				
			||||||
			return(1);
 | 
								return(1);
 | 
				
			||||||
		BUF_strlcpy(buf,def,sizeof buf);
 | 
							strcpy(buf,def);
 | 
				
			||||||
		BUF_strlcat(buf,"\n",sizeof buf);
 | 
							strcat(buf,"\n");
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else if ((buf[0] == '.') && (buf[1] == '\n')) return(1);
 | 
						else if ((buf[0] == '.') && (buf[1] == '\n')) return(1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										14
									
								
								apps/rsa.c
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								apps/rsa.c
									
									
									
									
									
								
							@@ -104,9 +104,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *infile,*outfile,*prog;
 | 
						char *infile,*outfile,*prog;
 | 
				
			||||||
	char *passargin = NULL, *passargout = NULL;
 | 
						char *passargin = NULL, *passargout = NULL;
 | 
				
			||||||
	char *passin = NULL, *passout = NULL;
 | 
						char *passin = NULL, *passout = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	int modulus=0;
 | 
						int modulus=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
@@ -158,13 +156,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			passargout= *(++argv);
 | 
								passargout= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-sgckey") == 0)
 | 
							else if (strcmp(*argv,"-sgckey") == 0)
 | 
				
			||||||
			sgckey=1;
 | 
								sgckey=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-pubin") == 0)
 | 
							else if (strcmp(*argv,"-pubin") == 0)
 | 
				
			||||||
@@ -216,17 +212,13 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -check          verify key consistency\n");
 | 
							BIO_printf(bio_err," -check          verify key consistency\n");
 | 
				
			||||||
		BIO_printf(bio_err," -pubin          expect a public key in input file\n");
 | 
							BIO_printf(bio_err," -pubin          expect a public key in input file\n");
 | 
				
			||||||
		BIO_printf(bio_err," -pubout         output a public key\n");
 | 
							BIO_printf(bio_err," -pubout         output a public key\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ERR_load_crypto_strings();
 | 
						ERR_load_crypto_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) {
 | 
						if(!app_passwd(bio_err, passargin, passargout, &passin, &passout)) {
 | 
				
			||||||
		BIO_printf(bio_err, "Error getting passwords\n");
 | 
							BIO_printf(bio_err, "Error getting passwords\n");
 | 
				
			||||||
@@ -246,12 +238,12 @@ bad:
 | 
				
			|||||||
		if (pubin)
 | 
							if (pubin)
 | 
				
			||||||
			pkey = load_pubkey(bio_err, infile,
 | 
								pkey = load_pubkey(bio_err, infile,
 | 
				
			||||||
				(informat == FORMAT_NETSCAPE && sgckey ?
 | 
									(informat == FORMAT_NETSCAPE && sgckey ?
 | 
				
			||||||
					FORMAT_IISSGC : informat), 1,
 | 
										FORMAT_IISSGC : informat),
 | 
				
			||||||
				passin, e, "Public Key");
 | 
									passin, e, "Public Key");
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			pkey = load_key(bio_err, infile,
 | 
								pkey = load_key(bio_err, infile,
 | 
				
			||||||
				(informat == FORMAT_NETSCAPE && sgckey ?
 | 
									(informat == FORMAT_NETSCAPE && sgckey ?
 | 
				
			||||||
					FORMAT_IISSGC : informat), 1,
 | 
										FORMAT_IISSGC : informat),
 | 
				
			||||||
				passin, e, "Private Key");
 | 
									passin, e, "Private Key");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (pkey != NULL)
 | 
							if (pkey != NULL)
 | 
				
			||||||
@@ -377,7 +369,7 @@ end:
 | 
				
			|||||||
	if(passin) OPENSSL_free(passin);
 | 
						if(passin) OPENSSL_free(passin);
 | 
				
			||||||
	if(passout) OPENSSL_free(passout);
 | 
						if(passout) OPENSSL_free(passout);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#else /* !OPENSSL_NO_RSA */
 | 
					#else /* !OPENSSL_NO_RSA */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,7 @@
 | 
				
			|||||||
 * project 2000.
 | 
					 * project 2000.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 2000-2005 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 2000 The OpenSSL Project.  All rights reserved.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Redistribution and use in source and binary forms, with or without
 | 
					 * Redistribution and use in source and binary forms, with or without
 | 
				
			||||||
 * modification, are permitted provided that the following conditions
 | 
					 * modification, are permitted provided that the following conditions
 | 
				
			||||||
@@ -85,9 +85,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
	BIO *in = NULL, *out = NULL;
 | 
						BIO *in = NULL, *out = NULL;
 | 
				
			||||||
	char *infile = NULL, *outfile = NULL;
 | 
						char *infile = NULL, *outfile = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine = NULL;
 | 
						char *engine = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *keyfile = NULL;
 | 
						char *keyfile = NULL;
 | 
				
			||||||
	char rsa_mode = RSA_VERIFY, key_type = KEY_PRIVKEY;
 | 
						char rsa_mode = RSA_VERIFY, key_type = KEY_PRIVKEY;
 | 
				
			||||||
	int keyform = FORMAT_PEM;
 | 
						int keyform = FORMAT_PEM;
 | 
				
			||||||
@@ -97,7 +95,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	EVP_PKEY *pkey = NULL;
 | 
						EVP_PKEY *pkey = NULL;
 | 
				
			||||||
	RSA *rsa = NULL;
 | 
						RSA *rsa = NULL;
 | 
				
			||||||
	unsigned char *rsa_in = NULL, *rsa_out = NULL, pad;
 | 
						unsigned char *rsa_in = NULL, *rsa_out = NULL, pad;
 | 
				
			||||||
	char *passargin = NULL, *passin = NULL;
 | 
					 | 
				
			||||||
	int rsa_inlen, rsa_outlen = 0;
 | 
						int rsa_inlen, rsa_outlen = 0;
 | 
				
			||||||
	int keysize;
 | 
						int keysize;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -125,17 +122,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		} else if(!strcmp(*argv, "-inkey")) {
 | 
							} else if(!strcmp(*argv, "-inkey")) {
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			keyfile = *(++argv);
 | 
								keyfile = *(++argv);
 | 
				
			||||||
		} else if (!strcmp(*argv,"-passin")) {
 | 
					 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
					 | 
				
			||||||
			passargin= *(++argv);
 | 
					 | 
				
			||||||
		} else if (strcmp(*argv,"-keyform") == 0) {
 | 
							} else if (strcmp(*argv,"-keyform") == 0) {
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			keyform=str2fmt(*(++argv));
 | 
								keyform=str2fmt(*(++argv));
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		} else if(!strcmp(*argv, "-engine")) {
 | 
							} else if(!strcmp(*argv, "-engine")) {
 | 
				
			||||||
			if (--argc < 1) badarg = 1;
 | 
								if (--argc < 1) badarg = 1;
 | 
				
			||||||
			engine = *(++argv);
 | 
								engine = *(++argv);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		} else if(!strcmp(*argv, "-pubin")) {
 | 
							} else if(!strcmp(*argv, "-pubin")) {
 | 
				
			||||||
			key_type = KEY_PUBKEY;
 | 
								key_type = KEY_PUBKEY;
 | 
				
			||||||
		} else if(!strcmp(*argv, "-certin")) {
 | 
							} else if(!strcmp(*argv, "-certin")) {
 | 
				
			||||||
@@ -147,7 +139,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if(!strcmp(*argv, "-oaep")) pad = RSA_PKCS1_OAEP_PADDING;
 | 
							else if(!strcmp(*argv, "-oaep")) pad = RSA_PKCS1_OAEP_PADDING;
 | 
				
			||||||
		else if(!strcmp(*argv, "-ssl")) pad = RSA_SSLV23_PADDING;
 | 
							else if(!strcmp(*argv, "-ssl")) pad = RSA_SSLV23_PADDING;
 | 
				
			||||||
		else if(!strcmp(*argv, "-pkcs")) pad = RSA_PKCS1_PADDING;
 | 
							else if(!strcmp(*argv, "-pkcs")) pad = RSA_PKCS1_PADDING;
 | 
				
			||||||
		else if(!strcmp(*argv, "-x931")) pad = RSA_X931_PADDING;
 | 
					 | 
				
			||||||
		else if(!strcmp(*argv, "-sign")) {
 | 
							else if(!strcmp(*argv, "-sign")) {
 | 
				
			||||||
			rsa_mode = RSA_SIGN;
 | 
								rsa_mode = RSA_SIGN;
 | 
				
			||||||
			need_priv = 1;
 | 
								need_priv = 1;
 | 
				
			||||||
@@ -171,25 +162,19 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, NULL, &passin, NULL)) {
 | 
					 | 
				
			||||||
		BIO_printf(bio_err, "Error getting password\n");
 | 
					 | 
				
			||||||
		goto end;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* FIXME: seed PRNG only if needed */
 | 
					/* FIXME: seed PRNG only if needed */
 | 
				
			||||||
	app_RAND_load_file(NULL, bio_err, 0);
 | 
						app_RAND_load_file(NULL, bio_err, 0);
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	switch(key_type) {
 | 
						switch(key_type) {
 | 
				
			||||||
		case KEY_PRIVKEY:
 | 
							case KEY_PRIVKEY:
 | 
				
			||||||
		pkey = load_key(bio_err, keyfile, keyform, 0,
 | 
							pkey = load_key(bio_err, keyfile, keyform,
 | 
				
			||||||
			passin, e, "Private Key");
 | 
								NULL, e, "Private Key");
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		case KEY_PUBKEY:
 | 
							case KEY_PUBKEY:
 | 
				
			||||||
		pkey = load_pubkey(bio_err, keyfile, keyform, 0,
 | 
							pkey = load_pubkey(bio_err, keyfile, keyform,
 | 
				
			||||||
			NULL, e, "Public Key");
 | 
								NULL, e, "Public Key");
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -299,7 +284,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	BIO_free_all(out);
 | 
						BIO_free_all(out);
 | 
				
			||||||
	if(rsa_in) OPENSSL_free(rsa_in);
 | 
						if(rsa_in) OPENSSL_free(rsa_in);
 | 
				
			||||||
	if(rsa_out) OPENSSL_free(rsa_out);
 | 
						if(rsa_out) OPENSSL_free(rsa_out);
 | 
				
			||||||
	if(passin) OPENSSL_free(passin);
 | 
					 | 
				
			||||||
	return ret;
 | 
						return ret;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -321,10 +305,7 @@ static void usage()
 | 
				
			|||||||
	BIO_printf(bio_err, "-encrypt        encrypt with public key\n");
 | 
						BIO_printf(bio_err, "-encrypt        encrypt with public key\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-decrypt        decrypt with private key\n");
 | 
						BIO_printf(bio_err, "-decrypt        decrypt with private key\n");
 | 
				
			||||||
	BIO_printf(bio_err, "-hexdump        hex dump output\n");
 | 
						BIO_printf(bio_err, "-hexdump        hex dump output\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	BIO_printf(bio_err, "-engine e       use engine e, possibly a hardware device.\n");
 | 
						BIO_printf(bio_err, "-engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
	BIO_printf (bio_err, "-passin arg    pass phrase source\n");
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -112,14 +112,6 @@
 | 
				
			|||||||
#include <sys/types.h>
 | 
					#include <sys/types.h>
 | 
				
			||||||
#include <openssl/opensslconf.h>
 | 
					#include <openssl/opensslconf.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					 | 
				
			||||||
#include <conio.h>
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef OPENSSL_SYS_MSDOS
 | 
					 | 
				
			||||||
#define _kbhit kbhit
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#if defined(OPENSSL_SYS_VMS) && !defined(FD_SET)
 | 
					#if defined(OPENSSL_SYS_VMS) && !defined(FD_SET)
 | 
				
			||||||
/* VAX C does not defined fd_set and friends, but it's actually quite simple */
 | 
					/* VAX C does not defined fd_set and friends, but it's actually quite simple */
 | 
				
			||||||
/* These definitions are borrowed from SOCKETSHR.	/Richard Levitte */
 | 
					/* These definitions are borrowed from SOCKETSHR.	/Richard Levitte */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -134,7 +134,7 @@ int MS_CALLBACK verify_callback(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
	err=	X509_STORE_CTX_get_error(ctx);
 | 
						err=	X509_STORE_CTX_get_error(ctx);
 | 
				
			||||||
	depth=	X509_STORE_CTX_get_error_depth(ctx);
 | 
						depth=	X509_STORE_CTX_get_error_depth(ctx);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	X509_NAME_oneline(X509_get_subject_name(err_cert),buf,sizeof buf);
 | 
						X509_NAME_oneline(X509_get_subject_name(err_cert),buf,256);
 | 
				
			||||||
	BIO_printf(bio_err,"depth=%d %s\n",depth,buf);
 | 
						BIO_printf(bio_err,"depth=%d %s\n",depth,buf);
 | 
				
			||||||
	if (!ok)
 | 
						if (!ok)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -154,7 +154,7 @@ int MS_CALLBACK verify_callback(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
	switch (ctx->error)
 | 
						switch (ctx->error)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
	case X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT:
 | 
						case X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT:
 | 
				
			||||||
		X509_NAME_oneline(X509_get_issuer_name(ctx->current_cert),buf,sizeof buf);
 | 
							X509_NAME_oneline(X509_get_issuer_name(ctx->current_cert),buf,256);
 | 
				
			||||||
		BIO_printf(bio_err,"issuer= %s\n",buf);
 | 
							BIO_printf(bio_err,"issuer= %s\n",buf);
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case X509_V_ERR_CERT_NOT_YET_VALID:
 | 
						case X509_V_ERR_CERT_NOT_YET_VALID:
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -136,12 +136,8 @@ typedef unsigned int u_int;
 | 
				
			|||||||
#include <openssl/rand.h>
 | 
					#include <openssl/rand.h>
 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_SYS_WINCE
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
/* Windows CE incorrectly defines fileno as returning void*, so to avoid problems below... */
 | 
					#include <conio.h>
 | 
				
			||||||
#ifdef fileno
 | 
					 | 
				
			||||||
#undef fileno
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#define fileno(a) (int)_fileno(a)
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -187,7 +183,7 @@ static void sc_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err," -port port     - use -connect instead\n");
 | 
						BIO_printf(bio_err," -port port     - use -connect instead\n");
 | 
				
			||||||
	BIO_printf(bio_err," -connect host:port - who to connect to (default is %s:%s)\n",SSL_HOST_NAME,PORT_STR);
 | 
						BIO_printf(bio_err," -connect host:port - who to connect to (default is %s:%s)\n",SSL_HOST_NAME,PORT_STR);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	BIO_printf(bio_err," -verify depth - turn on peer certificate verification\n");
 | 
						BIO_printf(bio_err," -verify arg   - turn on peer certificate verification\n");
 | 
				
			||||||
	BIO_printf(bio_err," -cert arg     - certificate file to use, PEM format assumed\n");
 | 
						BIO_printf(bio_err," -cert arg     - certificate file to use, PEM format assumed\n");
 | 
				
			||||||
	BIO_printf(bio_err," -key arg      - Private key file to use, PEM format assumed, in cert file if\n");
 | 
						BIO_printf(bio_err," -key arg      - Private key file to use, PEM format assumed, in cert file if\n");
 | 
				
			||||||
	BIO_printf(bio_err,"                 not specified but cert file is.\n");
 | 
						BIO_printf(bio_err,"                 not specified but cert file is.\n");
 | 
				
			||||||
@@ -197,9 +193,6 @@ static void sc_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err," -pause        - sleep(1) after each read(2) and write(2) system call\n");
 | 
						BIO_printf(bio_err," -pause        - sleep(1) after each read(2) and write(2) system call\n");
 | 
				
			||||||
	BIO_printf(bio_err," -showcerts    - show all certificates in the chain\n");
 | 
						BIO_printf(bio_err," -showcerts    - show all certificates in the chain\n");
 | 
				
			||||||
	BIO_printf(bio_err," -debug        - extra output\n");
 | 
						BIO_printf(bio_err," -debug        - extra output\n");
 | 
				
			||||||
#ifdef WATT32
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -wdebug       - WATT-32 tcp debugging\n");
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -msg          - Show protocol messages\n");
 | 
						BIO_printf(bio_err," -msg          - Show protocol messages\n");
 | 
				
			||||||
	BIO_printf(bio_err," -nbio_test    - more ssl protocol testing\n");
 | 
						BIO_printf(bio_err," -nbio_test    - more ssl protocol testing\n");
 | 
				
			||||||
	BIO_printf(bio_err," -state        - print the 'ssl' states\n");
 | 
						BIO_printf(bio_err," -state        - print the 'ssl' states\n");
 | 
				
			||||||
@@ -220,10 +213,8 @@ static void sc_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err," -starttls prot - use the STARTTLS command before starting TLS\n");
 | 
						BIO_printf(bio_err," -starttls prot - use the STARTTLS command before starting TLS\n");
 | 
				
			||||||
	BIO_printf(bio_err,"                 for those protocols that support it, where\n");
 | 
						BIO_printf(bio_err,"                 for those protocols that support it, where\n");
 | 
				
			||||||
	BIO_printf(bio_err,"                 'prot' defines which one to assume.  Currently,\n");
 | 
						BIO_printf(bio_err,"                 'prot' defines which one to assume.  Currently,\n");
 | 
				
			||||||
	BIO_printf(bio_err,"                 only \"smtp\" and \"pop3\" are supported.\n");
 | 
						BIO_printf(bio_err,"                 only \"smtp\" is supported.\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -engine id    - Initialise and use the specified engine\n");
 | 
						BIO_printf(bio_err," -engine id    - Initialise and use the specified engine\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
						BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -250,16 +241,14 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int write_tty,read_tty,write_ssl,read_ssl,tty_on,ssl_pending;
 | 
						int write_tty,read_tty,write_ssl,read_ssl,tty_on,ssl_pending;
 | 
				
			||||||
	SSL_CTX *ctx=NULL;
 | 
						SSL_CTX *ctx=NULL;
 | 
				
			||||||
	int ret=1,in_init=1,i,nbio_test=0;
 | 
						int ret=1,in_init=1,i,nbio_test=0;
 | 
				
			||||||
	int starttls_proto = 0;
 | 
						int smtp_starttls = 0;
 | 
				
			||||||
	int prexit = 0, vflags = 0;
 | 
						int prexit = 0, vflags = 0;
 | 
				
			||||||
	SSL_METHOD *meth=NULL;
 | 
						SSL_METHOD *meth=NULL;
 | 
				
			||||||
	BIO *sbio;
 | 
						BIO *sbio;
 | 
				
			||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine_id=NULL;
 | 
						char *engine_id=NULL;
 | 
				
			||||||
	ENGINE *e=NULL;
 | 
						ENGINE *e=NULL;
 | 
				
			||||||
#endif
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					 | 
				
			||||||
	struct timeval tv;
 | 
						struct timeval tv;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -351,10 +340,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			c_Pause=1;
 | 
								c_Pause=1;
 | 
				
			||||||
		else if	(strcmp(*argv,"-debug") == 0)
 | 
							else if	(strcmp(*argv,"-debug") == 0)
 | 
				
			||||||
			c_debug=1;
 | 
								c_debug=1;
 | 
				
			||||||
#ifdef WATT32
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-wdebug") == 0)
 | 
					 | 
				
			||||||
			dbug_init();
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-msg") == 0)
 | 
							else if	(strcmp(*argv,"-msg") == 0)
 | 
				
			||||||
			c_msg=1;
 | 
								c_msg=1;
 | 
				
			||||||
		else if	(strcmp(*argv,"-showcerts") == 0)
 | 
							else if	(strcmp(*argv,"-showcerts") == 0)
 | 
				
			||||||
@@ -418,19 +403,15 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			++argv;
 | 
								++argv;
 | 
				
			||||||
			if (strcmp(*argv,"smtp") == 0)
 | 
								if (strcmp(*argv,"smtp") == 0)
 | 
				
			||||||
				starttls_proto = 1;
 | 
									smtp_starttls = 1;
 | 
				
			||||||
			else if (strcmp(*argv,"pop3") == 0)
 | 
					 | 
				
			||||||
				starttls_proto = 2;
 | 
					 | 
				
			||||||
			else
 | 
								else
 | 
				
			||||||
				goto bad;
 | 
									goto bad;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if	(strcmp(*argv,"-engine") == 0)
 | 
							else if	(strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine_id = *(++argv);
 | 
								engine_id = *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-rand") == 0)
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -452,13 +433,6 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	OpenSSL_add_ssl_algorithms();
 | 
					 | 
				
			||||||
	SSL_load_error_strings();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine_id, 1);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (!app_RAND_load_file(NULL, bio_err, 1) && inrand == NULL
 | 
						if (!app_RAND_load_file(NULL, bio_err, 1) && inrand == NULL
 | 
				
			||||||
		&& !RAND_status())
 | 
							&& !RAND_status())
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -481,6 +455,11 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						OpenSSL_add_ssl_algorithms();
 | 
				
			||||||
 | 
						SSL_load_error_strings();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        e = setup_engine(bio_err, engine_id, 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx=SSL_CTX_new(meth);
 | 
						ctx=SSL_CTX_new(meth);
 | 
				
			||||||
	if (ctx == NULL)
 | 
						if (ctx == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -592,20 +571,12 @@ re_start:
 | 
				
			|||||||
	sbuf_off=0;
 | 
						sbuf_off=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* This is an ugly hack that does a lot of assumptions */
 | 
						/* This is an ugly hack that does a lot of assumptions */
 | 
				
			||||||
	if (starttls_proto == 1)
 | 
						if (smtp_starttls)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_read(sbio,mbuf,BUFSIZZ);
 | 
							BIO_read(sbio,mbuf,BUFSIZZ);
 | 
				
			||||||
		BIO_printf(sbio,"EHLO some.host.name\r\n");
 | 
					 | 
				
			||||||
		BIO_read(sbio,mbuf,BUFSIZZ);
 | 
					 | 
				
			||||||
		BIO_printf(sbio,"STARTTLS\r\n");
 | 
							BIO_printf(sbio,"STARTTLS\r\n");
 | 
				
			||||||
		BIO_read(sbio,sbuf,BUFSIZZ);
 | 
							BIO_read(sbio,sbuf,BUFSIZZ);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (starttls_proto == 2)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_read(sbio,mbuf,BUFSIZZ);
 | 
					 | 
				
			||||||
		BIO_printf(sbio,"STLS\r\n");
 | 
					 | 
				
			||||||
		BIO_read(sbio,sbuf,BUFSIZZ);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (;;)
 | 
						for (;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -626,11 +597,11 @@ re_start:
 | 
				
			|||||||
				print_stuff(bio_c_out,con,full_log);
 | 
									print_stuff(bio_c_out,con,full_log);
 | 
				
			||||||
				if (full_log > 0) full_log--;
 | 
									if (full_log > 0) full_log--;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (starttls_proto)
 | 
									if (smtp_starttls)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					BIO_printf(bio_err,"%s",mbuf);
 | 
										BIO_printf(bio_err,"%s",mbuf);
 | 
				
			||||||
					/* We don't need to know any more */
 | 
										/* We don't need to know any more */
 | 
				
			||||||
					starttls_proto = 0;
 | 
										smtp_starttls = 0;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (reconnect)
 | 
									if (reconnect)
 | 
				
			||||||
@@ -649,7 +620,7 @@ re_start:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (!ssl_pending)
 | 
							if (!ssl_pending)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
#if !defined(OPENSSL_SYS_WINDOWS) && !defined(OPENSSL_SYS_MSDOS)
 | 
					#ifndef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
			if (tty_on)
 | 
								if (tty_on)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if (read_tty)  FD_SET(fileno(stdin),&readfds);
 | 
									if (read_tty)  FD_SET(fileno(stdin),&readfds);
 | 
				
			||||||
@@ -676,8 +647,8 @@ re_start:
 | 
				
			|||||||
			 * will choke the compiler: if you do have a cast then
 | 
								 * will choke the compiler: if you do have a cast then
 | 
				
			||||||
			 * you can either go for (int *) or (void *).
 | 
								 * you can either go for (int *) or (void *).
 | 
				
			||||||
			 */
 | 
								 */
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
                        /* Under Windows/DOS we make the assumption that we can
 | 
								/* Under Windows we make the assumption that we can
 | 
				
			||||||
			 * always write to the tty: therefore if we need to
 | 
								 * always write to the tty: therefore if we need to
 | 
				
			||||||
			 * write to the tty we just fall through. Otherwise
 | 
								 * write to the tty we just fall through. Otherwise
 | 
				
			||||||
			 * we timeout the select every second and see if there
 | 
								 * we timeout the select every second and see if there
 | 
				
			||||||
@@ -691,11 +662,7 @@ re_start:
 | 
				
			|||||||
					tv.tv_usec = 0;
 | 
										tv.tv_usec = 0;
 | 
				
			||||||
					i=select(width,(void *)&readfds,(void *)&writefds,
 | 
										i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
						 NULL,&tv);
 | 
											 NULL,&tv);
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINCE) || defined(OPENSSL_SYS_MSDOS)
 | 
					 | 
				
			||||||
					if(!i && (!_kbhit() || !read_tty) ) continue;
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
					if(!i && (!((_kbhit()) || (WAIT_OBJECT_0 == WaitForSingleObject(GetStdHandle(STD_INPUT_HANDLE), 0))) || !read_tty) ) continue;
 | 
										if(!i && (!((_kbhit()) || (WAIT_OBJECT_0 == WaitForSingleObject(GetStdHandle(STD_INPUT_HANDLE), 0))) || !read_tty) ) continue;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
				} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
									} else 	i=select(width,(void *)&readfds,(void *)&writefds,
 | 
				
			||||||
					 NULL,NULL);
 | 
										 NULL,NULL);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
@@ -779,8 +746,8 @@ re_start:
 | 
				
			|||||||
				goto shut;
 | 
									goto shut;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
		/* Assume Windows/DOS can always write */
 | 
							/* Assume Windows can always write */
 | 
				
			||||||
		else if (!ssl_pending && write_tty)
 | 
							else if (!ssl_pending && write_tty)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
		else if (!ssl_pending && FD_ISSET(fileno(stdout),&writefds))
 | 
							else if (!ssl_pending && FD_ISSET(fileno(stdout),&writefds))
 | 
				
			||||||
@@ -860,12 +827,8 @@ printf("read=%d pending=%d peek=%d\n",k,SSL_pending(con),SSL_peek(con,zbuf,10240
 | 
				
			|||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINCE) || defined(OPENSSL_SYS_MSDOS)
 | 
					 | 
				
			||||||
		else if (_kbhit())
 | 
					 | 
				
			||||||
#else
 | 
					 | 
				
			||||||
		else if ((_kbhit()) || (WAIT_OBJECT_0 == WaitForSingleObject(GetStdHandle(STD_INPUT_HANDLE), 0)))
 | 
							else if ((_kbhit()) || (WAIT_OBJECT_0 == WaitForSingleObject(GetStdHandle(STD_INPUT_HANDLE), 0)))
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
		else if (FD_ISSET(fileno(stdin),&readfds))
 | 
							else if (FD_ISSET(fileno(stdin),&readfds))
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -929,16 +892,16 @@ end:
 | 
				
			|||||||
	if (con != NULL) SSL_free(con);
 | 
						if (con != NULL) SSL_free(con);
 | 
				
			||||||
	if (con2 != NULL) SSL_free(con2);
 | 
						if (con2 != NULL) SSL_free(con2);
 | 
				
			||||||
	if (ctx != NULL) SSL_CTX_free(ctx);
 | 
						if (ctx != NULL) SSL_CTX_free(ctx);
 | 
				
			||||||
	if (cbuf != NULL) { OPENSSL_cleanse(cbuf,BUFSIZZ); OPENSSL_free(cbuf); }
 | 
						if (cbuf != NULL) { memset(cbuf,0,BUFSIZZ); OPENSSL_free(cbuf); }
 | 
				
			||||||
	if (sbuf != NULL) { OPENSSL_cleanse(sbuf,BUFSIZZ); OPENSSL_free(sbuf); }
 | 
						if (sbuf != NULL) { memset(sbuf,0,BUFSIZZ); OPENSSL_free(sbuf); }
 | 
				
			||||||
	if (mbuf != NULL) { OPENSSL_cleanse(mbuf,BUFSIZZ); OPENSSL_free(mbuf); }
 | 
						if (mbuf != NULL) { memset(mbuf,0,BUFSIZZ); OPENSSL_free(mbuf); }
 | 
				
			||||||
	if (bio_c_out != NULL)
 | 
						if (bio_c_out != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_free(bio_c_out);
 | 
							BIO_free(bio_c_out);
 | 
				
			||||||
		bio_c_out=NULL;
 | 
							bio_c_out=NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -967,10 +930,10 @@ static void print_stuff(BIO *bio, SSL *s, int full)
 | 
				
			|||||||
			for (i=0; i<sk_X509_num(sk); i++)
 | 
								for (i=0; i<sk_X509_num(sk); i++)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				X509_NAME_oneline(X509_get_subject_name(
 | 
									X509_NAME_oneline(X509_get_subject_name(
 | 
				
			||||||
					sk_X509_value(sk,i)),buf,sizeof buf);
 | 
										sk_X509_value(sk,i)),buf,BUFSIZ);
 | 
				
			||||||
				BIO_printf(bio,"%2d s:%s\n",i,buf);
 | 
									BIO_printf(bio,"%2d s:%s\n",i,buf);
 | 
				
			||||||
				X509_NAME_oneline(X509_get_issuer_name(
 | 
									X509_NAME_oneline(X509_get_issuer_name(
 | 
				
			||||||
					sk_X509_value(sk,i)),buf,sizeof buf);
 | 
										sk_X509_value(sk,i)),buf,BUFSIZ);
 | 
				
			||||||
				BIO_printf(bio,"   i:%s\n",buf);
 | 
									BIO_printf(bio,"   i:%s\n",buf);
 | 
				
			||||||
				if (c_showcerts)
 | 
									if (c_showcerts)
 | 
				
			||||||
					PEM_write_bio_X509(bio,sk_X509_value(sk,i));
 | 
										PEM_write_bio_X509(bio,sk_X509_value(sk,i));
 | 
				
			||||||
@@ -985,10 +948,10 @@ static void print_stuff(BIO *bio, SSL *s, int full)
 | 
				
			|||||||
			if (!(c_showcerts && got_a_chain)) /* Redundant if we showed the whole chain */
 | 
								if (!(c_showcerts && got_a_chain)) /* Redundant if we showed the whole chain */
 | 
				
			||||||
				PEM_write_bio_X509(bio,peer);
 | 
									PEM_write_bio_X509(bio,peer);
 | 
				
			||||||
			X509_NAME_oneline(X509_get_subject_name(peer),
 | 
								X509_NAME_oneline(X509_get_subject_name(peer),
 | 
				
			||||||
				buf,sizeof buf);
 | 
									buf,BUFSIZ);
 | 
				
			||||||
			BIO_printf(bio,"subject=%s\n",buf);
 | 
								BIO_printf(bio,"subject=%s\n",buf);
 | 
				
			||||||
			X509_NAME_oneline(X509_get_issuer_name(peer),
 | 
								X509_NAME_oneline(X509_get_issuer_name(peer),
 | 
				
			||||||
				buf,sizeof buf);
 | 
									buf,BUFSIZ);
 | 
				
			||||||
			BIO_printf(bio,"issuer=%s\n",buf);
 | 
								BIO_printf(bio,"issuer=%s\n",buf);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
@@ -1010,7 +973,7 @@ static void print_stuff(BIO *bio, SSL *s, int full)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio,"---\nNo client certificate CA names sent\n");
 | 
								BIO_printf(bio,"---\nNo client certificate CA names sent\n");
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		p=SSL_get_shared_ciphers(s,buf,sizeof buf);
 | 
							p=SSL_get_shared_ciphers(s,buf,BUFSIZ);
 | 
				
			||||||
		if (p != NULL)
 | 
							if (p != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			/* This works only for SSL 2.  In later protocol
 | 
								/* This works only for SSL 2.  In later protocol
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -140,12 +140,8 @@ typedef unsigned int u_int;
 | 
				
			|||||||
#include <openssl/rand.h>
 | 
					#include <openssl/rand.h>
 | 
				
			||||||
#include "s_apps.h"
 | 
					#include "s_apps.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_SYS_WINCE
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
/* Windows CE incorrectly defines fileno as returning void*, so to avoid problems below... */
 | 
					#include <conio.h>
 | 
				
			||||||
#ifdef fileno
 | 
					 | 
				
			||||||
#undef fileno
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#define fileno(a) (int)_fileno(a)
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if (defined(OPENSSL_SYS_VMS) && __VMS_VER < 70000000)
 | 
					#if (defined(OPENSSL_SYS_VMS) && __VMS_VER < 70000000)
 | 
				
			||||||
@@ -238,9 +234,7 @@ static int s_msg=0;
 | 
				
			|||||||
static int s_quiet=0;
 | 
					static int s_quiet=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int hack=0;
 | 
					static int hack=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
static char *engine_id=NULL;
 | 
					static char *engine_id=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
static const char *session_id_prefix=NULL;
 | 
					static const char *session_id_prefix=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef MONOLITH
 | 
					#ifdef MONOLITH
 | 
				
			||||||
@@ -265,9 +259,7 @@ static void s_server_init(void)
 | 
				
			|||||||
	s_msg=0;
 | 
						s_msg=0;
 | 
				
			||||||
	s_quiet=0;
 | 
						s_quiet=0;
 | 
				
			||||||
	hack=0;
 | 
						hack=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	engine_id=NULL;
 | 
						engine_id=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -316,9 +308,7 @@ static void sv_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err," -WWW          - Respond to a 'GET /<path> HTTP/1.0' with file ./<path>\n");
 | 
						BIO_printf(bio_err," -WWW          - Respond to a 'GET /<path> HTTP/1.0' with file ./<path>\n");
 | 
				
			||||||
	BIO_printf(bio_err," -HTTP         - Respond to a 'GET /<path> HTTP/1.0' with file ./<path>\n");
 | 
						BIO_printf(bio_err," -HTTP         - Respond to a 'GET /<path> HTTP/1.0' with file ./<path>\n");
 | 
				
			||||||
        BIO_printf(bio_err,"                 with the assumption it contains a complete HTTP response.\n");
 | 
					        BIO_printf(bio_err,"                 with the assumption it contains a complete HTTP response.\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -engine id    - Initialise and use the specified engine\n");
 | 
						BIO_printf(bio_err," -engine id    - Initialise and use the specified engine\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	BIO_printf(bio_err," -id_prefix arg - Generate SSL/TLS session IDs prefixed by 'arg'\n");
 | 
						BIO_printf(bio_err," -id_prefix arg - Generate SSL/TLS session IDs prefixed by 'arg'\n");
 | 
				
			||||||
	BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
						BIO_printf(bio_err," -rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -330,10 +320,10 @@ static char **local_argv;
 | 
				
			|||||||
static int ebcdic_new(BIO *bi);
 | 
					static int ebcdic_new(BIO *bi);
 | 
				
			||||||
static int ebcdic_free(BIO *a);
 | 
					static int ebcdic_free(BIO *a);
 | 
				
			||||||
static int ebcdic_read(BIO *b, char *out, int outl);
 | 
					static int ebcdic_read(BIO *b, char *out, int outl);
 | 
				
			||||||
static int ebcdic_write(BIO *b, const char *in, int inl);
 | 
					static int ebcdic_write(BIO *b, char *in, int inl);
 | 
				
			||||||
static long ebcdic_ctrl(BIO *b, int cmd, long num, void *ptr);
 | 
					static long ebcdic_ctrl(BIO *b, int cmd, long num, char *ptr);
 | 
				
			||||||
static int ebcdic_gets(BIO *bp, char *buf, int size);
 | 
					static int ebcdic_gets(BIO *bp, char *buf, int size);
 | 
				
			||||||
static int ebcdic_puts(BIO *bp, const char *str);
 | 
					static int ebcdic_puts(BIO *bp, char *str);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define BIO_TYPE_EBCDIC_FILTER	(18|0x0200)
 | 
					#define BIO_TYPE_EBCDIC_FILTER	(18|0x0200)
 | 
				
			||||||
static BIO_METHOD methods_ebcdic=
 | 
					static BIO_METHOD methods_ebcdic=
 | 
				
			||||||
@@ -398,7 +388,7 @@ static int ebcdic_read(BIO *b, char *out, int outl)
 | 
				
			|||||||
	return(ret);
 | 
						return(ret);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int ebcdic_write(BIO *b, const char *in, int inl)
 | 
					static int ebcdic_write(BIO *b, char *in, int inl)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	EBCDIC_OUTBUFF *wbuf;
 | 
						EBCDIC_OUTBUFF *wbuf;
 | 
				
			||||||
	int ret=0;
 | 
						int ret=0;
 | 
				
			||||||
@@ -431,7 +421,7 @@ static int ebcdic_write(BIO *b, const char *in, int inl)
 | 
				
			|||||||
	return(ret);
 | 
						return(ret);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static long ebcdic_ctrl(BIO *b, int cmd, long num, void *ptr)
 | 
					static long ebcdic_ctrl(BIO *b, int cmd, long num, char *ptr)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	long ret;
 | 
						long ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -450,7 +440,7 @@ static long ebcdic_ctrl(BIO *b, int cmd, long num, void *ptr)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static int ebcdic_gets(BIO *bp, char *buf, int size)
 | 
					static int ebcdic_gets(BIO *bp, char *buf, int size)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int i, ret=0;
 | 
						int i, ret;
 | 
				
			||||||
	if (bp->next_bio == NULL) return(0);
 | 
						if (bp->next_bio == NULL) return(0);
 | 
				
			||||||
/*	return(BIO_gets(bp->next_bio,buf,size));*/
 | 
					/*	return(BIO_gets(bp->next_bio,buf,size));*/
 | 
				
			||||||
	for (i=0; i<size-1; ++i)
 | 
						for (i=0; i<size-1; ++i)
 | 
				
			||||||
@@ -469,7 +459,7 @@ static int ebcdic_gets(BIO *bp, char *buf, int size)
 | 
				
			|||||||
	return (ret < 0 && i == 0) ? ret : i;
 | 
						return (ret < 0 && i == 0) ? ret : i;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int ebcdic_puts(BIO *bp, const char *str)
 | 
					static int ebcdic_puts(BIO *bp, char *str)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (bp->next_bio == NULL) return(0);
 | 
						if (bp->next_bio == NULL) return(0);
 | 
				
			||||||
	return ebcdic_write(bp, str, strlen(str));
 | 
						return ebcdic_write(bp, str, strlen(str));
 | 
				
			||||||
@@ -492,9 +482,7 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
	int no_tmp_rsa=0,no_dhe=0,nocert=0;
 | 
						int no_tmp_rsa=0,no_dhe=0,nocert=0;
 | 
				
			||||||
	int state=0;
 | 
						int state=0;
 | 
				
			||||||
	SSL_METHOD *meth=NULL;
 | 
						SSL_METHOD *meth=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e=NULL;
 | 
						ENGINE *e=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	char *inrand=NULL;
 | 
						char *inrand=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
					#if !defined(OPENSSL_NO_SSL2) && !defined(OPENSSL_NO_SSL3)
 | 
				
			||||||
@@ -669,13 +657,11 @@ int MAIN(int argc, char *argv[])
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			session_id_prefix = *(++argv);
 | 
								session_id_prefix = *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine_id= *(++argv);
 | 
								engine_id= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-rand") == 0)
 | 
							else if (strcmp(*argv,"-rand") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
@@ -697,13 +683,6 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	SSL_load_error_strings();
 | 
					 | 
				
			||||||
	OpenSSL_add_ssl_algorithms();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine_id, 1);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (!app_RAND_load_file(NULL, bio_err, 1) && inrand == NULL
 | 
						if (!app_RAND_load_file(NULL, bio_err, 1) && inrand == NULL
 | 
				
			||||||
		&& !RAND_status())
 | 
							&& !RAND_status())
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -726,7 +705,7 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if !defined(OPENSSL_NO_RSA) || !defined(OPENSSL_NO_DSA)
 | 
					#if !defined(OPENSSL_NO_RSA) || !defined(OPENSSL_NO_DSA) || !defined(OPENSSL_NO_ECDSA)
 | 
				
			||||||
	if (nocert)
 | 
						if (nocert)
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -736,6 +715,11 @@ bad:
 | 
				
			|||||||
		s_dkey_file=NULL;
 | 
							s_dkey_file=NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						SSL_load_error_strings();
 | 
				
			||||||
 | 
						OpenSSL_add_ssl_algorithms();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        e = setup_engine(bio_err, engine_id, 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx=SSL_CTX_new(meth);
 | 
						ctx=SSL_CTX_new(meth);
 | 
				
			||||||
	if (ctx == NULL)
 | 
						if (ctx == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -876,7 +860,7 @@ end:
 | 
				
			|||||||
		bio_s_out=NULL;
 | 
							bio_s_out=NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void print_stats(BIO *bio, SSL_CTX *ssl_ctx)
 | 
					static void print_stats(BIO *bio, SSL_CTX *ssl_ctx)
 | 
				
			||||||
@@ -913,7 +897,7 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
	unsigned long l;
 | 
						unsigned long l;
 | 
				
			||||||
	SSL *con=NULL;
 | 
						SSL *con=NULL;
 | 
				
			||||||
	BIO *sbio;
 | 
						BIO *sbio;
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
	struct timeval tv;
 | 
						struct timeval tv;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -987,7 +971,7 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
		if (!read_from_sslcon)
 | 
							if (!read_from_sslcon)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			FD_ZERO(&readfds);
 | 
								FD_ZERO(&readfds);
 | 
				
			||||||
#if !defined(OPENSSL_SYS_WINDOWS) && !defined(OPENSSL_SYS_MSDOS)
 | 
					#ifndef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
			FD_SET(fileno(stdin),&readfds);
 | 
								FD_SET(fileno(stdin),&readfds);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
			FD_SET(s,&readfds);
 | 
								FD_SET(s,&readfds);
 | 
				
			||||||
@@ -997,8 +981,8 @@ static int sv_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
			 * the compiler: if you do have a cast then you can either
 | 
								 * the compiler: if you do have a cast then you can either
 | 
				
			||||||
			 * go for (int *) or (void *).
 | 
								 * go for (int *) or (void *).
 | 
				
			||||||
			 */
 | 
								 */
 | 
				
			||||||
#if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS)
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
                        /* Under DOS (non-djgpp) and Windows we can't select on stdin: only
 | 
								/* Under Windows we can't select on stdin: only
 | 
				
			||||||
			 * on sockets. As a workaround we timeout the select every
 | 
								 * on sockets. As a workaround we timeout the select every
 | 
				
			||||||
			 * second and check for any keypress. In a proper Windows
 | 
								 * second and check for any keypress. In a proper Windows
 | 
				
			||||||
			 * application we wouldn't do this because it is inefficient.
 | 
								 * application we wouldn't do this because it is inefficient.
 | 
				
			||||||
@@ -1192,7 +1176,7 @@ err:
 | 
				
			|||||||
	BIO_printf(bio_s_out,"CONNECTION CLOSED\n");
 | 
						BIO_printf(bio_s_out,"CONNECTION CLOSED\n");
 | 
				
			||||||
	if (buf != NULL)
 | 
						if (buf != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		OPENSSL_cleanse(buf,bufsize);
 | 
							memset(buf,0,bufsize);
 | 
				
			||||||
		OPENSSL_free(buf);
 | 
							OPENSSL_free(buf);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (ret >= 0)
 | 
						if (ret >= 0)
 | 
				
			||||||
@@ -1244,14 +1228,14 @@ static int init_ssl_connection(SSL *con)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_printf(bio_s_out,"Client certificate\n");
 | 
							BIO_printf(bio_s_out,"Client certificate\n");
 | 
				
			||||||
		PEM_write_bio_X509(bio_s_out,peer);
 | 
							PEM_write_bio_X509(bio_s_out,peer);
 | 
				
			||||||
		X509_NAME_oneline(X509_get_subject_name(peer),buf,sizeof buf);
 | 
							X509_NAME_oneline(X509_get_subject_name(peer),buf,BUFSIZ);
 | 
				
			||||||
		BIO_printf(bio_s_out,"subject=%s\n",buf);
 | 
							BIO_printf(bio_s_out,"subject=%s\n",buf);
 | 
				
			||||||
		X509_NAME_oneline(X509_get_issuer_name(peer),buf,sizeof buf);
 | 
							X509_NAME_oneline(X509_get_issuer_name(peer),buf,BUFSIZ);
 | 
				
			||||||
		BIO_printf(bio_s_out,"issuer=%s\n",buf);
 | 
							BIO_printf(bio_s_out,"issuer=%s\n",buf);
 | 
				
			||||||
		X509_free(peer);
 | 
							X509_free(peer);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (SSL_get_shared_ciphers(con,buf,sizeof buf) != NULL)
 | 
						if (SSL_get_shared_ciphers(con,buf,BUFSIZ) != NULL)
 | 
				
			||||||
		BIO_printf(bio_s_out,"Shared ciphers:%s\n",buf);
 | 
							BIO_printf(bio_s_out,"Shared ciphers:%s\n",buf);
 | 
				
			||||||
	str=SSL_CIPHER_get_name(SSL_get_current_cipher(con));
 | 
						str=SSL_CIPHER_get_name(SSL_get_current_cipher(con));
 | 
				
			||||||
	BIO_printf(bio_s_out,"CIPHER is %s\n",(str != NULL)?str:"(NONE)");
 | 
						BIO_printf(bio_s_out,"CIPHER is %s\n",(str != NULL)?str:"(NONE)");
 | 
				
			||||||
@@ -1259,13 +1243,7 @@ static int init_ssl_connection(SSL *con)
 | 
				
			|||||||
	if (SSL_ctrl(con,SSL_CTRL_GET_FLAGS,0,NULL) &
 | 
						if (SSL_ctrl(con,SSL_CTRL_GET_FLAGS,0,NULL) &
 | 
				
			||||||
		TLS1_FLAGS_TLS_PADDING_BUG)
 | 
							TLS1_FLAGS_TLS_PADDING_BUG)
 | 
				
			||||||
		BIO_printf(bio_s_out,"Peer has incorrect TLSv1 block padding\n");
 | 
							BIO_printf(bio_s_out,"Peer has incorrect TLSv1 block padding\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_KRB5
 | 
					
 | 
				
			||||||
	if (con->kssl_ctx->client_princ != NULL)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		BIO_printf(bio_s_out,"Kerberos peer principal is %s\n",
 | 
					 | 
				
			||||||
			con->kssl_ctx->client_princ);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif /* OPENSSL_NO_KRB5 */
 | 
					 | 
				
			||||||
	return(1);
 | 
						return(1);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1417,7 +1395,7 @@ static int www_body(char *hostname, int s, unsigned char *context)
 | 
				
			|||||||
			else
 | 
								else
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				BIO_printf(bio_s_out,"read R BLOCK\n");
 | 
									BIO_printf(bio_s_out,"read R BLOCK\n");
 | 
				
			||||||
#if !defined(OPENSSL_SYS_MSDOS) && !defined(__DJGPP__)
 | 
					#ifndef OPENSSL_SYS_MSDOS
 | 
				
			||||||
				sleep(1);
 | 
									sleep(1);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -83,9 +83,9 @@ typedef unsigned int u_int;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static struct hostent *GetHostByName(char *name);
 | 
					static struct hostent *GetHostByName(char *name);
 | 
				
			||||||
#ifdef OPENSSL_SYS_WINDOWS
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
static void ssl_sock_cleanup(void);
 | 
					static void sock_cleanup(void);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
static int ssl_sock_init(void);
 | 
					static int sock_init(void);
 | 
				
			||||||
static int init_client_ip(int *sock,unsigned char ip[4], int port);
 | 
					static int init_client_ip(int *sock,unsigned char ip[4], int port);
 | 
				
			||||||
static int init_server(int *sock, int port);
 | 
					static int init_server(int *sock, int port);
 | 
				
			||||||
static int init_server_long(int *sock, int port,char *ip);
 | 
					static int init_server_long(int *sock, int port,char *ip);
 | 
				
			||||||
@@ -118,7 +118,7 @@ static LONG FAR PASCAL topHookProc(HWND hwnd, UINT message, WPARAM wParam,
 | 
				
			|||||||
		case WM_DESTROY:
 | 
							case WM_DESTROY:
 | 
				
			||||||
		case WM_CLOSE:
 | 
							case WM_CLOSE:
 | 
				
			||||||
			SetWindowLong(topWnd,GWL_WNDPROC,(LONG)lpTopWndProc);
 | 
								SetWindowLong(topWnd,GWL_WNDPROC,(LONG)lpTopWndProc);
 | 
				
			||||||
			ssl_sock_cleanup();
 | 
								sock_cleanup();
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -135,33 +135,26 @@ static BOOL CALLBACK enumproc(HWND hwnd,LPARAM lParam)
 | 
				
			|||||||
#endif /* OPENSSL_SYS_WINDOWS */
 | 
					#endif /* OPENSSL_SYS_WINDOWS */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_SYS_WINDOWS
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
static void ssl_sock_cleanup(void)
 | 
					static void sock_cleanup(void)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	if (wsa_init_done)
 | 
						if (wsa_init_done)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		wsa_init_done=0;
 | 
							wsa_init_done=0;
 | 
				
			||||||
#ifndef OPENSSL_SYS_WINCE
 | 
					 | 
				
			||||||
		WSACancelBlockingCall();
 | 
							WSACancelBlockingCall();
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		WSACleanup();
 | 
							WSACleanup();
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int ssl_sock_init(void)
 | 
					static int sock_init(void)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifdef WATT32
 | 
					#ifdef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
	extern int _watt_do_exit;
 | 
					 | 
				
			||||||
	_watt_do_exit = 0;
 | 
					 | 
				
			||||||
	if (sock_init())
 | 
					 | 
				
			||||||
		return (0);
 | 
					 | 
				
			||||||
#elif defined(OPENSSL_SYS_WINDOWS)
 | 
					 | 
				
			||||||
	if (!wsa_init_done)
 | 
						if (!wsa_init_done)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		int err;
 | 
							int err;
 | 
				
			||||||
	  
 | 
						  
 | 
				
			||||||
#ifdef SIGINT
 | 
					#ifdef SIGINT
 | 
				
			||||||
		signal(SIGINT,(void (*)(int))ssl_sock_cleanup);
 | 
							signal(SIGINT,(void (*)(int))sock_cleanup);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
		wsa_init_done=1;
 | 
							wsa_init_done=1;
 | 
				
			||||||
		memset(&wsa_state,0,sizeof(wsa_state));
 | 
							memset(&wsa_state,0,sizeof(wsa_state));
 | 
				
			||||||
@@ -203,7 +196,7 @@ static int init_client_ip(int *sock, unsigned char ip[4], int port)
 | 
				
			|||||||
	struct sockaddr_in them;
 | 
						struct sockaddr_in them;
 | 
				
			||||||
	int s,i;
 | 
						int s,i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!ssl_sock_init()) return(0);
 | 
						if (!sock_init()) return(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	memset((char *)&them,0,sizeof(them));
 | 
						memset((char *)&them,0,sizeof(them));
 | 
				
			||||||
	them.sin_family=AF_INET;
 | 
						them.sin_family=AF_INET;
 | 
				
			||||||
@@ -268,7 +261,7 @@ static int init_server_long(int *sock, int port, char *ip)
 | 
				
			|||||||
	struct sockaddr_in server;
 | 
						struct sockaddr_in server;
 | 
				
			||||||
	int s= -1,i;
 | 
						int s= -1,i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!ssl_sock_init()) return(0);
 | 
						if (!sock_init()) return(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	memset((char *)&server,0,sizeof(server));
 | 
						memset((char *)&server,0,sizeof(server));
 | 
				
			||||||
	server.sin_family=AF_INET;
 | 
						server.sin_family=AF_INET;
 | 
				
			||||||
@@ -325,7 +318,7 @@ static int do_accept(int acc_sock, int *sock, char **host)
 | 
				
			|||||||
	int len;
 | 
						int len;
 | 
				
			||||||
/*	struct linger ling; */
 | 
					/*	struct linger ling; */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!ssl_sock_init()) return(0);
 | 
						if (!sock_init()) return(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_SYS_WINDOWS
 | 
					#ifndef OPENSSL_SYS_WINDOWS
 | 
				
			||||||
redoit:
 | 
					redoit:
 | 
				
			||||||
@@ -388,7 +381,7 @@ redoit:
 | 
				
			|||||||
			perror("OPENSSL_malloc");
 | 
								perror("OPENSSL_malloc");
 | 
				
			||||||
			return(0);
 | 
								return(0);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		BUF_strlcpy(*host,h1->h_name,strlen(h1->h_name)+1);
 | 
							strcpy(*host,h1->h_name);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		h2=GetHostByName(*host);
 | 
							h2=GetHostByName(*host);
 | 
				
			||||||
		if (h2 == NULL)
 | 
							if (h2 == NULL)
 | 
				
			||||||
@@ -455,7 +448,7 @@ static int host_ip(char *str, unsigned char ip[4])
 | 
				
			|||||||
		{ /* do a gethostbyname */
 | 
							{ /* do a gethostbyname */
 | 
				
			||||||
		struct hostent *he;
 | 
							struct hostent *he;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!ssl_sock_init()) return(0);
 | 
							if (!sock_init()) return(0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		he=GetHostByName(str);
 | 
							he=GetHostByName(str);
 | 
				
			||||||
		if (he == NULL)
 | 
							if (he == NULL)
 | 
				
			||||||
@@ -536,12 +529,9 @@ static struct hostent *GetHostByName(char *name)
 | 
				
			|||||||
		ret=gethostbyname(name);
 | 
							ret=gethostbyname(name);
 | 
				
			||||||
		if (ret == NULL) return(NULL);
 | 
							if (ret == NULL) return(NULL);
 | 
				
			||||||
		/* else add to cache */
 | 
							/* else add to cache */
 | 
				
			||||||
		if(strlen(name) < sizeof ghbn_cache[0].name)
 | 
							strncpy(ghbn_cache[lowi].name,name,128);
 | 
				
			||||||
			{
 | 
							memcpy((char *)&(ghbn_cache[lowi].ent),ret,sizeof(struct hostent));
 | 
				
			||||||
			strcpy(ghbn_cache[lowi].name,name);
 | 
							ghbn_cache[lowi].order=ghbn_miss+ghbn_hits;
 | 
				
			||||||
			memcpy((char *)&(ghbn_cache[lowi].ent),ret,sizeof(struct hostent));
 | 
					 | 
				
			||||||
			ghbn_cache[lowi].order=ghbn_miss+ghbn_hits;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		return(ret);
 | 
							return(ret);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -85,7 +85,7 @@
 | 
				
			|||||||
#include OPENSSL_UNISTD
 | 
					#include OPENSSL_UNISTD
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if !defined(OPENSSL_SYS_MSDOS) && !defined(OPENSSL_SYS_VXWORKS) && (!defined(OPENSSL_SYS_VMS) || defined(__DECC))
 | 
					#if !defined(OPENSSL_SYS_MSDOS) && !defined(OPENSSL_SYS_VXWORKS) && (!defined(OPENSSL_SYS_VMS) || defined(__DECC)) && !defined(OPENSSL_SYS_MACOSX)
 | 
				
			||||||
#define TIMES
 | 
					#define TIMES
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -109,6 +109,10 @@
 | 
				
			|||||||
#include <sys/timeb.h>
 | 
					#include <sys/timeb.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef _AIX
 | 
				
			||||||
 | 
					#include <sys/select.h>
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(sun) || defined(__ultrix)
 | 
					#if defined(sun) || defined(__ultrix)
 | 
				
			||||||
#define _POSIX_SOURCE
 | 
					#define _POSIX_SOURCE
 | 
				
			||||||
#include <limits.h>
 | 
					#include <limits.h>
 | 
				
			||||||
@@ -146,8 +150,6 @@
 | 
				
			|||||||
#undef BUFSIZZ
 | 
					#undef BUFSIZZ
 | 
				
			||||||
#define BUFSIZZ 1024*10
 | 
					#define BUFSIZZ 1024*10
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define MYBUFSIZ 1024*8
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#undef min
 | 
					#undef min
 | 
				
			||||||
#undef max
 | 
					#undef max
 | 
				
			||||||
#define min(a,b) (((a) < (b)) ? (a) : (b))
 | 
					#define min(a,b) (((a) < (b)) ? (a) : (b))
 | 
				
			||||||
@@ -322,11 +324,6 @@ static int parseArgs(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (--argc < 1) goto bad;
 | 
							if (--argc < 1) goto bad;
 | 
				
			||||||
		s_www_path= *(++argv);
 | 
							s_www_path= *(++argv);
 | 
				
			||||||
		if(strlen(s_www_path) > MYBUFSIZ-100)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"-www option too long\n");
 | 
					 | 
				
			||||||
			badop=1;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else if(strcmp(*argv,"-bugs") == 0)
 | 
						else if(strcmp(*argv,"-bugs") == 0)
 | 
				
			||||||
	    st_bugs=1;
 | 
						    st_bugs=1;
 | 
				
			||||||
@@ -487,7 +484,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	tm_Time_F(START);
 | 
						tm_Time_F(START);
 | 
				
			||||||
	for (;;)
 | 
						for (;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (finishtime < (long)time(NULL)) break;
 | 
							if (finishtime < time(NULL)) break;
 | 
				
			||||||
#ifdef WIN32_STUFF
 | 
					#ifdef WIN32_STUFF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if( flushWinMsgs(0) == -1 )
 | 
							if( flushWinMsgs(0) == -1 )
 | 
				
			||||||
@@ -502,7 +499,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (s_www_path != NULL)
 | 
							if (s_www_path != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_snprintf(buf,sizeof buf,"GET %s HTTP/1.0\r\n\r\n",s_www_path);
 | 
								sprintf(buf,"GET %s HTTP/1.0\r\n\r\n",s_www_path);
 | 
				
			||||||
			SSL_write(scon,buf,strlen(buf));
 | 
								SSL_write(scon,buf,strlen(buf));
 | 
				
			||||||
			while ((i=SSL_read(scon,buf,sizeof(buf))) > 0)
 | 
								while ((i=SSL_read(scon,buf,sizeof(buf))) > 0)
 | 
				
			||||||
				bytes_read+=i;
 | 
									bytes_read+=i;
 | 
				
			||||||
@@ -538,9 +535,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	totalTime += tm_Time_F(STOP); /* Add the time for this iteration */
 | 
						totalTime += tm_Time_F(STOP); /* Add the time for this iteration */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	i=(int)((long)time(NULL)-finishtime+maxTime);
 | 
						i=(int)(time(NULL)-finishtime+maxTime);
 | 
				
			||||||
	printf( "\n\n%d connections in %.2fs; %.2f connections/user sec, bytes read %ld\n", nConn, totalTime, ((double)nConn/totalTime),bytes_read);
 | 
						printf( "\n\n%d connections in %.2fs; %.2f connections/user sec, bytes read %ld\n", nConn, totalTime, ((double)nConn/totalTime),bytes_read);
 | 
				
			||||||
	printf( "%d connections in %ld real seconds, %ld bytes read per connection\n",nConn,(long)time(NULL)-finishtime+maxTime,bytes_read/nConn);
 | 
						printf( "%d connections in %ld real seconds, %ld bytes read per connection\n",nConn,time(NULL)-finishtime+maxTime,bytes_read/nConn);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Now loop and time connections using the same session id over and over */
 | 
						/* Now loop and time connections using the same session id over and over */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -557,7 +554,7 @@ next:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (s_www_path != NULL)
 | 
						if (s_www_path != NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_snprintf(buf,sizeof buf,"GET %s HTTP/1.0\r\n\r\n",s_www_path);
 | 
							sprintf(buf,"GET %s HTTP/1.0\r\n\r\n",s_www_path);
 | 
				
			||||||
		SSL_write(scon,buf,strlen(buf));
 | 
							SSL_write(scon,buf,strlen(buf));
 | 
				
			||||||
		while (SSL_read(scon,buf,sizeof(buf)) > 0)
 | 
							while (SSL_read(scon,buf,sizeof(buf)) > 0)
 | 
				
			||||||
			;
 | 
								;
 | 
				
			||||||
@@ -572,7 +569,7 @@ next:
 | 
				
			|||||||
	nConn = 0;
 | 
						nConn = 0;
 | 
				
			||||||
	totalTime = 0.0;
 | 
						totalTime = 0.0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	finishtime=(long)time(NULL)+maxTime;
 | 
						finishtime=time(NULL)+maxTime;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	printf( "starting\n" );
 | 
						printf( "starting\n" );
 | 
				
			||||||
	bytes_read=0;
 | 
						bytes_read=0;
 | 
				
			||||||
@@ -580,7 +577,7 @@ next:
 | 
				
			|||||||
		
 | 
							
 | 
				
			||||||
	for (;;)
 | 
						for (;;)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if (finishtime < (long)time(NULL)) break;
 | 
							if (finishtime < time(NULL)) break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef WIN32_STUFF
 | 
					#ifdef WIN32_STUFF
 | 
				
			||||||
		if( flushWinMsgs(0) == -1 )
 | 
							if( flushWinMsgs(0) == -1 )
 | 
				
			||||||
@@ -595,7 +592,7 @@ next:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (s_www_path)
 | 
							if (s_www_path)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_snprintf(buf,sizeof buf,"GET %s HTTP/1.0\r\n\r\n",s_www_path);
 | 
								sprintf(buf,"GET %s HTTP/1.0\r\n\r\n",s_www_path);
 | 
				
			||||||
			SSL_write(scon,buf,strlen(buf));
 | 
								SSL_write(scon,buf,strlen(buf));
 | 
				
			||||||
			while ((i=SSL_read(scon,buf,sizeof(buf))) > 0)
 | 
								while ((i=SSL_read(scon,buf,sizeof(buf))) > 0)
 | 
				
			||||||
				bytes_read+=i;
 | 
									bytes_read+=i;
 | 
				
			||||||
@@ -630,7 +627,7 @@ next:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	printf( "\n\n%d connections in %.2fs; %.2f connections/user sec, bytes read %ld\n", nConn, totalTime, ((double)nConn/totalTime),bytes_read);
 | 
						printf( "\n\n%d connections in %.2fs; %.2f connections/user sec, bytes read %ld\n", nConn, totalTime, ((double)nConn/totalTime),bytes_read);
 | 
				
			||||||
	printf( "%d connections in %ld real seconds, %ld bytes read per connection\n",nConn,(long)time(NULL)-finishtime+maxTime,bytes_read/nConn);
 | 
						printf( "%d connections in %ld real seconds, %ld bytes read per connection\n",nConn,time(NULL)-finishtime+maxTime,bytes_read/nConn);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ret=0;
 | 
						ret=0;
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
@@ -642,7 +639,7 @@ end:
 | 
				
			|||||||
		tm_ctx=NULL;
 | 
							tm_ctx=NULL;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/***********************************************************************
 | 
					/***********************************************************************
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -273,7 +273,7 @@ end:
 | 
				
			|||||||
	if (out != NULL) BIO_free_all(out);
 | 
						if (out != NULL) BIO_free_all(out);
 | 
				
			||||||
	if (x != NULL) SSL_SESSION_free(x);
 | 
						if (x != NULL) SSL_SESSION_free(x);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static SSL_SESSION *load_sess_id(char *infile, int format)
 | 
					static SSL_SESSION *load_sess_id(char *infile, int format)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										17
									
								
								apps/smime.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								apps/smime.c
									
									
									
									
									
								
							@@ -104,9 +104,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int need_rand = 0;
 | 
						int need_rand = 0;
 | 
				
			||||||
	int informat = FORMAT_SMIME, outformat = FORMAT_SMIME;
 | 
						int informat = FORMAT_SMIME, outformat = FORMAT_SMIME;
 | 
				
			||||||
        int keyform = FORMAT_PEM;
 | 
					        int keyform = FORMAT_PEM;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	args = argv + 1;
 | 
						args = argv + 1;
 | 
				
			||||||
	ret = 1;
 | 
						ret = 1;
 | 
				
			||||||
@@ -168,10 +166,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				flags |= PKCS7_BINARY;
 | 
									flags |= PKCS7_BINARY;
 | 
				
			||||||
		else if (!strcmp (*args, "-nosigs"))
 | 
							else if (!strcmp (*args, "-nosigs"))
 | 
				
			||||||
				flags |= PKCS7_NOSIGS;
 | 
									flags |= PKCS7_NOSIGS;
 | 
				
			||||||
		else if (!strcmp (*args, "-nooldmime"))
 | 
					 | 
				
			||||||
				flags |= PKCS7_NOOLDMIMETYPE;
 | 
					 | 
				
			||||||
		else if (!strcmp (*args, "-crlfeol"))
 | 
					 | 
				
			||||||
				flags |= PKCS7_CRLFEOL;
 | 
					 | 
				
			||||||
		else if (!strcmp (*args, "-crl_check"))
 | 
							else if (!strcmp (*args, "-crl_check"))
 | 
				
			||||||
				store_flags |= X509_V_FLAG_CRL_CHECK;
 | 
									store_flags |= X509_V_FLAG_CRL_CHECK;
 | 
				
			||||||
		else if (!strcmp (*args, "-crl_check_all"))
 | 
							else if (!strcmp (*args, "-crl_check_all"))
 | 
				
			||||||
@@ -182,13 +176,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				inrand = *args;
 | 
									inrand = *args;
 | 
				
			||||||
			} else badarg = 1;
 | 
								} else badarg = 1;
 | 
				
			||||||
			need_rand = 1;
 | 
								need_rand = 1;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		} else if (!strcmp(*args,"-engine")) {
 | 
							} else if (!strcmp(*args,"-engine")) {
 | 
				
			||||||
			if (args[1]) {
 | 
								if (args[1]) {
 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
				engine = *args;
 | 
									engine = *args;
 | 
				
			||||||
			} else badarg = 1;
 | 
								} else badarg = 1;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		} else if (!strcmp(*args,"-passin")) {
 | 
							} else if (!strcmp(*args,"-passin")) {
 | 
				
			||||||
			if (args[1]) {
 | 
								if (args[1]) {
 | 
				
			||||||
				args++;
 | 
									args++;
 | 
				
			||||||
@@ -338,9 +330,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_printf (bio_err, "-CAfile file   trusted certificates file\n");
 | 
							BIO_printf (bio_err, "-CAfile file   trusted certificates file\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-crl_check     check revocation status of signer's certificate using CRLs\n");
 | 
							BIO_printf (bio_err, "-crl_check     check revocation status of signer's certificate using CRLs\n");
 | 
				
			||||||
		BIO_printf (bio_err, "-crl_check_all check revocation status of signer's certificate chain using CRLs\n");
 | 
							BIO_printf (bio_err, "-crl_check_all check revocation status of signer's certificate chain using CRLs\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf (bio_err, "-engine e      use engine e, possibly a hardware device.\n");
 | 
							BIO_printf (bio_err, "-engine e      use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf (bio_err, "-passin arg    input file pass phrase source\n");
 | 
							BIO_printf (bio_err, "-passin arg    input file pass phrase source\n");
 | 
				
			||||||
		BIO_printf(bio_err,  "-rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
							BIO_printf(bio_err,  "-rand file%cfile%c...\n", LIST_SEPARATOR_CHAR, LIST_SEPARATOR_CHAR);
 | 
				
			||||||
		BIO_printf(bio_err,  "               load the file (or the files in the directory) into\n");
 | 
							BIO_printf(bio_err,  "               load the file (or the files in the directory) into\n");
 | 
				
			||||||
@@ -349,9 +339,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(!app_passwd(bio_err, passargin, NULL, &passin, NULL)) {
 | 
						if(!app_passwd(bio_err, passargin, NULL, &passin, NULL)) {
 | 
				
			||||||
		BIO_printf(bio_err, "Error getting password\n");
 | 
							BIO_printf(bio_err, "Error getting password\n");
 | 
				
			||||||
@@ -440,7 +428,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	} else keyfile = NULL;
 | 
						} else keyfile = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(keyfile) {
 | 
						if(keyfile) {
 | 
				
			||||||
		key = load_key(bio_err, keyfile, keyform, 0, passin, e,
 | 
							key = load_key(bio_err, keyfile, keyform, passin, e,
 | 
				
			||||||
			       "signing key file");
 | 
								       "signing key file");
 | 
				
			||||||
		if (!key) {
 | 
							if (!key) {
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
@@ -483,8 +471,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		p7 = PKCS7_encrypt(encerts, in, cipher, flags);
 | 
							p7 = PKCS7_encrypt(encerts, in, cipher, flags);
 | 
				
			||||||
	} else if(operation == SMIME_SIGN) {
 | 
						} else if(operation == SMIME_SIGN) {
 | 
				
			||||||
		p7 = PKCS7_sign(signer, key, other, in, flags);
 | 
							p7 = PKCS7_sign(signer, key, other, in, flags);
 | 
				
			||||||
		if ((flags & PKCS7_DETACHED) && (outformat == FORMAT_SMIME)
 | 
							if (BIO_reset(in) != 0 && (flags & PKCS7_DETACHED)) {
 | 
				
			||||||
			&& (BIO_reset(in) != 0)) {
 | 
					 | 
				
			||||||
		  BIO_printf(bio_err, "Can't rewind input file\n");
 | 
							  BIO_printf(bio_err, "Can't rewind input file\n");
 | 
				
			||||||
		  goto end;
 | 
							  goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										31
									
								
								apps/speed.c
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								apps/speed.c
									
									
									
									
									
								
							@@ -58,8 +58,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* most of this code has been pilfered from my libdes speed.c program */
 | 
					/* most of this code has been pilfered from my libdes speed.c program */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_SPEED
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#undef SECONDS
 | 
					#undef SECONDS
 | 
				
			||||||
#define SECONDS		3	
 | 
					#define SECONDS		3	
 | 
				
			||||||
#define RSA_SECONDS	10
 | 
					#define RSA_SECONDS	10
 | 
				
			||||||
@@ -189,8 +187,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* The following if from times(3) man page.  It may need to be changed */
 | 
					/* The following if from times(3) man page.  It may need to be changed */
 | 
				
			||||||
#ifndef HZ
 | 
					#ifndef HZ
 | 
				
			||||||
# if defined(_SC_CLK_TCK) \
 | 
					# ifdef _SC_CLK_TCK
 | 
				
			||||||
     && (!defined(OPENSSL_SYS_VMS) || __CTRL_VER >= 70000000)
 | 
					 | 
				
			||||||
#  define HZ ((double)sysconf(_SC_CLK_TCK))
 | 
					#  define HZ ((double)sysconf(_SC_CLK_TCK))
 | 
				
			||||||
# else
 | 
					# else
 | 
				
			||||||
#  ifndef CLK_TCK
 | 
					#  ifndef CLK_TCK
 | 
				
			||||||
@@ -372,9 +369,7 @@ int MAIN(int, char **);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int MAIN(int argc, char **argv)
 | 
					int MAIN(int argc, char **argv)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	ENGINE *e = NULL;
 | 
						ENGINE *e = NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	unsigned char *buf=NULL,*buf2=NULL;
 | 
						unsigned char *buf=NULL,*buf2=NULL;
 | 
				
			||||||
	int mret=1;
 | 
						int mret=1;
 | 
				
			||||||
	long count=0,save_count=0;
 | 
						long count=0,save_count=0;
 | 
				
			||||||
@@ -594,7 +589,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			j--;	/* Otherwise, -elapsed gets confused with
 | 
								j--;	/* Otherwise, -elapsed gets confused with
 | 
				
			||||||
				   an algorithm. */
 | 
									   an algorithm. */
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if	((argc > 0) && (strcmp(*argv,"-engine") == 0))
 | 
							else if	((argc > 0) && (strcmp(*argv,"-engine") == 0))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--;
 | 
								argc--;
 | 
				
			||||||
@@ -611,7 +605,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			   means all of them should be run) */
 | 
								   means all of them should be run) */
 | 
				
			||||||
			j--;
 | 
								j--;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifdef HAVE_FORK
 | 
					#ifdef HAVE_FORK
 | 
				
			||||||
		else if	((argc > 0) && (strcmp(*argv,"-multi") == 0))
 | 
							else if	((argc > 0) && (strcmp(*argv,"-multi") == 0))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -773,7 +766,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
			dsa_doit[R_DSA_512]=1;
 | 
								dsa_doit[R_DSA_512]=1;
 | 
				
			||||||
			dsa_doit[R_DSA_1024]=1;
 | 
								dsa_doit[R_DSA_1024]=1;
 | 
				
			||||||
			dsa_doit[R_DSA_2048]=1;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -869,12 +861,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
			BIO_printf(bio_err,"\n");
 | 
								BIO_printf(bio_err,"\n");
 | 
				
			||||||
			BIO_printf(bio_err,"Available options:\n");
 | 
								BIO_printf(bio_err,"Available options:\n");
 | 
				
			||||||
#if defined(TIMES) || defined(USE_TOD)
 | 
					#ifdef TIMES
 | 
				
			||||||
			BIO_printf(bio_err,"-elapsed        measure time in real time instead of CPU user time.\n");
 | 
								BIO_printf(bio_err,"-elapsed        measure time in real time instead of CPU user time.\n");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"-engine e       use engine e, possibly a hardware device.\n");
 | 
								BIO_printf(bio_err,"-engine e       use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"-evp e          use EVP e.\n");
 | 
								BIO_printf(bio_err,"-evp e          use EVP e.\n");
 | 
				
			||||||
			BIO_printf(bio_err,"-decrypt        time decryption instead of encryption (only EVP).\n");
 | 
								BIO_printf(bio_err,"-decrypt        time decryption instead of encryption (only EVP).\n");
 | 
				
			||||||
			BIO_printf(bio_err,"-mr             produce machine readable output.\n");
 | 
								BIO_printf(bio_err,"-mr             produce machine readable output.\n");
 | 
				
			||||||
@@ -1007,9 +997,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	c[D_CBC_RC5][0]=count;
 | 
						c[D_CBC_RC5][0]=count;
 | 
				
			||||||
	c[D_CBC_BF][0]=count;
 | 
						c[D_CBC_BF][0]=count;
 | 
				
			||||||
	c[D_CBC_CAST][0]=count;
 | 
						c[D_CBC_CAST][0]=count;
 | 
				
			||||||
	c[D_CBC_128_AES][0]=count;
 | 
					 | 
				
			||||||
	c[D_CBC_192_AES][0]=count;
 | 
					 | 
				
			||||||
	c[D_CBC_256_AES][0]=count;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i=1; i<SIZE_NUM; i++)
 | 
						for (i=1; i<SIZE_NUM; i++)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1035,9 +1022,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		c[D_CBC_RC5][i]=c[D_CBC_RC5][i-1]*l0/l1;
 | 
							c[D_CBC_RC5][i]=c[D_CBC_RC5][i-1]*l0/l1;
 | 
				
			||||||
		c[D_CBC_BF][i]=c[D_CBC_BF][i-1]*l0/l1;
 | 
							c[D_CBC_BF][i]=c[D_CBC_BF][i-1]*l0/l1;
 | 
				
			||||||
		c[D_CBC_CAST][i]=c[D_CBC_CAST][i-1]*l0/l1;
 | 
							c[D_CBC_CAST][i]=c[D_CBC_CAST][i-1]*l0/l1;
 | 
				
			||||||
		c[D_CBC_128_AES][i]=c[D_CBC_128_AES][i-1]*l0/l1;
 | 
					 | 
				
			||||||
		c[D_CBC_192_AES][i]=c[D_CBC_192_AES][i-1]*l0/l1;
 | 
					 | 
				
			||||||
		c[D_CBC_256_AES][i]=c[D_CBC_256_AES][i-1]*l0/l1;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#ifndef OPENSSL_NO_RSA
 | 
					#ifndef OPENSSL_NO_RSA
 | 
				
			||||||
	rsa_c[R_RSA_512][0]=count/2000;
 | 
						rsa_c[R_RSA_512][0]=count/2000;
 | 
				
			||||||
@@ -1395,7 +1379,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
					EVP_DecryptInit_ex(&ctx,evp_cipher,NULL,key16,iv);
 | 
										EVP_DecryptInit_ex(&ctx,evp_cipher,NULL,key16,iv);
 | 
				
			||||||
				else
 | 
									else
 | 
				
			||||||
					EVP_EncryptInit_ex(&ctx,evp_cipher,NULL,key16,iv);
 | 
										EVP_EncryptInit_ex(&ctx,evp_cipher,NULL,key16,iv);
 | 
				
			||||||
				EVP_CIPHER_CTX_set_padding(&ctx, 0);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
				Time_F(START);
 | 
									Time_F(START);
 | 
				
			||||||
				if(decrypt)
 | 
									if(decrypt)
 | 
				
			||||||
@@ -1409,7 +1392,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				else
 | 
									else
 | 
				
			||||||
					EVP_EncryptFinal_ex(&ctx,buf,&outl);
 | 
										EVP_EncryptFinal_ex(&ctx,buf,&outl);
 | 
				
			||||||
				d=Time_F(STOP);
 | 
									d=Time_F(STOP);
 | 
				
			||||||
				EVP_CIPHER_CTX_cleanup(&ctx);
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			if (evp_md)
 | 
								if (evp_md)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
@@ -1706,7 +1688,7 @@ show_res:
 | 
				
			|||||||
				k,rsa_bits[k],rsa_results[k][0],
 | 
									k,rsa_bits[k],rsa_results[k][0],
 | 
				
			||||||
				rsa_results[k][1]);
 | 
									rsa_results[k][1]);
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			fprintf(stdout,"rsa %4u bits %8.6fs %8.6fs %8.1f %8.1f\n",
 | 
								fprintf(stdout,"rsa %4u bits %8.4fs %8.4fs %8.1f %8.1f\n",
 | 
				
			||||||
				rsa_bits[k],rsa_results[k][0],rsa_results[k][1],
 | 
									rsa_bits[k],rsa_results[k][0],rsa_results[k][1],
 | 
				
			||||||
				1.0/rsa_results[k][0],1.0/rsa_results[k][1]);
 | 
									1.0/rsa_results[k][0],1.0/rsa_results[k][1]);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1725,7 +1707,7 @@ show_res:
 | 
				
			|||||||
			fprintf(stdout,"+F3:%u:%u:%f:%f\n",
 | 
								fprintf(stdout,"+F3:%u:%u:%f:%f\n",
 | 
				
			||||||
				k,dsa_bits[k],dsa_results[k][0],dsa_results[k][1]);
 | 
									k,dsa_bits[k],dsa_results[k][0],dsa_results[k][1]);
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			fprintf(stdout,"dsa %4u bits %8.6fs %8.6fs %8.1f %8.1f\n",
 | 
								fprintf(stdout,"dsa %4u bits %8.4fs %8.4fs %8.1f %8.1f\n",
 | 
				
			||||||
				dsa_bits[k],dsa_results[k][0],dsa_results[k][1],
 | 
									dsa_bits[k],dsa_results[k][0],dsa_results[k][1],
 | 
				
			||||||
				1.0/dsa_results[k][0],1.0/dsa_results[k][1]);
 | 
									1.0/dsa_results[k][0],1.0/dsa_results[k][1]);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1746,7 +1728,7 @@ end:
 | 
				
			|||||||
			DSA_free(dsa_key[i]);
 | 
								DSA_free(dsa_key[i]);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(mret);
 | 
						EXIT(mret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void print_message(const char *s, long num, int length)
 | 
					static void print_message(const char *s, long num, int length)
 | 
				
			||||||
@@ -1799,7 +1781,7 @@ static char *sstrsep(char **string, const char *delim)
 | 
				
			|||||||
    if (**string == 0)
 | 
					    if (**string == 0)
 | 
				
			||||||
        return NULL;
 | 
					        return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    memset(isdelim, 0, sizeof isdelim);
 | 
					    memset(isdelim, 0, 256);
 | 
				
			||||||
    isdelim[0] = 1;
 | 
					    isdelim[0] = 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    while (*delim)
 | 
					    while (*delim)
 | 
				
			||||||
@@ -1956,4 +1938,3 @@ static int do_multi(int multi)
 | 
				
			|||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										12
									
								
								apps/spkac.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								apps/spkac.c
									
									
									
									
									
								
							@@ -92,9 +92,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	CONF *conf = NULL;
 | 
						CONF *conf = NULL;
 | 
				
			||||||
	NETSCAPE_SPKI *spki = NULL;
 | 
						NETSCAPE_SPKI *spki = NULL;
 | 
				
			||||||
	EVP_PKEY *pkey = NULL;
 | 
						EVP_PKEY *pkey = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -143,13 +141,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			spksect= *(++argv);
 | 
								spksect= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-noout") == 0)
 | 
							else if (strcmp(*argv,"-noout") == 0)
 | 
				
			||||||
			noout=1;
 | 
								noout=1;
 | 
				
			||||||
		else if (strcmp(*argv,"-pubkey") == 0)
 | 
							else if (strcmp(*argv,"-pubkey") == 0)
 | 
				
			||||||
@@ -175,9 +171,7 @@ bad:
 | 
				
			|||||||
		BIO_printf(bio_err," -noout         don't print SPKAC\n");
 | 
							BIO_printf(bio_err," -noout         don't print SPKAC\n");
 | 
				
			||||||
		BIO_printf(bio_err," -pubkey        output public key\n");
 | 
							BIO_printf(bio_err," -pubkey        output public key\n");
 | 
				
			||||||
		BIO_printf(bio_err," -verify        verify SPKAC signature\n");
 | 
							BIO_printf(bio_err," -verify        verify SPKAC signature\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," -engine e      use engine e, possibly a hardware device.\n");
 | 
							BIO_printf(bio_err," -engine e      use engine e, possibly a hardware device.\n");
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -187,14 +181,12 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(keyfile) {
 | 
						if(keyfile) {
 | 
				
			||||||
		pkey = load_key(bio_err,
 | 
							pkey = load_key(bio_err,
 | 
				
			||||||
				strcmp(keyfile, "-") ? keyfile : NULL,
 | 
									strcmp(keyfile, "-") ? keyfile : NULL,
 | 
				
			||||||
				FORMAT_PEM, 1, passin, e, "private key");
 | 
									FORMAT_PEM, passin, e, "private key");
 | 
				
			||||||
		if(!pkey) {
 | 
							if(!pkey) {
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -303,5 +295,5 @@ end:
 | 
				
			|||||||
	EVP_PKEY_free(pkey);
 | 
						EVP_PKEY_free(pkey);
 | 
				
			||||||
	if(passin) OPENSSL_free(passin);
 | 
						if(passin) OPENSSL_free(passin);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -86,9 +86,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	STACK_OF(X509) *untrusted = NULL, *trusted = NULL;
 | 
						STACK_OF(X509) *untrusted = NULL, *trusted = NULL;
 | 
				
			||||||
	X509_STORE *cert_ctx=NULL;
 | 
						X509_STORE *cert_ctx=NULL;
 | 
				
			||||||
	X509_LOOKUP *lookup=NULL;
 | 
						X509_LOOKUP *lookup=NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	cert_ctx=X509_STORE_new();
 | 
						cert_ctx=X509_STORE_new();
 | 
				
			||||||
	if (cert_ctx == NULL) goto end;
 | 
						if (cert_ctx == NULL) goto end;
 | 
				
			||||||
@@ -144,13 +142,11 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
				if (argc-- < 1) goto end;
 | 
									if (argc-- < 1) goto end;
 | 
				
			||||||
				trustfile= *(++argv);
 | 
									trustfile= *(++argv);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
			else if (strcmp(*argv,"-engine") == 0)
 | 
								else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				if (--argc < 1) goto end;
 | 
									if (--argc < 1) goto end;
 | 
				
			||||||
				engine= *(++argv);
 | 
									engine= *(++argv);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
			else if (strcmp(*argv,"-help") == 0)
 | 
								else if (strcmp(*argv,"-help") == 0)
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
			else if (strcmp(*argv,"-ignore_critical") == 0)
 | 
								else if (strcmp(*argv,"-ignore_critical") == 0)
 | 
				
			||||||
@@ -174,9 +170,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			break;
 | 
								break;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	lookup=X509_STORE_add_lookup(cert_ctx,X509_LOOKUP_file());
 | 
						lookup=X509_STORE_add_lookup(cert_ctx,X509_LOOKUP_file());
 | 
				
			||||||
	if (lookup == NULL) abort();
 | 
						if (lookup == NULL) abort();
 | 
				
			||||||
@@ -225,11 +219,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	ret=0;
 | 
						ret=0;
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
	if (ret == 1) {
 | 
						if (ret == 1) {
 | 
				
			||||||
		BIO_printf(bio_err,"usage: verify [-verbose] [-CApath path] [-CAfile file] [-purpose purpose] [-crl_check]");
 | 
							BIO_printf(bio_err,"usage: verify [-verbose] [-CApath path] [-CAfile file] [-purpose purpose] [-crl_check] [-engine e] cert1 cert2 ...\n");
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," [-engine e]");
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		BIO_printf(bio_err," cert1 cert2 ...\n");
 | 
					 | 
				
			||||||
		BIO_printf(bio_err,"recognized usages:\n");
 | 
							BIO_printf(bio_err,"recognized usages:\n");
 | 
				
			||||||
		for(i = 0; i < X509_PURPOSE_get_count(); i++) {
 | 
							for(i = 0; i < X509_PURPOSE_get_count(); i++) {
 | 
				
			||||||
			X509_PURPOSE *ptmp;
 | 
								X509_PURPOSE *ptmp;
 | 
				
			||||||
@@ -242,7 +232,7 @@ end:
 | 
				
			|||||||
	sk_X509_pop_free(untrusted, X509_free);
 | 
						sk_X509_pop_free(untrusted, X509_free);
 | 
				
			||||||
	sk_X509_pop_free(trusted, X509_free);
 | 
						sk_X509_pop_free(trusted, X509_free);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int check(X509_STORE *ctx, char *file, STACK_OF(X509) *uchain, STACK_OF(X509) *tchain, int purpose, ENGINE *e)
 | 
					static int check(X509_STORE *ctx, char *file, STACK_OF(X509) *uchain, STACK_OF(X509) *tchain, int purpose, ENGINE *e)
 | 
				
			||||||
@@ -340,8 +330,7 @@ static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
	if (!ok)
 | 
						if (!ok)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		X509_NAME_oneline(
 | 
							X509_NAME_oneline(
 | 
				
			||||||
				X509_get_subject_name(ctx->current_cert),buf,
 | 
									X509_get_subject_name(ctx->current_cert),buf,256);
 | 
				
			||||||
				sizeof buf);
 | 
					 | 
				
			||||||
		printf("%s\n",buf);
 | 
							printf("%s\n",buf);
 | 
				
			||||||
		printf("error %d at %d depth lookup:%s\n",ctx->error,
 | 
							printf("error %d at %d depth lookup:%s\n",ctx->error,
 | 
				
			||||||
			ctx->error_depth,
 | 
								ctx->error_depth,
 | 
				
			||||||
@@ -354,7 +343,6 @@ static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
		if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
							if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
				
			||||||
		/* Continue after extension errors too */
 | 
							/* Continue after extension errors too */
 | 
				
			||||||
		if (ctx->error == X509_V_ERR_INVALID_CA) ok=1;
 | 
							if (ctx->error == X509_V_ERR_INVALID_CA) ok=1;
 | 
				
			||||||
		if (ctx->error == X509_V_ERR_INVALID_NON_CA) ok=1;
 | 
					 | 
				
			||||||
		if (ctx->error == X509_V_ERR_PATH_LENGTH_EXCEEDED) ok=1;
 | 
							if (ctx->error == X509_V_ERR_PATH_LENGTH_EXCEEDED) ok=1;
 | 
				
			||||||
		if (ctx->error == X509_V_ERR_INVALID_PURPOSE) ok=1;
 | 
							if (ctx->error == X509_V_ERR_INVALID_PURPOSE) ok=1;
 | 
				
			||||||
		if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
							if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -200,5 +200,5 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if (dir)  printf("%s\n",SSLeay_version(SSLEAY_DIR));
 | 
						if (dir)  printf("%s\n",SSLeay_version(SSLEAY_DIR));
 | 
				
			||||||
end:
 | 
					end:
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -118,6 +118,7 @@ LRESULT CALLBACK WndProc(HWND hwnd, UINT iMsg, WPARAM wParam, LPARAM lParam)
 | 
				
			|||||||
        HDC hdc;
 | 
					        HDC hdc;
 | 
				
			||||||
	PAINTSTRUCT ps;
 | 
						PAINTSTRUCT ps;
 | 
				
			||||||
        RECT rect;
 | 
					        RECT rect;
 | 
				
			||||||
 | 
					        char buffer[200];
 | 
				
			||||||
        static int seeded = 0;
 | 
					        static int seeded = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	switch (iMsg)
 | 
						switch (iMsg)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										197
									
								
								apps/x509.c
									
									
									
									
									
								
							
							
						
						
									
										197
									
								
								apps/x509.c
									
									
									
									
									
								
							@@ -122,7 +122,7 @@ static char *x509_usage[]={
 | 
				
			|||||||
" -CAkey arg      - set the CA key, must be PEM format\n",
 | 
					" -CAkey arg      - set the CA key, must be PEM format\n",
 | 
				
			||||||
"                   missing, it is assumed to be in the CA file.\n",
 | 
					"                   missing, it is assumed to be in the CA file.\n",
 | 
				
			||||||
" -CAcreateserial - create serial number file if it does not exist\n",
 | 
					" -CAcreateserial - create serial number file if it does not exist\n",
 | 
				
			||||||
" -CAserial arg   - serial file\n",
 | 
					" -CAserial       - serial file\n",
 | 
				
			||||||
" -set_serial     - serial number to use\n",
 | 
					" -set_serial     - serial number to use\n",
 | 
				
			||||||
" -text           - print the certificate in text form\n",
 | 
					" -text           - print the certificate in text form\n",
 | 
				
			||||||
" -C              - print out C code forms\n",
 | 
					" -C              - print out C code forms\n",
 | 
				
			||||||
@@ -131,9 +131,7 @@ static char *x509_usage[]={
 | 
				
			|||||||
" -extensions     - section from config file with X509V3 extensions to add\n",
 | 
					" -extensions     - section from config file with X509V3 extensions to add\n",
 | 
				
			||||||
" -clrext         - delete extensions before signing and input certificate\n",
 | 
					" -clrext         - delete extensions before signing and input certificate\n",
 | 
				
			||||||
" -nameopt arg    - various certificate name options\n",
 | 
					" -nameopt arg    - various certificate name options\n",
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
" -engine e       - use engine e, possibly a hardware device.\n",
 | 
					" -engine e       - use engine e, possibly a hardware device.\n",
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
" -certopt arg    - various certificate text options\n",
 | 
					" -certopt arg    - various certificate text options\n",
 | 
				
			||||||
NULL
 | 
					NULL
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
@@ -168,7 +166,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *CAkeyfile=NULL,*CAserial=NULL;
 | 
						char *CAkeyfile=NULL,*CAserial=NULL;
 | 
				
			||||||
	char *alias=NULL;
 | 
						char *alias=NULL;
 | 
				
			||||||
	int text=0,serial=0,hash=0,subject=0,issuer=0,startdate=0,enddate=0;
 | 
						int text=0,serial=0,hash=0,subject=0,issuer=0,startdate=0,enddate=0;
 | 
				
			||||||
	int next_serial=0,ocspid=0;
 | 
						int ocspid=0;
 | 
				
			||||||
	int noout=0,sign_flag=0,CA_flag=0,CA_createserial=0,email=0;
 | 
						int noout=0,sign_flag=0,CA_flag=0,CA_createserial=0,email=0;
 | 
				
			||||||
	int trustout=0,clrtrust=0,clrreject=0,aliasout=0,clrext=0;
 | 
						int trustout=0,clrtrust=0,clrreject=0,aliasout=0,clrext=0;
 | 
				
			||||||
	int C=0;
 | 
						int C=0;
 | 
				
			||||||
@@ -179,15 +177,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	X509_REQ *rq=NULL;
 | 
						X509_REQ *rq=NULL;
 | 
				
			||||||
	int fingerprint=0;
 | 
						int fingerprint=0;
 | 
				
			||||||
	char buf[256];
 | 
						char buf[256];
 | 
				
			||||||
	const EVP_MD *md_alg,*digest;
 | 
						const EVP_MD *md_alg,*digest=EVP_md5();
 | 
				
			||||||
	CONF *extconf = NULL;
 | 
						CONF *extconf = NULL;
 | 
				
			||||||
	char *extsect = NULL, *extfile = NULL, *passin = NULL, *passargin = NULL;
 | 
						char *extsect = NULL, *extfile = NULL, *passin = NULL, *passargin = NULL;
 | 
				
			||||||
	int need_rand = 0;
 | 
						int need_rand = 0;
 | 
				
			||||||
	int checkend=0,checkoffset=0;
 | 
						int checkend=0,checkoffset=0;
 | 
				
			||||||
	unsigned long nmflag = 0, certflag = 0;
 | 
						unsigned long nmflag = 0, certflag = 0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	reqfile=0;
 | 
						reqfile=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -216,13 +212,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if (ctx == NULL) goto end;
 | 
						if (ctx == NULL) goto end;
 | 
				
			||||||
	X509_STORE_set_verify_cb_func(ctx,callb);
 | 
						X509_STORE_set_verify_cb_func(ctx,callb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef  OPENSSL_FIPS
 | 
					 | 
				
			||||||
	if (FIPS_mode())
 | 
					 | 
				
			||||||
		digest = EVP_sha1();
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		digest = EVP_md5();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	argc--;
 | 
						argc--;
 | 
				
			||||||
	argv++;
 | 
						argv++;
 | 
				
			||||||
	num=0;
 | 
						num=0;
 | 
				
			||||||
@@ -256,7 +245,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (strcmp(*argv,"-CAkeyform") == 0)
 | 
							else if (strcmp(*argv,"-CAkeyform") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			CAkeyformat=str2fmt(*(++argv));
 | 
								CAformat=str2fmt(*(++argv));
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-days") == 0)
 | 
							else if (strcmp(*argv,"-days") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -365,21 +354,23 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			if (!set_name_ex(&nmflag, *(++argv))) goto bad;
 | 
								if (!set_name_ex(&nmflag, *(++argv))) goto bad;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
							else if (strcmp(*argv,"-setalias") == 0)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
 | 
								alias= *(++argv);
 | 
				
			||||||
 | 
								trustout = 1;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			engine= *(++argv);
 | 
								engine= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-C") == 0)
 | 
							else if (strcmp(*argv,"-C") == 0)
 | 
				
			||||||
			C= ++num;
 | 
								C= ++num;
 | 
				
			||||||
		else if (strcmp(*argv,"-email") == 0)
 | 
							else if (strcmp(*argv,"-email") == 0)
 | 
				
			||||||
			email= ++num;
 | 
								email= ++num;
 | 
				
			||||||
		else if (strcmp(*argv,"-serial") == 0)
 | 
							else if (strcmp(*argv,"-serial") == 0)
 | 
				
			||||||
			serial= ++num;
 | 
								serial= ++num;
 | 
				
			||||||
		else if (strcmp(*argv,"-next_serial") == 0)
 | 
					 | 
				
			||||||
			next_serial= ++num;
 | 
					 | 
				
			||||||
		else if (strcmp(*argv,"-modulus") == 0)
 | 
							else if (strcmp(*argv,"-modulus") == 0)
 | 
				
			||||||
			modulus= ++num;
 | 
								modulus= ++num;
 | 
				
			||||||
		else if (strcmp(*argv,"-pubkey") == 0)
 | 
							else if (strcmp(*argv,"-pubkey") == 0)
 | 
				
			||||||
@@ -459,9 +450,7 @@ bad:
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					 | 
				
			||||||
        e = setup_engine(bio_err, engine, 0);
 | 
					        e = setup_engine(bio_err, engine, 0);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (need_rand)
 | 
						if (need_rand)
 | 
				
			||||||
		app_RAND_load_file(NULL, bio_err, 0);
 | 
							app_RAND_load_file(NULL, bio_err, 0);
 | 
				
			||||||
@@ -490,7 +479,7 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (extfile)
 | 
						if (extfile)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		long errorline = -1;
 | 
							long errorline;
 | 
				
			||||||
		X509V3_CTX ctx2;
 | 
							X509V3_CTX ctx2;
 | 
				
			||||||
		extconf = NCONF_new(NULL);
 | 
							extconf = NCONF_new(NULL);
 | 
				
			||||||
		if (!NCONF_load(extconf, extfile,&errorline))
 | 
							if (!NCONF_load(extconf, extfile,&errorline))
 | 
				
			||||||
@@ -600,19 +589,12 @@ bad:
 | 
				
			|||||||
		if ((x=X509_new()) == NULL) goto end;
 | 
							if ((x=X509_new()) == NULL) goto end;
 | 
				
			||||||
		ci=x->cert_info;
 | 
							ci=x->cert_info;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (sno == NULL)
 | 
							if (sno)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			sno = ASN1_INTEGER_new();
 | 
								if (!X509_set_serialNumber(x, sno))
 | 
				
			||||||
			if (!sno || !rand_serial(NULL, sno))
 | 
					 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
			if (!X509_set_serialNumber(x, sno)) 
 | 
					 | 
				
			||||||
				goto end;
 | 
					 | 
				
			||||||
			ASN1_INTEGER_free(sno);
 | 
					 | 
				
			||||||
			sno = NULL;
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (!X509_set_serialNumber(x, sno)) 
 | 
							else if (!ASN1_INTEGER_set(X509_get_serialNumber(x),0)) goto end;
 | 
				
			||||||
			goto end;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (!X509_set_issuer_name(x,req->req_info->subject)) goto end;
 | 
							if (!X509_set_issuer_name(x,req->req_info->subject)) goto end;
 | 
				
			||||||
		if (!X509_set_subject_name(x,req->req_info->subject)) goto end;
 | 
							if (!X509_set_subject_name(x,req->req_info->subject)) goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -633,7 +615,7 @@ bad:
 | 
				
			|||||||
		if (xca == NULL) goto end;
 | 
							if (xca == NULL) goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!noout || text || next_serial)
 | 
						if (!noout || text)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		OBJ_create("2.99999.3",
 | 
							OBJ_create("2.99999.3",
 | 
				
			||||||
			"SET.ex3","SET x509v3 extension 3");
 | 
								"SET.ex3","SET x509v3 extension 3");
 | 
				
			||||||
@@ -707,24 +689,6 @@ bad:
 | 
				
			|||||||
				i2a_ASN1_INTEGER(STDout,x->cert_info->serialNumber);
 | 
									i2a_ASN1_INTEGER(STDout,x->cert_info->serialNumber);
 | 
				
			||||||
				BIO_printf(STDout,"\n");
 | 
									BIO_printf(STDout,"\n");
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			else if (next_serial == i)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIGNUM *bnser;
 | 
					 | 
				
			||||||
				ASN1_INTEGER *ser;
 | 
					 | 
				
			||||||
				ser = X509_get_serialNumber(x);
 | 
					 | 
				
			||||||
				bnser = ASN1_INTEGER_to_BN(ser, NULL);
 | 
					 | 
				
			||||||
				if (!bnser)
 | 
					 | 
				
			||||||
					goto end;
 | 
					 | 
				
			||||||
				if (!BN_add_word(bnser, 1))
 | 
					 | 
				
			||||||
					goto end;
 | 
					 | 
				
			||||||
				ser = BN_to_ASN1_INTEGER(bnser, NULL);
 | 
					 | 
				
			||||||
				if (!ser)
 | 
					 | 
				
			||||||
					goto end;
 | 
					 | 
				
			||||||
				BN_free(bnser);
 | 
					 | 
				
			||||||
				i2a_ASN1_INTEGER(out, ser);
 | 
					 | 
				
			||||||
				ASN1_INTEGER_free(ser);
 | 
					 | 
				
			||||||
				BIO_puts(out, "\n");
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			else if (email == i) 
 | 
								else if (email == i) 
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				int j;
 | 
									int j;
 | 
				
			||||||
@@ -806,11 +770,10 @@ bad:
 | 
				
			|||||||
				int y,z;
 | 
									int y,z;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				X509_NAME_oneline(X509_get_subject_name(x),
 | 
									X509_NAME_oneline(X509_get_subject_name(x),
 | 
				
			||||||
					buf,sizeof buf);
 | 
										buf,256);
 | 
				
			||||||
				BIO_printf(STDout,"/* subject:%s */\n",buf);
 | 
									BIO_printf(STDout,"/* subject:%s */\n",buf);
 | 
				
			||||||
				m=X509_NAME_oneline(
 | 
									m=X509_NAME_oneline(
 | 
				
			||||||
					X509_get_issuer_name(x),buf,
 | 
										X509_get_issuer_name(x),buf,256);
 | 
				
			||||||
					sizeof buf);
 | 
					 | 
				
			||||||
				BIO_printf(STDout,"/* issuer :%s */\n",buf);
 | 
									BIO_printf(STDout,"/* issuer :%s */\n",buf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				z=i2d_X509(x,NULL);
 | 
									z=i2d_X509(x,NULL);
 | 
				
			||||||
@@ -898,14 +861,18 @@ bad:
 | 
				
			|||||||
				if (Upkey == NULL)
 | 
									if (Upkey == NULL)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					Upkey=load_key(bio_err,
 | 
										Upkey=load_key(bio_err,
 | 
				
			||||||
						keyfile, keyformat, 0,
 | 
											keyfile,keyformat, passin, e,
 | 
				
			||||||
						passin, e, "Private key");
 | 
											"Private key");
 | 
				
			||||||
					if (Upkey == NULL) goto end;
 | 
										if (Upkey == NULL) goto end;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
		                if (Upkey->type == EVP_PKEY_DSA)
 | 
							                if (Upkey->type == EVP_PKEY_DSA)
 | 
				
			||||||
		                        digest=EVP_dss1();
 | 
							                        digest=EVP_dss1();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
									if (Upkey->type == EVP_PKEY_ECDSA)
 | 
				
			||||||
 | 
										digest=EVP_ecdsa();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				assert(need_rand);
 | 
									assert(need_rand);
 | 
				
			||||||
				if (!sign(x,Upkey,days,clrext,digest,
 | 
									if (!sign(x,Upkey,days,clrext,digest,
 | 
				
			||||||
@@ -917,15 +884,18 @@ bad:
 | 
				
			|||||||
				if (CAkeyfile != NULL)
 | 
									if (CAkeyfile != NULL)
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					CApkey=load_key(bio_err,
 | 
										CApkey=load_key(bio_err,
 | 
				
			||||||
						CAkeyfile, CAkeyformat,
 | 
											CAkeyfile,CAkeyformat, passin,
 | 
				
			||||||
						0, passin, e,
 | 
											e, "CA Private Key");
 | 
				
			||||||
						"CA Private Key");
 | 
					 | 
				
			||||||
					if (CApkey == NULL) goto end;
 | 
										if (CApkey == NULL) goto end;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
		                if (CApkey->type == EVP_PKEY_DSA)
 | 
							                if (CApkey->type == EVP_PKEY_DSA)
 | 
				
			||||||
		                        digest=EVP_dss1();
 | 
							                        digest=EVP_dss1();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					#ifndef OPENSSL_NO_ECDSA
 | 
				
			||||||
 | 
									if (CApkey->type == EVP_PKEY_ECDSA)
 | 
				
			||||||
 | 
										digest = EVP_ecdsa();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
				
 | 
									
 | 
				
			||||||
				assert(need_rand);
 | 
									assert(need_rand);
 | 
				
			||||||
				if (!x509_certify(ctx,CAfile,digest,x,xca,
 | 
									if (!x509_certify(ctx,CAfile,digest,x,xca,
 | 
				
			||||||
@@ -946,17 +916,17 @@ bad:
 | 
				
			|||||||
				else
 | 
									else
 | 
				
			||||||
					{
 | 
										{
 | 
				
			||||||
					pk=load_key(bio_err,
 | 
										pk=load_key(bio_err,
 | 
				
			||||||
						keyfile, FORMAT_PEM, 0,
 | 
											keyfile,FORMAT_PEM, passin, e,
 | 
				
			||||||
						passin, e, "request key");
 | 
											"request key");
 | 
				
			||||||
					if (pk == NULL) goto end;
 | 
										if (pk == NULL) goto end;
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				BIO_printf(bio_err,"Generating certificate request\n");
 | 
									BIO_printf(bio_err,"Generating certificate request\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					 | 
				
			||||||
		                if (pk->type == EVP_PKEY_DSA)
 | 
							                if (pk->type == EVP_PKEY_DSA)
 | 
				
			||||||
		                        digest=EVP_dss1();
 | 
							                        digest=EVP_dss1();
 | 
				
			||||||
#endif
 | 
									else if (pk->type == EVP_PKEY_ECDSA)
 | 
				
			||||||
 | 
										digest=EVP_ecdsa();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				rq=X509_to_X509_REQ(x,pk,digest);
 | 
									rq=X509_to_X509_REQ(x,pk,digest);
 | 
				
			||||||
				EVP_PKEY_free(pk);
 | 
									EVP_PKEY_free(pk);
 | 
				
			||||||
@@ -981,9 +951,9 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (checkend)
 | 
						if (checkend)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		time_t tcheck=time(NULL) + checkoffset;
 | 
							time_t tnow=time(NULL);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (X509_cmp_time(X509_get_notAfter(x), &tcheck) < 0)
 | 
							if (ASN1_UTCTIME_cmp_time_t(X509_get_notAfter(x), tnow+checkoffset) == -1)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(out,"Certificate will expire\n");
 | 
								BIO_printf(out,"Certificate will expire\n");
 | 
				
			||||||
			ret=1;
 | 
								ret=1;
 | 
				
			||||||
@@ -1053,47 +1023,108 @@ end:
 | 
				
			|||||||
	sk_ASN1_OBJECT_pop_free(reject, ASN1_OBJECT_free);
 | 
						sk_ASN1_OBJECT_pop_free(reject, ASN1_OBJECT_free);
 | 
				
			||||||
	if (passin) OPENSSL_free(passin);
 | 
						if (passin) OPENSSL_free(passin);
 | 
				
			||||||
	apps_shutdown();
 | 
						apps_shutdown();
 | 
				
			||||||
	OPENSSL_EXIT(ret);
 | 
						EXIT(ret);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static ASN1_INTEGER *x509_load_serial(char *CAfile, char *serialfile, int create)
 | 
					static ASN1_INTEGER *load_serial(char *CAfile, char *serialfile, int create)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	char *buf = NULL, *p;
 | 
						char *buf = NULL, *p;
 | 
				
			||||||
	ASN1_INTEGER *bs = NULL;
 | 
						MS_STATIC char buf2[1024];
 | 
				
			||||||
 | 
						ASN1_INTEGER *bs = NULL, *bs2 = NULL;
 | 
				
			||||||
 | 
						BIO *io = NULL;
 | 
				
			||||||
	BIGNUM *serial = NULL;
 | 
						BIGNUM *serial = NULL;
 | 
				
			||||||
	size_t len;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	len = ((serialfile == NULL)
 | 
						buf=OPENSSL_malloc( ((serialfile == NULL)
 | 
				
			||||||
		?(strlen(CAfile)+strlen(POSTFIX)+1)
 | 
								?(strlen(CAfile)+strlen(POSTFIX)+1)
 | 
				
			||||||
		:(strlen(serialfile)))+1;
 | 
								:(strlen(serialfile)))+1);
 | 
				
			||||||
	buf=OPENSSL_malloc(len);
 | 
					 | 
				
			||||||
	if (buf == NULL) { BIO_printf(bio_err,"out of mem\n"); goto end; }
 | 
						if (buf == NULL) { BIO_printf(bio_err,"out of mem\n"); goto end; }
 | 
				
			||||||
	if (serialfile == NULL)
 | 
						if (serialfile == NULL)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BUF_strlcpy(buf,CAfile,len);
 | 
							strcpy(buf,CAfile);
 | 
				
			||||||
		for (p=buf; *p; p++)
 | 
							for (p=buf; *p; p++)
 | 
				
			||||||
			if (*p == '.')
 | 
								if (*p == '.')
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
				*p='\0';
 | 
									*p='\0';
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
		BUF_strlcat(buf,POSTFIX,len);
 | 
							strcat(buf,POSTFIX);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		BUF_strlcpy(buf,serialfile,len);
 | 
							strcpy(buf,serialfile);
 | 
				
			||||||
 | 
						serial=BN_new();
 | 
				
			||||||
 | 
						bs=ASN1_INTEGER_new();
 | 
				
			||||||
 | 
						if ((serial == NULL) || (bs == NULL))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	serial = load_serial(buf, create, NULL);
 | 
						io=BIO_new(BIO_s_file());
 | 
				
			||||||
	if (serial == NULL) goto end;
 | 
						if (io == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (BIO_read_filename(io,buf) <= 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							if (!create)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								perror(buf);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1_INTEGER_set(bs,1);
 | 
				
			||||||
 | 
								BN_one(serial);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						else 
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							if (!a2i_ASN1_INTEGER(io,bs,buf2,1024))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"unable to load serial number from %s\n",buf);
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								serial=BN_bin2bn(bs->data,bs->length,serial);
 | 
				
			||||||
 | 
								if (serial == NULL)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
									BIO_printf(bio_err,"error converting bin 2 bn");
 | 
				
			||||||
 | 
									goto end;
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!BN_add_word(serial,1))
 | 
						if (!BN_add_word(serial,1))
 | 
				
			||||||
		{ BIO_printf(bio_err,"add_word failure\n"); goto end; }
 | 
							{ BIO_printf(bio_err,"add_word failure\n"); goto end; }
 | 
				
			||||||
 | 
						if (!(bs2 = BN_to_ASN1_INTEGER(serial, NULL)))
 | 
				
			||||||
 | 
							{ BIO_printf(bio_err,"error converting bn 2 asn1_integer\n"); goto end; }
 | 
				
			||||||
 | 
						if (BIO_write_filename(io,buf) <= 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"error attempting to write serial number file\n");
 | 
				
			||||||
 | 
							perror(buf);
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						i2a_ASN1_INTEGER(io,bs2);
 | 
				
			||||||
 | 
						BIO_puts(io,"\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!save_serial(buf, NULL, serial, &bs)) goto end;
 | 
						BIO_free(io);
 | 
				
			||||||
 | 
					 | 
				
			||||||
 end:
 | 
					 | 
				
			||||||
	if (buf) OPENSSL_free(buf);
 | 
						if (buf) OPENSSL_free(buf);
 | 
				
			||||||
 | 
						ASN1_INTEGER_free(bs2);
 | 
				
			||||||
	BN_free(serial);
 | 
						BN_free(serial);
 | 
				
			||||||
 | 
						io=NULL;
 | 
				
			||||||
	return bs;
 | 
						return bs;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						end:
 | 
				
			||||||
 | 
						if (buf) OPENSSL_free(buf);
 | 
				
			||||||
 | 
						BIO_free(io);
 | 
				
			||||||
 | 
						ASN1_INTEGER_free(bs);
 | 
				
			||||||
 | 
						BN_free(serial);
 | 
				
			||||||
 | 
						return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
					static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
				
			||||||
@@ -1115,10 +1146,10 @@ static int x509_certify(X509_STORE *ctx, char *CAfile, const EVP_MD *digest,
 | 
				
			|||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (sno) bs = sno;
 | 
						if (sno) bs = sno;
 | 
				
			||||||
	else if (!(bs = x509_load_serial(CAfile, serialfile, create)))
 | 
						else if (!(bs = load_serial(CAfile, serialfile, create)))
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*	if (!X509_STORE_add_cert(ctx,x)) goto end;*/
 | 
						if (!X509_STORE_add_cert(ctx,x)) goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* NOTE: this certificate can/should be self signed, unless it was
 | 
						/* NOTE: this certificate can/should be self signed, unless it was
 | 
				
			||||||
	 * a certificate request in which case it is not. */
 | 
						 * a certificate request in which case it is not. */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -29,7 +29,7 @@ RC4-MD5, but a re-connect tries to use DES-CBC-SHA.  So netscape, when
 | 
				
			|||||||
doing a re-connect, always takes the first cipher in the cipher list.
 | 
					doing a re-connect, always takes the first cipher in the cipher list.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If we accept a netscape connection, demand a client cert, have a
 | 
					If we accept a netscape connection, demand a client cert, have a
 | 
				
			||||||
non-self-signed CA which does not have it's CA in netscape, and the
 | 
					non-self-sighed CA which does not have it's CA in netscape, and the
 | 
				
			||||||
browser has a cert, it will crash/hang.  Works for 3.x and 4.xbeta
 | 
					browser has a cert, it will crash/hang.  Works for 3.x and 4.xbeta
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Netscape browsers do not really notice the server sending a
 | 
					Netscape browsers do not really notice the server sending a
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										59
									
								
								certs/ICE-CA.pem
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								certs/ICE-CA.pem
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,59 @@
 | 
				
			|||||||
 | 
					Certificate:
 | 
				
			||||||
 | 
					    Data:
 | 
				
			||||||
 | 
					        Version: 3 (0x2)
 | 
				
			||||||
 | 
					        Serial Number: 1 (0x1)
 | 
				
			||||||
 | 
					        Signature Algorithm: md5WithRSAEncryption
 | 
				
			||||||
 | 
					        Issuer: O=European ICE-TEL project, OU=V3-Certification Authority
 | 
				
			||||||
 | 
					        Validity
 | 
				
			||||||
 | 
					            Not Before: Apr  2 17:35:53 1997 GMT
 | 
				
			||||||
 | 
					            Not After : Apr  2 17:35:53 1998 GMT
 | 
				
			||||||
 | 
					        Subject: O=European ICE-TEL project, OU=V3-Certification Authority, L=Darmstadt
 | 
				
			||||||
 | 
					        Subject Public Key Info:
 | 
				
			||||||
 | 
					            Public Key Algorithm: rsa
 | 
				
			||||||
 | 
					            RSA Public Key: (512 bit)
 | 
				
			||||||
 | 
					                Modulus (512 bit):
 | 
				
			||||||
 | 
					                    00:82:75:ba:f6:d1:60:b5:f9:15:b3:6a:dd:29:8f:
 | 
				
			||||||
 | 
					                    8b:a4:6f:1a:88:e0:50:43:40:0b:79:41:d5:d3:16:
 | 
				
			||||||
 | 
					                    44:7d:74:65:17:42:06:52:0b:e9:50:c8:10:cd:24:
 | 
				
			||||||
 | 
					                    e2:ae:8d:22:30:73:e6:b4:b7:93:1f:e5:6e:a2:ae:
 | 
				
			||||||
 | 
					                    49:11:a5:c9:45
 | 
				
			||||||
 | 
					                Exponent: 65537 (0x10001)
 | 
				
			||||||
 | 
					        X509v3 extensions:
 | 
				
			||||||
 | 
					            X509v3 Authority Key Identifier: 
 | 
				
			||||||
 | 
					                0.........z.."p......e..
 | 
				
			||||||
 | 
					            X509v3 Subject Key Identifier: 
 | 
				
			||||||
 | 
					                ..~r..:..B.44fu......3
 | 
				
			||||||
 | 
					            X509v3 Key Usage: critical
 | 
				
			||||||
 | 
					                ....
 | 
				
			||||||
 | 
					            X509v3 Certificate Policies: critical
 | 
				
			||||||
 | 
					                0.0...*...
 | 
				
			||||||
 | 
					            X509v3 Subject Alternative Name: 
 | 
				
			||||||
 | 
					                0!..secude-support@darmstadt.gmd.de
 | 
				
			||||||
 | 
					            X509v3 Issuer Alternative Name: 
 | 
				
			||||||
 | 
					                0I..ice-tel-ca@darmstadt.gmd.de.*http://www.darmstadt.gmd.de/ice-tel/euroca
 | 
				
			||||||
 | 
					            X509v3 Basic Constraints: critical
 | 
				
			||||||
 | 
					                0....
 | 
				
			||||||
 | 
					            X509v3 CRL Distribution Points: 
 | 
				
			||||||
 | 
					                0200...,.*http://www.darmstadt.gmd.de/ice-tel/euroca
 | 
				
			||||||
 | 
					    Signature Algorithm: md5WithRSAEncryption
 | 
				
			||||||
 | 
					        17:a2:88:b7:99:5a:05:41:e4:13:34:67:e6:1f:3e:26:ec:4b:
 | 
				
			||||||
 | 
					        69:f9:3e:28:22:be:9d:1c:ab:41:6f:0c:00:85:fe:45:74:f6:
 | 
				
			||||||
 | 
					        98:f0:ce:9b:65:53:4a:50:42:c7:d4:92:bd:d7:a2:a8:3d:98:
 | 
				
			||||||
 | 
					        88:73:cd:60:28:79:a3:fc:48:7a
 | 
				
			||||||
 | 
					-----BEGIN CERTIFICATE-----
 | 
				
			||||||
 | 
					MIICzDCCAnagAwIBAgIBATANBgkqhkiG9w0BAQQFADBIMSEwHwYDVQQKExhFdXJv
 | 
				
			||||||
 | 
					cGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24g
 | 
				
			||||||
 | 
					QXV0aG9yaXR5MB4XDTk3MDQwMjE3MzU1M1oXDTk4MDQwMjE3MzU1M1owXDEhMB8G
 | 
				
			||||||
 | 
					A1UEChMYRXVyb3BlYW4gSUNFLVRFTCBwcm9qZWN0MSMwIQYDVQQLExpWMy1DZXJ0
 | 
				
			||||||
 | 
					aWZpY2F0aW9uIEF1dGhvcml0eTESMBAGA1UEBxMJRGFybXN0YWR0MFkwCgYEVQgB
 | 
				
			||||||
 | 
					AQICAgADSwAwSAJBAIJ1uvbRYLX5FbNq3SmPi6RvGojgUENAC3lB1dMWRH10ZRdC
 | 
				
			||||||
 | 
					BlIL6VDIEM0k4q6NIjBz5rS3kx/lbqKuSRGlyUUCAwEAAaOCATgwggE0MB8GA1Ud
 | 
				
			||||||
 | 
					IwQYMBaAFIr3yNUOx3ro1yJw4AuJ1bbsZbzPMB0GA1UdDgQWBBR+cvL4OoacQog0
 | 
				
			||||||
 | 
					NGZ1w9T80aIRMzAOBgNVHQ8BAf8EBAMCAfYwFAYDVR0gAQH/BAowCDAGBgQqAwQF
 | 
				
			||||||
 | 
					MCoGA1UdEQQjMCGBH3NlY3VkZS1zdXBwb3J0QGRhcm1zdGFkdC5nbWQuZGUwUgYD
 | 
				
			||||||
 | 
					VR0SBEswSYEbaWNlLXRlbC1jYUBkYXJtc3RhZHQuZ21kLmRlhipodHRwOi8vd3d3
 | 
				
			||||||
 | 
					LmRhcm1zdGFkdC5nbWQuZGUvaWNlLXRlbC9ldXJvY2EwDwYDVR0TAQH/BAUwAwEB
 | 
				
			||||||
 | 
					/zA7BgNVHR8ENDAyMDCgLqAshipodHRwOi8vd3d3LmRhcm1zdGFkdC5nbWQuZGUv
 | 
				
			||||||
 | 
					aWNlLXRlbC9ldXJvY2EwDQYJKoZIhvcNAQEEBQADQQAXooi3mVoFQeQTNGfmHz4m
 | 
				
			||||||
 | 
					7Etp+T4oIr6dHKtBbwwAhf5FdPaY8M6bZVNKUELH1JK916KoPZiIc81gKHmj/Eh6
 | 
				
			||||||
 | 
					-----END CERTIFICATE-----
 | 
				
			||||||
							
								
								
									
										48
									
								
								certs/ICE-root.pem
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								certs/ICE-root.pem
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,48 @@
 | 
				
			|||||||
 | 
					Certificate:
 | 
				
			||||||
 | 
					    Data:
 | 
				
			||||||
 | 
					        Version: 3 (0x2)
 | 
				
			||||||
 | 
					        Serial Number: 0 (0x0)
 | 
				
			||||||
 | 
					        Signature Algorithm: md5WithRSAEncryption
 | 
				
			||||||
 | 
					        Issuer: O=European ICE-TEL project, OU=V3-Certification Authority
 | 
				
			||||||
 | 
					        Validity
 | 
				
			||||||
 | 
					            Not Before: Apr  2 17:33:36 1997 GMT
 | 
				
			||||||
 | 
					            Not After : Apr  2 17:33:36 1998 GMT
 | 
				
			||||||
 | 
					        Subject: O=European ICE-TEL project, OU=V3-Certification Authority
 | 
				
			||||||
 | 
					        Subject Public Key Info:
 | 
				
			||||||
 | 
					            Public Key Algorithm: rsa
 | 
				
			||||||
 | 
					            RSA Public Key: (512 bit)
 | 
				
			||||||
 | 
					                Modulus (512 bit):
 | 
				
			||||||
 | 
					                    00:80:3e:eb:ae:47:a9:fe:10:54:0b:81:8b:9c:2b:
 | 
				
			||||||
 | 
					                    82:ab:3a:61:36:65:8b:f3:73:9f:ac:ac:7a:15:a7:
 | 
				
			||||||
 | 
					                    13:8f:b4:c4:ba:a3:0f:bc:a5:58:8d:cc:b1:93:31:
 | 
				
			||||||
 | 
					                    9e:81:9e:8c:19:61:86:fa:52:73:54:d1:97:76:22:
 | 
				
			||||||
 | 
					                    e7:c7:9f:41:cd
 | 
				
			||||||
 | 
					                Exponent: 65537 (0x10001)
 | 
				
			||||||
 | 
					        X509v3 extensions:
 | 
				
			||||||
 | 
					            X509v3 Subject Key Identifier: 
 | 
				
			||||||
 | 
					                ........z.."p......e..
 | 
				
			||||||
 | 
					            X509v3 Key Usage: critical
 | 
				
			||||||
 | 
					                ....
 | 
				
			||||||
 | 
					            X509v3 Subject Alternative Name: 
 | 
				
			||||||
 | 
					                0I.*http://www.darmstadt.gmd.de/ice-tel/euroca..ice-tel-ca@darmstadt.gmd.de
 | 
				
			||||||
 | 
					            X509v3 Basic Constraints: critical
 | 
				
			||||||
 | 
					                0....
 | 
				
			||||||
 | 
					    Signature Algorithm: md5WithRSAEncryption
 | 
				
			||||||
 | 
					        76:69:61:db:b7:cf:8b:06:9e:d8:8c:96:53:d2:4d:a8:23:a6:
 | 
				
			||||||
 | 
					        03:44:e8:8f:24:a5:c0:84:a8:4b:77:d4:2d:2b:7d:37:91:67:
 | 
				
			||||||
 | 
					        f2:2c:ce:02:31:4c:6b:cc:ce:f2:68:a6:11:11:ab:7d:88:b8:
 | 
				
			||||||
 | 
					        7e:22:9f:25:06:60:bd:79:30:3d
 | 
				
			||||||
 | 
					-----BEGIN CERTIFICATE-----
 | 
				
			||||||
 | 
					MIICFjCCAcCgAwIBAgIBADANBgkqhkiG9w0BAQQFADBIMSEwHwYDVQQKExhFdXJv
 | 
				
			||||||
 | 
					cGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24g
 | 
				
			||||||
 | 
					QXV0aG9yaXR5MB4XDTk3MDQwMjE3MzMzNloXDTk4MDQwMjE3MzMzNlowSDEhMB8G
 | 
				
			||||||
 | 
					A1UEChMYRXVyb3BlYW4gSUNFLVRFTCBwcm9qZWN0MSMwIQYDVQQLExpWMy1DZXJ0
 | 
				
			||||||
 | 
					aWZpY2F0aW9uIEF1dGhvcml0eTBZMAoGBFUIAQECAgIAA0sAMEgCQQCAPuuuR6n+
 | 
				
			||||||
 | 
					EFQLgYucK4KrOmE2ZYvzc5+srHoVpxOPtMS6ow+8pViNzLGTMZ6BnowZYYb6UnNU
 | 
				
			||||||
 | 
					0Zd2IufHn0HNAgMBAAGjgZcwgZQwHQYDVR0OBBYEFIr3yNUOx3ro1yJw4AuJ1bbs
 | 
				
			||||||
 | 
					ZbzPMA4GA1UdDwEB/wQEAwIB9jBSBgNVHREESzBJhipodHRwOi8vd3d3LmRhcm1z
 | 
				
			||||||
 | 
					dGFkdC5nbWQuZGUvaWNlLXRlbC9ldXJvY2GBG2ljZS10ZWwtY2FAZGFybXN0YWR0
 | 
				
			||||||
 | 
					LmdtZC5kZTAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBBAUAA0EAdmlh27fP
 | 
				
			||||||
 | 
					iwae2IyWU9JNqCOmA0TojySlwISoS3fULSt9N5Fn8izOAjFMa8zO8mimERGrfYi4
 | 
				
			||||||
 | 
					fiKfJQZgvXkwPQ==
 | 
				
			||||||
 | 
					-----END CERTIFICATE-----
 | 
				
			||||||
							
								
								
									
										63
									
								
								certs/ICE-user.pem
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								certs/ICE-user.pem
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,63 @@
 | 
				
			|||||||
 | 
					Certificate:
 | 
				
			||||||
 | 
					    Data:
 | 
				
			||||||
 | 
					        Version: 3 (0x2)
 | 
				
			||||||
 | 
					        Serial Number: 1 (0x1)
 | 
				
			||||||
 | 
					        Signature Algorithm: md5WithRSAEncryption
 | 
				
			||||||
 | 
					        Issuer: O=European ICE-TEL project, OU=V3-Certification Authority, L=Darmstadt
 | 
				
			||||||
 | 
					        Validity
 | 
				
			||||||
 | 
					            Not Before: Apr  2 17:35:59 1997 GMT
 | 
				
			||||||
 | 
					            Not After : Apr  2 17:35:59 1998 GMT
 | 
				
			||||||
 | 
					        Subject: O=European ICE-TEL project, OU=V3-Certification Authority, L=Darmstadt, CN=USER
 | 
				
			||||||
 | 
					        Subject Public Key Info:
 | 
				
			||||||
 | 
					            Public Key Algorithm: rsa
 | 
				
			||||||
 | 
					            RSA Public Key: (512 bit)
 | 
				
			||||||
 | 
					                Modulus (512 bit):
 | 
				
			||||||
 | 
					                    00:a8:a8:53:63:49:1b:93:c3:c3:0b:6c:88:11:55:
 | 
				
			||||||
 | 
					                    de:7e:6a:e2:f9:52:a0:dc:69:25:c4:c8:bf:55:e1:
 | 
				
			||||||
 | 
					                    31:a8:ce:e4:a9:29:85:99:8a:15:9a:de:f6:2f:e1:
 | 
				
			||||||
 | 
					                    b4:50:5f:5e:04:75:a6:f4:76:dc:3c:0e:39:dc:3a:
 | 
				
			||||||
 | 
					                    be:3e:a4:61:8b
 | 
				
			||||||
 | 
					                Exponent: 65537 (0x10001)
 | 
				
			||||||
 | 
					        X509v3 extensions:
 | 
				
			||||||
 | 
					            X509v3 Authority Key Identifier: 
 | 
				
			||||||
 | 
					                0...~r..:..B.44fu......3
 | 
				
			||||||
 | 
					            X509v3 Subject Key Identifier: 
 | 
				
			||||||
 | 
					                ...... .*...1.*.......
 | 
				
			||||||
 | 
					            X509v3 Key Usage: critical
 | 
				
			||||||
 | 
					                ....
 | 
				
			||||||
 | 
					            X509v3 Certificate Policies: critical
 | 
				
			||||||
 | 
					                0.0...*...0.......
 | 
				
			||||||
 | 
					            X509v3 Subject Alternative Name: 
 | 
				
			||||||
 | 
					                0:..user@darmstadt.gmd.de.!http://www.darmstadt.gmd.de/~user
 | 
				
			||||||
 | 
					            X509v3 Issuer Alternative Name: 
 | 
				
			||||||
 | 
					                0....gmdca@gmd.de..http://www.gmd.de..saturn.darmstadt.gmd.de.\1!0...U.
 | 
				
			||||||
 | 
					..European ICE-TEL project1#0!..U....V3-Certification Authority1.0...U....Darmstadt..141.12.62.26
 | 
				
			||||||
 | 
					            X509v3 Basic Constraints: critical
 | 
				
			||||||
 | 
					                0.
 | 
				
			||||||
 | 
					            X509v3 CRL Distribution Points: 
 | 
				
			||||||
 | 
					                0.0.......gmdca@gmd.de
 | 
				
			||||||
 | 
					    Signature Algorithm: md5WithRSAEncryption
 | 
				
			||||||
 | 
					        69:0c:e1:b7:a7:f2:d8:fb:e8:69:c0:13:cd:37:ad:21:06:22:
 | 
				
			||||||
 | 
					        4d:e8:c6:db:f1:04:0b:b7:e0:b3:d6:0c:81:03:ce:c3:6a:3e:
 | 
				
			||||||
 | 
					        c7:e7:24:24:a4:92:64:c2:83:83:06:42:53:0e:6f:09:1e:84:
 | 
				
			||||||
 | 
					        9a:f7:6f:63:9b:94:99:83:d6:a4
 | 
				
			||||||
 | 
					-----BEGIN CERTIFICATE-----
 | 
				
			||||||
 | 
					MIIDTzCCAvmgAwIBAgIBATANBgkqhkiG9w0BAQQFADBcMSEwHwYDVQQKExhFdXJv
 | 
				
			||||||
 | 
					cGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24g
 | 
				
			||||||
 | 
					QXV0aG9yaXR5MRIwEAYDVQQHEwlEYXJtc3RhZHQwHhcNOTcwNDAyMTczNTU5WhcN
 | 
				
			||||||
 | 
					OTgwNDAyMTczNTU5WjBrMSEwHwYDVQQKExhFdXJvcGVhbiBJQ0UtVEVMIHByb2pl
 | 
				
			||||||
 | 
					Y3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24gQXV0aG9yaXR5MRIwEAYDVQQH
 | 
				
			||||||
 | 
					EwlEYXJtc3RhZHQxDTALBgNVBAMTBFVTRVIwWTAKBgRVCAEBAgICAANLADBIAkEA
 | 
				
			||||||
 | 
					qKhTY0kbk8PDC2yIEVXefmri+VKg3GklxMi/VeExqM7kqSmFmYoVmt72L+G0UF9e
 | 
				
			||||||
 | 
					BHWm9HbcPA453Dq+PqRhiwIDAQABo4IBmDCCAZQwHwYDVR0jBBgwFoAUfnLy+DqG
 | 
				
			||||||
 | 
					nEKINDRmdcPU/NGiETMwHQYDVR0OBBYEFJfc4B8gjSoRmLUx4Sq/ucIYiMrPMA4G
 | 
				
			||||||
 | 
					A1UdDwEB/wQEAwIB8DAcBgNVHSABAf8EEjAQMAYGBCoDBAUwBgYECQgHBjBDBgNV
 | 
				
			||||||
 | 
					HREEPDA6gRV1c2VyQGRhcm1zdGFkdC5nbWQuZGWGIWh0dHA6Ly93d3cuZGFybXN0
 | 
				
			||||||
 | 
					YWR0LmdtZC5kZS9+dXNlcjCBsQYDVR0SBIGpMIGmgQxnbWRjYUBnbWQuZGWGEWh0
 | 
				
			||||||
 | 
					dHA6Ly93d3cuZ21kLmRlghdzYXR1cm4uZGFybXN0YWR0LmdtZC5kZaRcMSEwHwYD
 | 
				
			||||||
 | 
					VQQKExhFdXJvcGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRp
 | 
				
			||||||
 | 
					ZmljYXRpb24gQXV0aG9yaXR5MRIwEAYDVQQHEwlEYXJtc3RhZHSHDDE0MS4xMi42
 | 
				
			||||||
 | 
					Mi4yNjAMBgNVHRMBAf8EAjAAMB0GA1UdHwQWMBQwEqAQoA6BDGdtZGNhQGdtZC5k
 | 
				
			||||||
 | 
					ZTANBgkqhkiG9w0BAQQFAANBAGkM4ben8tj76GnAE803rSEGIk3oxtvxBAu34LPW
 | 
				
			||||||
 | 
					DIEDzsNqPsfnJCSkkmTCg4MGQlMObwkehJr3b2OblJmD1qQ=
 | 
				
			||||||
 | 
					-----END CERTIFICATE-----
 | 
				
			||||||
							
								
								
									
										9
									
								
								certs/ICE.crl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								certs/ICE.crl
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					-----BEGIN X509 CRL-----
 | 
				
			||||||
 | 
					MIIBNDCBnjANBgkqhkiG9w0BAQIFADBFMSEwHwYDVQQKExhFdXJvcGVhbiBJQ0Ut
 | 
				
			||||||
 | 
					VEVMIFByb2plY3QxIDAeBgNVBAsTF0NlcnRpZmljYXRpb24gQXV0aG9yaXR5Fw05
 | 
				
			||||||
 | 
					NzA2MDkxNDQyNDNaFw05NzA3MDkxNDQyNDNaMCgwEgIBChcNOTcwMzAzMTQ0MjU0
 | 
				
			||||||
 | 
					WjASAgEJFw05NjEwMDIxMjI5MjdaMA0GCSqGSIb3DQEBAgUAA4GBAH4vgWo2Tej/
 | 
				
			||||||
 | 
					i7kbiw4Imd30If91iosjClNpBFwvwUDBclPEeMuYimHbLOk4H8Nofc0fw11+U/IO
 | 
				
			||||||
 | 
					KSNouUDcqG7B64oY7c4SXKn+i1MWOb5OJiWeodX3TehHjBlyWzoNMWCnYA8XqFP1
 | 
				
			||||||
 | 
					mOKp8Jla1BibEZf14+/HqCi2hnZUiEXh
 | 
				
			||||||
 | 
					-----END X509 CRL-----
 | 
				
			||||||
@@ -1,22 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIDpDCCAoygAwIBAgIBATANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEc
 | 
					 | 
				
			||||||
MBoGA1UEChMTQW1lcmljYSBPbmxpbmUgSW5jLjE2MDQGA1UEAxMtQW1lcmljYSBP
 | 
					 | 
				
			||||||
bmxpbmUgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAxMB4XDTAyMDUyODA2
 | 
					 | 
				
			||||||
MDAwMFoXDTM3MTExOTIwNDMwMFowYzELMAkGA1UEBhMCVVMxHDAaBgNVBAoTE0Ft
 | 
					 | 
				
			||||||
ZXJpY2EgT25saW5lIEluYy4xNjA0BgNVBAMTLUFtZXJpY2EgT25saW5lIFJvb3Qg
 | 
					 | 
				
			||||||
Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMTCCASIwDQYJKoZIhvcNAQEBBQADggEP
 | 
					 | 
				
			||||||
ADCCAQoCggEBAKgv6KRpBgNHw+kqmP8ZonCaxlCyfqXfaE0bfA+2l2h9LaaLl+lk
 | 
					 | 
				
			||||||
hsmj76CGv2BlnEtUiMJIxUo5vxTjWVXlGbR0yLQFOVwWpeKVBeASrlmLojNoWBym
 | 
					 | 
				
			||||||
1BW32J/X3HGrfpq/m44zDyL9Hy7nBzbvYjnF3cu6JRQj3gzGPTzOggjmZj7aUTsW
 | 
					 | 
				
			||||||
OqMFf6Dch9Wc/HKpoH145LcxVR5lu9RhsCFg7RAycsWSJR74kEoYeEfffjA3PlAb
 | 
					 | 
				
			||||||
2xzTa5qGUwew76wGePiEmf4hjUyAtgyC9mZweRrTT6PP8c9GsEsPPt2IYriMqQko
 | 
					 | 
				
			||||||
O3rHl+Ee5fSfwMCuJKDIodkP1nsmgmkyPacCAwEAAaNjMGEwDwYDVR0TAQH/BAUw
 | 
					 | 
				
			||||||
AwEB/zAdBgNVHQ4EFgQUAK3Zo/Z59m50qX8zPYEX10zPM94wHwYDVR0jBBgwFoAU
 | 
					 | 
				
			||||||
AK3Zo/Z59m50qX8zPYEX10zPM94wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEB
 | 
					 | 
				
			||||||
BQUAA4IBAQB8itEfGDeC4Liwo+1WlchiYZwFos3CYiZhzRAW18y0ZTTQEYqtqKkF
 | 
					 | 
				
			||||||
Zu90821fnZmv9ov761KyBZiibyrFVL0lvV+uyIbqRizBs73B6UlwGBaXCBOMIOAb
 | 
					 | 
				
			||||||
LjpHyx7kADCVW/RFo8AasAFOq73AI25jP4BKxQft3OJvx8Fi8eNy1gTIdGcL+oir
 | 
					 | 
				
			||||||
oQHIb/AUr9KZzVGTfu0uOMe9zkZQPXLjeSWdm4grECDdpbgyn43gKd8hdIaC2y+C
 | 
					 | 
				
			||||||
MMbHNYaz+ZZfRtsMRf3zUMNvxsNIrUam4SdHCh0Om7bCd39j8uB9Gr784N/Xx6ds
 | 
					 | 
				
			||||||
sPmuujz9dLQR6FgNgLzTqIA6me11zEZ7
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,33 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIFpDCCA4ygAwIBAgIBATANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEc
 | 
					 | 
				
			||||||
MBoGA1UEChMTQW1lcmljYSBPbmxpbmUgSW5jLjE2MDQGA1UEAxMtQW1lcmljYSBP
 | 
					 | 
				
			||||||
bmxpbmUgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAyMB4XDTAyMDUyODA2
 | 
					 | 
				
			||||||
MDAwMFoXDTM3MDkyOTE0MDgwMFowYzELMAkGA1UEBhMCVVMxHDAaBgNVBAoTE0Ft
 | 
					 | 
				
			||||||
ZXJpY2EgT25saW5lIEluYy4xNjA0BgNVBAMTLUFtZXJpY2EgT25saW5lIFJvb3Qg
 | 
					 | 
				
			||||||
Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIP
 | 
					 | 
				
			||||||
ADCCAgoCggIBAMxBRR3pPU0Q9oyxQcngXssNt79Hc9PwVU3dxgz6sWYFas14tNwC
 | 
					 | 
				
			||||||
206B89enfHG8dWOgXeMHDEjsJcQDIPT/DjsS/5uN4cbVG7RtIuOx238hZK+GvFci
 | 
					 | 
				
			||||||
KtZHgVdEglZTvYYUAQv8f3SkWq7xuhG1m1hagLQ3eAkzfDJHA1zEpYNI9FdWboE2
 | 
					 | 
				
			||||||
JxhP7JsowtS013wMPgwr38oE18aO6lhOqKSlGBxsRZijQdEt0sdtjRnxrXm3gT+9
 | 
					 | 
				
			||||||
BoInLRBYBbV4Bbkv2wxrkJB+FFk4u5QkE+XRnRTf04JNRvCAOVIyD+OEsnpD8l7e
 | 
					 | 
				
			||||||
Xz8d3eOyG6ChKiMDbi4BFYdcpnV1x5dhvt6G3NRI270qv0pV2uh9UPu0gBe4lL8B
 | 
					 | 
				
			||||||
PeraunzgWGcXuVjgiIZGZ2ydEEdYMtA1fHkqkKJaEBEjNa0vzORKW6fIJ/KD3l67
 | 
					 | 
				
			||||||
Xnfn6KVuY8INXWHQjNJsWiEOyiijzirplcdIz5ZvHZIlyMbGwcEMBawmxNJ10uEq
 | 
					 | 
				
			||||||
Z8A9W6Wa6897GqidFEXlD6CaZd4vKL3Ob5Rmg0gp2OpljK+T2WSfVVcmv2/LNzGZ
 | 
					 | 
				
			||||||
o2C7HK2JNDJiuEMhBnIMoVxtRsX6Kc8w3onccVvdtjc+31D1uAclJuW8tf48ArO3
 | 
					 | 
				
			||||||
+L5DwYcRlJ4jbBeKuIonDFRH8KmzwICMoCfrHRnjB453cMor9H124HhnAgMBAAGj
 | 
					 | 
				
			||||||
YzBhMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFE1FwWg4u3OpaaEg5+31IqEj
 | 
					 | 
				
			||||||
FNeeMB8GA1UdIwQYMBaAFE1FwWg4u3OpaaEg5+31IqEjFNeeMA4GA1UdDwEB/wQE
 | 
					 | 
				
			||||||
AwIBhjANBgkqhkiG9w0BAQUFAAOCAgEAZ2sGuV9FOypLM7PmG2tZTiLMubekJcmn
 | 
					 | 
				
			||||||
xPBUlgtk87FYT15R/LKXeydlwuXK5w0MJXti4/qftIe3RUavg6WXSIylvfEWK5t2
 | 
					 | 
				
			||||||
LHo1YGwRgJfMqZJS5ivmae2p+DYtLHe/YUjRYwu5W1LtGLBDQiKmsXeu3mnFzccc
 | 
					 | 
				
			||||||
obGlHBD7GL4acN3Bkku+KVqdPzW+5X1R+FXgJXUjhx5c3LqdsKyzadsXg8n33gy8
 | 
					 | 
				
			||||||
CNyRnqjQ1xU3c6U1uPx+xURABsPr+CKAXEfOAuMRn0T//ZoyzH1kUQ7rVyZ2OuMe
 | 
					 | 
				
			||||||
IjzCpjbdGe+n/BLzJsBZMYVMnNjP36TMzCmT/5RtdlwTCJfy7aULTd3oyWgOZtMA
 | 
					 | 
				
			||||||
DjMSW7yV5TKQqLPGbIOtd+6Lfn6xqavT4fG2wLHqiMDn05DpKJKUe2h7lyoKZy2F
 | 
					 | 
				
			||||||
AjgQ5ANh1NolNscIWC2hp1GvMApJ9aZphwctREZ2jirlmjvXGKL8nDgQzMY70rUX
 | 
					 | 
				
			||||||
Om/9riW99XJZZLF0KjhfGEzfz3EEWjbUvy+ZnOjZurGV5gJLIaFb1cFPj65pbVPb
 | 
					 | 
				
			||||||
AZO1XB4Y3WRayhgoPmMEEf0cjQAPuDffZ4qdZqkCapH/E8ovXYO8h5Ns3CRRFgQl
 | 
					 | 
				
			||||||
Zvqz2cK6Kb6aSDiCmfS/O0oxGfm/jiEzFMpPVF/7zvuPcX/9XhmgD0uRuMRUvAaw
 | 
					 | 
				
			||||||
RY8mkaKO/qk=
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,23 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIID5jCCAs6gAwIBAgIBATANBgkqhkiG9w0BAQUFADCBgzELMAkGA1UEBhMCVVMx
 | 
					 | 
				
			||||||
HTAbBgNVBAoTFEFPTCBUaW1lIFdhcm5lciBJbmMuMRwwGgYDVQQLExNBbWVyaWNh
 | 
					 | 
				
			||||||
IE9ubGluZSBJbmMuMTcwNQYDVQQDEy5BT0wgVGltZSBXYXJuZXIgUm9vdCBDZXJ0
 | 
					 | 
				
			||||||
aWZpY2F0aW9uIEF1dGhvcml0eSAxMB4XDTAyMDUyOTA2MDAwMFoXDTM3MTEyMDE1
 | 
					 | 
				
			||||||
MDMwMFowgYMxCzAJBgNVBAYTAlVTMR0wGwYDVQQKExRBT0wgVGltZSBXYXJuZXIg
 | 
					 | 
				
			||||||
SW5jLjEcMBoGA1UECxMTQW1lcmljYSBPbmxpbmUgSW5jLjE3MDUGA1UEAxMuQU9M
 | 
					 | 
				
			||||||
IFRpbWUgV2FybmVyIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMTCCASIw
 | 
					 | 
				
			||||||
DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJnej8Mlo2k06AX3dLm/WpcZuS+U
 | 
					 | 
				
			||||||
0pPlLYnKhHw/EEMbjIt8hFj4JHxIzyr9wBXZGH6EGhfT257XyuTZ16pYUYfw8ItI
 | 
					 | 
				
			||||||
TuLCxFlpMGK2MKKMCxGZYTVtfu/FsRkGIBKOQuHfD5YQUqjPnF+VFNivO3ULMSAf
 | 
					 | 
				
			||||||
RC+iYkGzuxgh28pxPIzstrkNn+9R7017EvILDOGsQI93f7DKeHEMXRZxcKLXwjqF
 | 
					 | 
				
			||||||
zQ6axOAAsNUl6twr5JQtOJyJQVdkKGUZHLZEtMgxa44Be3ZZJX8VHIQIfHNlIAqh
 | 
					 | 
				
			||||||
BC4aMqiaILGcLCFZ5/vP7nAtCMpjPiybkxlqpMKX/7eGV4iFbJ4VFitNLLMCAwEA
 | 
					 | 
				
			||||||
AaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUoTYwFsuGkABFgFOxj8jY
 | 
					 | 
				
			||||||
PXy+XxIwHwYDVR0jBBgwFoAUoTYwFsuGkABFgFOxj8jYPXy+XxIwDgYDVR0PAQH/
 | 
					 | 
				
			||||||
BAQDAgGGMA0GCSqGSIb3DQEBBQUAA4IBAQCKIBilvrMvtKaEAEAwKfq0FHNMeUWn
 | 
					 | 
				
			||||||
9nDg6H5kHgqVfGphwu9OH77/yZkfB2FK4V1Mza3u0FIy2VkyvNp5ctZ7CegCgTXT
 | 
					 | 
				
			||||||
Ct8RHcl5oIBN/lrXVtbtDyqvpxh1MwzqwWEFT2qaifKNuZ8u77BfWgDrvq2g+EQF
 | 
					 | 
				
			||||||
Z7zLBO+eZMXpyD8Fv8YvBxzDNnGGyjhmSs3WuEvGbKeXO/oTLW4jYYehY0KswsuX
 | 
					 | 
				
			||||||
n2Fozy1MBJ3XJU8KDk2QixhWqJNIV9xvrr2eZ1d3iVCzvhGbRWeDhhmH05i9CBoW
 | 
					 | 
				
			||||||
H1iCC+GWaQVLjuyDUTEH1dSf/1l7qG6Fz9NLqUmwX7A5KGgOc90lmt4S
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,34 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIF5jCCA86gAwIBAgIBATANBgkqhkiG9w0BAQUFADCBgzELMAkGA1UEBhMCVVMx
 | 
					 | 
				
			||||||
HTAbBgNVBAoTFEFPTCBUaW1lIFdhcm5lciBJbmMuMRwwGgYDVQQLExNBbWVyaWNh
 | 
					 | 
				
			||||||
IE9ubGluZSBJbmMuMTcwNQYDVQQDEy5BT0wgVGltZSBXYXJuZXIgUm9vdCBDZXJ0
 | 
					 | 
				
			||||||
aWZpY2F0aW9uIEF1dGhvcml0eSAyMB4XDTAyMDUyOTA2MDAwMFoXDTM3MDkyODIz
 | 
					 | 
				
			||||||
NDMwMFowgYMxCzAJBgNVBAYTAlVTMR0wGwYDVQQKExRBT0wgVGltZSBXYXJuZXIg
 | 
					 | 
				
			||||||
SW5jLjEcMBoGA1UECxMTQW1lcmljYSBPbmxpbmUgSW5jLjE3MDUGA1UEAxMuQU9M
 | 
					 | 
				
			||||||
IFRpbWUgV2FybmVyIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMjCCAiIw
 | 
					 | 
				
			||||||
DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBALQ3WggWmRToVbEbJGv8x4vmh6mJ
 | 
					 | 
				
			||||||
7ouZzU9AhqS2TcnZsdw8TQ2FTBVsRotSeJ/4I/1n9SQ6aF3Q92RhQVSji6UI0ilb
 | 
					 | 
				
			||||||
m2BPJoPRYxJWSXakFsKlnUWsi4SVqBax7J/qJBrvuVdcmiQhLE0OcR+mrF1FdAOY
 | 
					 | 
				
			||||||
xFSMFkpBd4aVdQxHAWZg/BXxD+r1FHjHDtdugRxev17nOirYlxcwfACtCJ0zr7iZ
 | 
					 | 
				
			||||||
YYCLqJV+FNwSbKTQ2O9ASQI2+W6p1h2WVgSysy0WVoaP2SBXgM1nEG2wTPDaRrbq
 | 
					 | 
				
			||||||
JS5Gr42whTg0ixQmgiusrpkLjhTXUr2eacOGAgvqdnUxCc4zGSGFQ+aJLZ8lN2fx
 | 
					 | 
				
			||||||
I2rSAG2X+Z/nKcrdH9cG6rjJuQkhn8g/BsXS6RJGAE57COtCPStIbp1n3UsC5ETz
 | 
					 | 
				
			||||||
kxmlJ85per5n0/xQpCyrw2u544BMzwVhSyvcG7mm0tCq9Stz+86QNZ8MUhy/XCFh
 | 
					 | 
				
			||||||
EVsVS6kkUfykXPcXnbDS+gfpj1bkGoxoigTTfFrjnqKhynFbotSg5ymFXQNoKk/S
 | 
					 | 
				
			||||||
Btc9+cMDLz9l+WceR0DTYw/j1Y75hauXTLPXJuuWCpTehTacyH+BCQJJKg71ZDIM
 | 
					 | 
				
			||||||
gtG6aoIbs0t0EfOMd9afv9w3pKdVBC/UMejTRrkDfNoSTllkt1ExMVCgyhwn2RAu
 | 
					 | 
				
			||||||
rda9EGYrw7AiShJbAgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYE
 | 
					 | 
				
			||||||
FE9pbQN+nZ8HGEO8txBO1b+pxCAoMB8GA1UdIwQYMBaAFE9pbQN+nZ8HGEO8txBO
 | 
					 | 
				
			||||||
1b+pxCAoMA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQUFAAOCAgEAO/Ouyugu
 | 
					 | 
				
			||||||
h4X7ZVnnrREUpVe8WJ8kEle7+z802u6teio0cnAxa8cZmIDJgt43d15Ui47y6mdP
 | 
					 | 
				
			||||||
yXSEkVYJ1eV6moG2gcKtNuTxVBFT8zRFASbI5Rq8NEQh3q0l/HYWdyGQgJhXnU7q
 | 
					 | 
				
			||||||
7C+qPBR7V8F+GBRn7iTGvboVsNIYvbdVgaxTwOjdaRITQrcCtQVBynlQboIOcXKT
 | 
					 | 
				
			||||||
RuidDV29rs4prWPVVRaAMCf/drr3uNZK49m1+VLQTkCpx+XCMseqdiThawVQ68W/
 | 
					 | 
				
			||||||
ClTluUI8JPu3B5wwn3la5uBAUhX0/Kr0VvlEl4ftDmVyXr4m+02kLQgH3thcoNyB
 | 
					 | 
				
			||||||
M5kYJRF3p+v9WAksmWsbivNSPxpNSGDxoPYzAlOL7SUJuA0t7Zdz7NeWH45gDtoQ
 | 
					 | 
				
			||||||
my8YJPamTQr5O8t1wswvziRpyQoijlmn94IM19drNZxDAGrElWe6nEXLuA4399xO
 | 
					 | 
				
			||||||
AU++CrYD062KRffaJ00psUjf5BHklka9bAI+1lHIlRcBFanyqqryvy9lG2/QuRqT
 | 
					 | 
				
			||||||
9Y41xICHPpQvZuTpqP9BnHAqTyo5GJUefvthATxRCC4oGKQWDzH9OmwjkyB24f0H
 | 
					 | 
				
			||||||
hdFbP9IcczLd+rn4jM8Ch3qaluTtT4mNU0OrDhPAARW0eTjb/G49nlG2uBOLZ8/5
 | 
					 | 
				
			||||||
fNkiHfZdxRwBL5joeiQYvITX+txyW/fBOmg=
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,39 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIG0zCCBbugAwIBAgIBADANBgkqhkiG9w0BAQUFADCBzDELMAkGA1UEBhMCQVQx
 | 
					 | 
				
			||||||
EDAOBgNVBAgTB0F1c3RyaWExDzANBgNVBAcTBlZpZW5uYTE6MDgGA1UEChMxQVJH
 | 
					 | 
				
			||||||
RSBEQVRFTiAtIEF1c3RyaWFuIFNvY2lldHkgZm9yIERhdGEgUHJvdGVjdGlvbjEl
 | 
					 | 
				
			||||||
MCMGA1UECxMcQS1DRVJUIENlcnRpZmljYXRpb24gU2VydmljZTEYMBYGA1UEAxMP
 | 
					 | 
				
			||||||
QS1DRVJUIEFEVkFOQ0VEMR0wGwYJKoZIhvcNAQkBFg5pbmZvQGEtY2VydC5hdDAe
 | 
					 | 
				
			||||||
Fw0wNDEwMjMxNDE0MTRaFw0xMTEwMjMxNDE0MTRaMIHMMQswCQYDVQQGEwJBVDEQ
 | 
					 | 
				
			||||||
MA4GA1UECBMHQXVzdHJpYTEPMA0GA1UEBxMGVmllbm5hMTowOAYDVQQKEzFBUkdF
 | 
					 | 
				
			||||||
IERBVEVOIC0gQXVzdHJpYW4gU29jaWV0eSBmb3IgRGF0YSBQcm90ZWN0aW9uMSUw
 | 
					 | 
				
			||||||
IwYDVQQLExxBLUNFUlQgQ2VydGlmaWNhdGlvbiBTZXJ2aWNlMRgwFgYDVQQDEw9B
 | 
					 | 
				
			||||||
LUNFUlQgQURWQU5DRUQxHTAbBgkqhkiG9w0BCQEWDmluZm9AYS1jZXJ0LmF0MIIB
 | 
					 | 
				
			||||||
IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA3euXIy+mnf6BYKbK+QH5k679
 | 
					 | 
				
			||||||
tUFqeT8jlZxMew8eNiHuw9KoxWBzL6KksK+5uK7Gatw+sbAYntEGE80P+Jg1hADM
 | 
					 | 
				
			||||||
e+Fr5V0bc6QS3gkVtfUCW/RIvfMM39oxvmqJmOgPnJU7H6+nmLtsq61tv9kVJi/2
 | 
					 | 
				
			||||||
4Y5wXW3odet72sF57EoG6s78w0BUVLNcMngS9bZZzmdG3/d6JbkGgoNF/8DcgCBJ
 | 
					 | 
				
			||||||
W/t0JrcIzyppXIOVtUzzOrrU86zuUgT3Rtkl5kjG7DEHpFb9H0fTOY1v8+gRoaO6
 | 
					 | 
				
			||||||
2gA0PCiysgVZjwgVeYe3KAg11nznyleDv198uK3Dc1oXIGYjJx2FpKWUvAuAEwID
 | 
					 | 
				
			||||||
AQABo4ICvDCCArgwHQYDVR0OBBYEFDd/Pj6ZcWDKJNSRE3nQdCm0qCTYMIH5BgNV
 | 
					 | 
				
			||||||
HSMEgfEwge6AFDd/Pj6ZcWDKJNSRE3nQdCm0qCTYoYHSpIHPMIHMMQswCQYDVQQG
 | 
					 | 
				
			||||||
EwJBVDEQMA4GA1UECBMHQXVzdHJpYTEPMA0GA1UEBxMGVmllbm5hMTowOAYDVQQK
 | 
					 | 
				
			||||||
EzFBUkdFIERBVEVOIC0gQXVzdHJpYW4gU29jaWV0eSBmb3IgRGF0YSBQcm90ZWN0
 | 
					 | 
				
			||||||
aW9uMSUwIwYDVQQLExxBLUNFUlQgQ2VydGlmaWNhdGlvbiBTZXJ2aWNlMRgwFgYD
 | 
					 | 
				
			||||||
VQQDEw9BLUNFUlQgQURWQU5DRUQxHTAbBgkqhkiG9w0BCQEWDmluZm9AYS1jZXJ0
 | 
					 | 
				
			||||||
LmF0ggEAMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgHmMEcGA1UdJQRAMD4G
 | 
					 | 
				
			||||||
CCsGAQUFBwMBBggrBgEFBQcDAgYIKwYBBQUHAwMGCCsGAQUFBwMEBggrBgEFBQcD
 | 
					 | 
				
			||||||
CAYKKwYBBAGCNwoDBDARBglghkgBhvhCAQEEBAMCAP8wUQYDVR0gBEowSDBGBggq
 | 
					 | 
				
			||||||
KAAYAQEBAzA6MDgGCCsGAQUFBwIBFixodHRwOi8vd3d3LmEtY2VydC5hdC9jZXJ0
 | 
					 | 
				
			||||||
aWZpY2F0ZS1wb2xpY3kuaHRtbDA7BglghkgBhvhCAQgELhYsaHR0cDovL3d3dy5h
 | 
					 | 
				
			||||||
LWNlcnQuYXQvY2VydGlmaWNhdGUtcG9saWN5Lmh0bWwwGQYDVR0RBBIwEIEOaW5m
 | 
					 | 
				
			||||||
b0BhLWNlcnQuYXQwLwYDVR0SBCgwJoEOaW5mb0BhLWNlcnQuYXSGFGh0dHA6Ly93
 | 
					 | 
				
			||||||
d3cuYS1jZXJ0LmF0MEUGA1UdHwQ+MDwwOqA4oDaGNGh0dHBzOi8vc2VjdXJlLmEt
 | 
					 | 
				
			||||||
Y2VydC5hdC9jZ2ktYmluL2EtY2VydC1hZHZhbmNlZC5jZ2kwDQYJKoZIhvcNAQEF
 | 
					 | 
				
			||||||
BQADggEBACX1IvgfdG2rvfv35O48vSEvcVaEdlN8USFBHWz3JRAozgzvaBtwHkjK
 | 
					 | 
				
			||||||
Zwt5l/BWOtjbvHfRjDt7ijlBEcxOOrNC1ffyMHwHrXpvff6YpQ5wnxmIYEQcURiG
 | 
					 | 
				
			||||||
HMqruEX0WkuDNgSKwefsgXs27eeBauHgNGVcTYH1rmHu/ZyLpLxOyJQ2PCzA1DzW
 | 
					 | 
				
			||||||
3rWkIX92ogJ7lTRdWrbxwUL1XGinxnnaQ74+/y0pI9JNEv7ic2tpkweRMpkedaLW
 | 
					 | 
				
			||||||
msC1+orfKTebsg69aMaCx7o6jNONRmR/7TVaPf8/k6g52cHZ9YWjQvup22b5rWxG
 | 
					 | 
				
			||||||
J5r5LZ4vCPmF4+T4lutjUYAa/lGuQTg=
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,23 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIDwzCCAyygAwIBAgIBADANBgkqhkiG9w0BAQQFADCBmDELMAkGA1UEBhMCQVQx
 | 
					 | 
				
			||||||
EDAOBgNVBAgTB0F1c3RyaWExDzANBgNVBAcTBlZpZW5uYTFCMEAGA1UEChM5QXJn
 | 
					 | 
				
			||||||
ZSBEYXRlbiBPZXN0ZXJyZWljaGlzY2hlIEdlc2VsbHNjaGFmdCBmdWVyIERhdGVu
 | 
					 | 
				
			||||||
c2NodXR6MSIwIAYJKoZIhvcNAQkBFhNhLWNlcnRAYXJnZWRhdGVuLmF0MB4XDTAx
 | 
					 | 
				
			||||||
MDIxMjExMzAzMFoXDTA5MDIxMjExMzAzMFowgZgxCzAJBgNVBAYTAkFUMRAwDgYD
 | 
					 | 
				
			||||||
VQQIEwdBdXN0cmlhMQ8wDQYDVQQHEwZWaWVubmExQjBABgNVBAoTOUFyZ2UgRGF0
 | 
					 | 
				
			||||||
ZW4gT2VzdGVycmVpY2hpc2NoZSBHZXNlbGxzY2hhZnQgZnVlciBEYXRlbnNjaHV0
 | 
					 | 
				
			||||||
ejEiMCAGCSqGSIb3DQEJARYTYS1jZXJ0QGFyZ2VkYXRlbi5hdDCBnzANBgkqhkiG
 | 
					 | 
				
			||||||
9w0BAQEFAAOBjQAwgYkCgYEAwgsHqoNtmmrJ86+e1I4hOVBaL4kokqKN2IPOIL+1
 | 
					 | 
				
			||||||
XwY8vfOOUfPEdhWpaC0ldt7VYrksgDiUccgH0FROANWK2GkfKMDzjjXHysR04uEb
 | 
					 | 
				
			||||||
Om7Kqjqn0nproOGkFG+QvBZgs+Ws+HXNFJA6V76fU4+JXq4452LSK4Lr5YcBquu3
 | 
					 | 
				
			||||||
NJECAwEAAaOCARkwggEVMB0GA1UdDgQWBBQ0j59zH/G31zRjgK1y2P//tSAWZjCB
 | 
					 | 
				
			||||||
xQYDVR0jBIG9MIG6gBQ0j59zH/G31zRjgK1y2P//tSAWZqGBnqSBmzCBmDELMAkG
 | 
					 | 
				
			||||||
A1UEBhMCQVQxEDAOBgNVBAgTB0F1c3RyaWExDzANBgNVBAcTBlZpZW5uYTFCMEAG
 | 
					 | 
				
			||||||
A1UEChM5QXJnZSBEYXRlbiBPZXN0ZXJyZWljaGlzY2hlIEdlc2VsbHNjaGFmdCBm
 | 
					 | 
				
			||||||
dWVyIERhdGVuc2NodXR6MSIwIAYJKoZIhvcNAQkBFhNhLWNlcnRAYXJnZWRhdGVu
 | 
					 | 
				
			||||||
LmF0ggEAMAwGA1UdEwQFMAMBAf8wCwYDVR0PBAQDAgEGMBEGCWCGSAGG+EIBAQQE
 | 
					 | 
				
			||||||
AwICBDANBgkqhkiG9w0BAQQFAAOBgQBFuJYncqMYB6gXQS3eDOI90BEHfFTKy/dV
 | 
					 | 
				
			||||||
AV+K7QdAYikWmqgBheRdPKddJdccPy/Zl/p3ZT7GhDyC5f3wZjcuu8AJ27BNwbCA
 | 
					 | 
				
			||||||
x54dgxgCNcyPm79nY8MRtEdEpoRGdSsFKJemz6hpXM++MWFciyrRWIIA44XB0Gv3
 | 
					 | 
				
			||||||
US0spjsDPQ==
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,23 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBqDELMAkGA1UEBhMCQ0Ex
 | 
					 | 
				
			||||||
CzAJBgNVBAgTAk9OMRAwDgYDVQQHEwdUb3JvbnRvMRgwFgYDVQQKEw9CYW5rRW5n
 | 
					 | 
				
			||||||
aW5lIEluYy4xKTAnBgNVBAsTIENlcnRpZmljYXRpb24gQXV0aG9yaXR5IERpdmlz
 | 
					 | 
				
			||||||
aW9uMRMwEQYDVQQDEwpiYW5rZW5naW5lMSAwHgYJKoZIhvcNAQkBFhFjYUBiYW5r
 | 
					 | 
				
			||||||
ZW5naW5lLmNvbTAeFw05ODAxMDEwMDAwMDBaFw0zODAxMTcwMDAwMDBaMIGoMQsw
 | 
					 | 
				
			||||||
CQYDVQQGEwJDQTELMAkGA1UECBMCT04xEDAOBgNVBAcTB1Rvcm9udG8xGDAWBgNV
 | 
					 | 
				
			||||||
BAoTD0JhbmtFbmdpbmUgSW5jLjEpMCcGA1UECxMgQ2VydGlmaWNhdGlvbiBBdXRo
 | 
					 | 
				
			||||||
b3JpdHkgRGl2aXNpb24xEzARBgNVBAMTCmJhbmtlbmdpbmUxIDAeBgkqhkiG9w0B
 | 
					 | 
				
			||||||
CQEWEWNhQGJhbmtlbmdpbmUuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB
 | 
					 | 
				
			||||||
CgKCAQEA14LoTUAl1/hEy+Kh1kLHiBdW2zD3V4IhM7xxTVKsYsIH56nr69ATTIxU
 | 
					 | 
				
			||||||
P36eRzeZ137qt1AxHFjDCidk3m1Ul6l59ProPexdslLLM2npM3f2cteg+toyiYiS
 | 
					 | 
				
			||||||
EJKjyzIu1xF1j9qzGkymSY/4DsXLZNk9FaczxMk/Ooc6Os1M3AverL4VG4rYIb6f
 | 
					 | 
				
			||||||
eR32cIKJ9Q1fGuyKk7ipq1XQfPW8a8TgZdbHbe7U9Gk3iasGMHHvpR9Ep3mGbgdT
 | 
					 | 
				
			||||||
uQ98SBEuIwe1BUCGg/MXpVy48MNXfAMotBgGw4pl9yqSjMni2FB+E9Q9DHFs2RgX
 | 
					 | 
				
			||||||
MqzKuo8zcPxKx2kZ6Arj8+27dw2clQIDAQABoxAwDjAMBgNVHRMEBTADAQH/MA0G
 | 
					 | 
				
			||||||
CSqGSIb3DQEBBQUAA4IBAQBauupHX9EhpC/r57d6b5kkeWvognxIP9//TO4iw3qb
 | 
					 | 
				
			||||||
zIXEkPXmJmwVzlzoKJWqiya+aw19SP0+G6CzsFOBo/9ehmz+hZ8bhYX4MjlWzX5u
 | 
					 | 
				
			||||||
Tnkhz172j9fOBUmrTVPkcRIs6zjCD5PQAGoBPP1/Zdy2N36lZ0U7lg07Opirj/yJ
 | 
					 | 
				
			||||||
PSJeM2j0fwIFAroiVckvdT0BVwB6S/cPaAQGPghbbr1YGSmYrMriSv825ILJUfxz
 | 
					 | 
				
			||||||
rJYunGR9FiY9Ob7+jwJwiZMS4CxSPktutxr/3hOvr1+ALS7IcVakhhA3PuZAJbdH
 | 
					 | 
				
			||||||
FRclR9qMM8aBnBZmf+Uv3K3uhT+UBzzY654U9Yi1JYnA
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,23 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBqDELMAkGA1UEBhMCQ0Ex
 | 
					 | 
				
			||||||
CzAJBgNVBAgTAk9OMRAwDgYDVQQHEwdUb3JvbnRvMRgwFgYDVQQKEw9DZXJ0RW5n
 | 
					 | 
				
			||||||
aW5lIEluYy4xKTAnBgNVBAsTIENlcnRpZmljYXRpb24gQXV0aG9yaXR5IERpdmlz
 | 
					 | 
				
			||||||
aW9uMRMwEQYDVQQDEwpjZXJ0ZW5naW5lMSAwHgYJKoZIhvcNAQkBFhFjYUBjZXJ0
 | 
					 | 
				
			||||||
ZW5naW5lLmNvbTAeFw05ODAxMDEwMDAwMDBaFw0zODAxMTcwMDAwMDBaMIGoMQsw
 | 
					 | 
				
			||||||
CQYDVQQGEwJDQTELMAkGA1UECBMCT04xEDAOBgNVBAcTB1Rvcm9udG8xGDAWBgNV
 | 
					 | 
				
			||||||
BAoTD0NlcnRFbmdpbmUgSW5jLjEpMCcGA1UECxMgQ2VydGlmaWNhdGlvbiBBdXRo
 | 
					 | 
				
			||||||
b3JpdHkgRGl2aXNpb24xEzARBgNVBAMTCmNlcnRlbmdpbmUxIDAeBgkqhkiG9w0B
 | 
					 | 
				
			||||||
CQEWEWNhQGNlcnRlbmdpbmUuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB
 | 
					 | 
				
			||||||
CgKCAQEA7aTXURShaeVt9u/dP3Q2dVib3jTCZvEyc6yfpGgaYWewXWuP4HOSfI4h
 | 
					 | 
				
			||||||
GZblbpl+dzJc6RjhR+pguIRtbT5FJB8SJGjRqoujBEOQOxtVtc2fjM9Dqh0iOvMW
 | 
					 | 
				
			||||||
WS6buxHG55GVrHAQaO5HXEScKQBa9ZyNmpSXPTEBrDMej1OAGOkc524/TZrgFPF4
 | 
					 | 
				
			||||||
AiJLLkxCcP8NuzUKlW3WzNMSSoCtjkUKy4wjSLlAWCFM0T9Df6/+Z8ZUQTzHoKCD
 | 
					 | 
				
			||||||
ncH5Qnynd7DlOwKQ2JwwxRhYGiGVTUN0GUq7qA11kW3+vnbFesKQXoF6o2PVx9s2
 | 
					 | 
				
			||||||
YXviI2NXXUjZ0pVnsnFCc45Pm8XojwIDAQABoxAwDjAMBgNVHRMEBTADAQH/MA0G
 | 
					 | 
				
			||||||
CSqGSIb3DQEBBQUAA4IBAQBP/aHOKJ00Akzc9HWM1X30hlWZFBaQi4pqD4Uhk8+p
 | 
					 | 
				
			||||||
KzzwFP5DRLBOz8TYBbtdXrS6hxVMr2sqWmhVkuyepWhHZazKGyHY/y0FbOXsewAV
 | 
					 | 
				
			||||||
1QxxSyx7ve89pCKv4/w0rQcP916iHc8Y/TCpmz7eITa3GId+8H/XTaBi8GBp9X9O
 | 
					 | 
				
			||||||
w8m25FmEB1NT+eJwefvfdKowjy4tSorKdW/eJspxNuTSRGmUy8G71W5dYvgpAlx6
 | 
					 | 
				
			||||||
mdnHyzxEGvRYNNI2bS0ifXgbEFNWqSas9q34ea5KOpkJu8T/KyXfSb6rPOsBSb0t
 | 
					 | 
				
			||||||
wMowwGtCVH2C4Lw/8zo0EjhMpTOsPaub408PrZ+NQ2bl
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,34 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIF3TCCA8WgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBqDELMAkGA1UEBhMCQ0Ex
 | 
					 | 
				
			||||||
CzAJBgNVBAgTAk9OMRAwDgYDVQQHEwdUb3JvbnRvMRgwFgYDVQQKEw9Gb3J0RW5n
 | 
					 | 
				
			||||||
aW5lIEluYy4xKTAnBgNVBAsTIENlcnRpZmljYXRpb24gQXV0aG9yaXR5IERpdmlz
 | 
					 | 
				
			||||||
aW9uMRMwEQYDVQQDEwpmb3J0ZW5naW5lMSAwHgYJKoZIhvcNAQkBFhFjYUBmb3J0
 | 
					 | 
				
			||||||
ZW5naW5lLmNvbTAeFw05ODAxMDEwMDAwMDBaFw0zODAxMTcwMDAwMDBaMIGoMQsw
 | 
					 | 
				
			||||||
CQYDVQQGEwJDQTELMAkGA1UECBMCT04xEDAOBgNVBAcTB1Rvcm9udG8xGDAWBgNV
 | 
					 | 
				
			||||||
BAoTD0ZvcnRFbmdpbmUgSW5jLjEpMCcGA1UECxMgQ2VydGlmaWNhdGlvbiBBdXRo
 | 
					 | 
				
			||||||
b3JpdHkgRGl2aXNpb24xEzARBgNVBAMTCmZvcnRlbmdpbmUxIDAeBgkqhkiG9w0B
 | 
					 | 
				
			||||||
CQEWEWNhQGZvcnRlbmdpbmUuY29tMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC
 | 
					 | 
				
			||||||
CgKCAgEAyr7GbpwDxx1v3EYbo0gcO+ligEhlDqG2e7u/AbWGoVAqc8+q6auUJUtz
 | 
					 | 
				
			||||||
4i7oh0yNadu1o9kpXW+znkgO0zlrgjGskqqMO1ooppzTJdFy/P8gR6x1Iuv3kWtX
 | 
					 | 
				
			||||||
OuzwPPEjv09LWlhyJsN+oU4ztTVf07I0Q9zYupcoDQ58XKRheI9KdDB2DYSmxywA
 | 
					 | 
				
			||||||
WSLQwIeG0Qa7gvokeQlpkgkEC7viEecJ3752KXBJHnh7As51mxnlpmG6sDy67Eli
 | 
					 | 
				
			||||||
HDw5tHETRqbtnscGBjskGQBqR5xt7+QnnthZrN8HJHDoa9zgGephwizhkL44lXLF
 | 
					 | 
				
			||||||
YK9W5XhFbblw2c+mAcHkokRiwD7CPeIoyD2a/Jcw3n5hegKTlNhd4BFGVF6JR7gF
 | 
					 | 
				
			||||||
OFk2QfHXit5uthsij9Xhl7WAgQUqLgggD9MphqPf4nY66OZUJV9ZsmB+Qfp8UizB
 | 
					 | 
				
			||||||
0WAOegactKVyRqHtRa+KIEXQXNtZgjcmMk9CYkP0nIbKtgKXaH6+9VMHNOryCnFE
 | 
					 | 
				
			||||||
7pSsuPUkypncFWCHGSeiFO3w4w4J4csltxBADQzxfRu5KZnlToQN7bVpI/Q31tVX
 | 
					 | 
				
			||||||
E5bjrJcq6Oj/OTqZ3ID+OqbkUdAg0ggjRKcTgxnLHd/AbMzJ6PsclDDf7cLs0WSl
 | 
					 | 
				
			||||||
xMxQR/z5bNST1rNtT9rsiv2TOhfvCBxO9AOjBioO8PLO032HTNECAwEAAaMQMA4w
 | 
					 | 
				
			||||||
DAYDVR0TBAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAgEAVyBpPWfT2VOyvVpslGKx
 | 
					 | 
				
			||||||
8h0+CWP8cilygGRtZJ5dAJzc//1REAHdvK+TgZ4Foz3dqHhXI+RNN0FpzuWaYMjW
 | 
					 | 
				
			||||||
ZTS0kAmcOQuGY1Oo4PGlPHI21pNz29oFDTJr0ZmLBJ4JKVsE2soJg55jdk9MZHA7
 | 
					 | 
				
			||||||
K//7HH9RsmrWZOE5DZDlrxp6+naixhMwnlPKKisIy9GNZUPqGdUWABMdB/BUVVNl
 | 
					 | 
				
			||||||
NU5TtWpIXUClMd8a+eoKcItBeYXowkHOBpinPkDX3clFDIUfWiw0Ro08s8SrrFqR
 | 
					 | 
				
			||||||
8Szwbrj52Xv1RM56oGqCjnkvJctxihODV7NcpxoAFjIZokDom0q6zPrrTUsLFQov
 | 
					 | 
				
			||||||
Plovc3w5hmALiDMshaTvE1nm3Psn4yQ+FlRE8epTZrQiIGypZkZC6lcz0mYawueW
 | 
					 | 
				
			||||||
cThYWGFhVG4ktQzOjjNRsNxopW+W7cF1zQTxiWUDnxIKSj7gtdQ2jiubxEEhfVag
 | 
					 | 
				
			||||||
r8DMtAccNVTZVURpGi56TptOOuotrTqqC+2GviW4hlxvdvmuQN0OlXlUwzz2Trxc
 | 
					 | 
				
			||||||
FamNnuA54lZw/8arLtxsFmHrcnPw53+1spumLD0S5UkxHNu40h6LIVpZz3H+0rLz
 | 
					 | 
				
			||||||
uFofTfiyMjcfK2AyHQTgUCbsrvgNuLDQUbyFGVchdFUkhztX3DhEVnxnnrpY4BVj
 | 
					 | 
				
			||||||
QdTqWIvw7lGlSuDCjxEQAOc=
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,23 +0,0 @@
 | 
				
			|||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBqDELMAkGA1UEBhMCQ0Ex
 | 
					 | 
				
			||||||
CzAJBgNVBAgTAk9OMRAwDgYDVQQHEwdUb3JvbnRvMRgwFgYDVQQKEw9NYWlsRW5n
 | 
					 | 
				
			||||||
aW5lIEluYy4xKTAnBgNVBAsTIENlcnRpZmljYXRpb24gQXV0aG9yaXR5IERpdmlz
 | 
					 | 
				
			||||||
aW9uMRMwEQYDVQQDEwptYWlsZW5naW5lMSAwHgYJKoZIhvcNAQkBFhFjYUBtYWls
 | 
					 | 
				
			||||||
ZW5naW5lLmNvbTAeFw05ODAxMDEwMDAwMDBaFw0zODAxMTcwMDAwMDBaMIGoMQsw
 | 
					 | 
				
			||||||
CQYDVQQGEwJDQTELMAkGA1UECBMCT04xEDAOBgNVBAcTB1Rvcm9udG8xGDAWBgNV
 | 
					 | 
				
			||||||
BAoTD01haWxFbmdpbmUgSW5jLjEpMCcGA1UECxMgQ2VydGlmaWNhdGlvbiBBdXRo
 | 
					 | 
				
			||||||
b3JpdHkgRGl2aXNpb24xEzARBgNVBAMTCm1haWxlbmdpbmUxIDAeBgkqhkiG9w0B
 | 
					 | 
				
			||||||
CQEWEWNhQG1haWxlbmdpbmUuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB
 | 
					 | 
				
			||||||
CgKCAQEAqXmfsU+lx+NFmn6tN17RTOyaddHqLnr/3rzEDIyT9TN+tF9TG7jmK7lJ
 | 
					 | 
				
			||||||
Jrj5arQ3nTFaLF8JuND2U1z/cLPw6/TX+1tE3v3CNUDSjaisyUDiUyp3TE8hMMMz
 | 
					 | 
				
			||||||
zfZQn0JsGgNhhWxqyzjhRQGtKL4+xtn8VsF/8zGgZYke7nlmVKz/FslDFTnNoodL
 | 
					 | 
				
			||||||
BAEGiu9JQS9qqpbSs20NdZ6LXPL2A4iTjnsNFBW3jIMVIn/JVVyaycU7ue2oFviD
 | 
					 | 
				
			||||||
vLNpkVZcR7A+jjIdIumOc5VSF0y7y74cQC5YwkR2mLK7UBYDK6NCY3ta/C4M8NsM
 | 
					 | 
				
			||||||
0FpmvRl0+A1ivZtVwqI98dxDtp7HeQIDAQABoxAwDjAMBgNVHRMEBTADAQH/MA0G
 | 
					 | 
				
			||||||
CSqGSIb3DQEBBQUAA4IBAQAjfNn5BCzxylBDakFQGWKE/P43PRibMOEzfd7+DzbY
 | 
					 | 
				
			||||||
WIekoz3i00DwoH3b6j4gwlDJRAOq4dF6/Pt/uBOHDo/op+ef+9ErmKPd+ehXN9h3
 | 
					 | 
				
			||||||
7QbccTgz7DtVwA4iRlDRLru+JuXzT+OsCHuFZMOLJ+KD2JAGh3W68JjdcLkrlcpt
 | 
					 | 
				
			||||||
AU0wc5aOHPPfEBdIah8y8QtNzXRVzoBt8zzvgCARkXxTS2u/9QaXR1hML0JtDgQS
 | 
					 | 
				
			||||||
SdZ6Kd8SN6yzqxD+buYD5sOfJmjBF/n3lqFHNMHnnGXy2TAXZtIAWzffU3A0cGPB
 | 
					 | 
				
			||||||
N6FZ026a86HbF1X4k+xszhbJu/ikczyuWnCJIg3fTYSD
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user