3 $! Original Author: UNKNOWN
4 $! Rewritten By: Robert Byer
6 $! A-Com Computing, Inc.
7 $! byer@mail.all-net.net
9 $! Changes by Richard Levitte <richard@levitte.org>
11 $! This procedure creates the SSL libraries of "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB"
12 $! "[.xxx.EXE.SSL]LIBSSL.OLB" and if specified "[.xxx.EXE.RSAREF]LIBRSAGLUE.OLB".
13 $! The "xxx" denotes the machine architecture of AXP or VAX.
15 $! This procedures accepts two command line options listed below.
17 $! Specify one of the following build options for P1.
19 $! ALL Just build "everything".
20 $! DATE Just build the "[.INCLUDE.OPENSSL]DATE.H" file.
21 $! SOFTLINKS Just fix the Unix soft links.
22 $! RSAREF Just build the "[.xxx.EXE.RSAREF]LIBRSAGLUE.OLB" library.
23 $! CRYPTO Just build the "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB" library.
24 $! SSL Just build the "[.xxx.EXE.SSL]LIBSSL.OLB" library.
25 $! SSL_TASK Just build the "[.xxx.EXE.SSL]SSL_TASK.EXE" program.
26 $! TEST Just build the "[.xxx.EXE.TEST]" test programs for OpenSSL.
27 $! APPS Just build the "[.xxx.EXE.APPS]" application programs for OpenSSL.
30 $! Specify RSAREF as P2 to compile using the RSAREF Library.
31 $! If you specify NORSAREF, it will compile without using RSAREF.
32 $! (If in the United States, You Must Compile Using RSAREF).
34 $! Note: The RSAREF libraries are NOT INCLUDED and you have to
35 $! download it from "ftp://ftp.rsa.com/rsaref". You have to
36 $! get the ".tar-Z" file as the ".zip" file dosen't have the
37 $! directory structure stored. You have to extract the file
38 $! into the [.RSAREF] directory as that is where the scripts
39 $! will look for the files.
41 $! Speficy DEBUG or NODEBUG as P3 to compile with or without debugging
44 $! Specify which compiler at P4 to try to compile under.
49 $! LINK To only link the programs from existing object files.
51 $! If you don't speficy a compiler, it will try to determine which
52 $! "C" compiler to use.
54 $! P5, if defined, sets a TCP/IP library to use, through one of the following
57 $! UCX for UCX or UCX emulation
58 $! SOCKETSHR for SOCKETSHR+NETLIB
60 $! P6, if defined, sets a compiler thread NOT needed on OpenVMS 7.1 (and up)
63 $! Check Which Architecture We Are Using.
65 $ IF (F$GETSYI("CPU").GE.128)
68 $! The Architecture Is AXP.
76 $! The Architecture Is VAX.
80 $! End The Architecture Check.
84 $! Check To Make Sure We Have Valid Command Line Parameters.
88 $! Check To See What We Are To Do.
90 $ IF (BUILDALL.EQS."TRUE")
93 $! Since Nothing Special Was Specified, Do Everything.
94 $! First, Fix The Unix Softlinks.
98 $! Create The "DATE.H" Include File.
102 $! Check To See If We Are Going To Be Building The
103 $! [.xxx.EXE.RSAREF]LIBRSAGLUE.OLB Library.
105 $ IF (RSAREF.EQS."RSAREF")
108 $! Build The [.xxx.EXE.RSAREF]LIBRSAGLUE.OLB Library.
112 $! End The RSAREF Check.
116 $! Build The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library.
120 $! Build The [.xxx.EXE.SSL]LIBSSL.OLB Library.
124 $! Build The [.xxx.EXE.SSL]SSL_TASK.EXE DECNet SSL Engine.
128 $! Build The [.xxx.EXE.TEST] OpenSSL Test Utilities.
132 $! Build The [.xxx.EXE.APPS] OpenSSL Application Utilities.
140 $! Build Just What The User Wants Us To Build.
149 $! Rebuild The "[.INCLUDE.OPENSSL]DATE.H" file.
153 $! Tell The User We Are Creating The [.CRYPTO]DATE.H File.
155 $ WRITE SYS$OUTPUT "Creating [.CRYPTO]DATE.H Include File."
157 $! Create The [.CRYPTO]DATE.H File.
159 $ OPEN/WRITE H_FILE SYS$DISK:[.CRYPTO]DATE.H
161 $! Get The Current Date & Time.
165 $! Write The [.CRYPTO]DATE.H File.
167 $ WRITE H_FILE "#define DATE ""''TIME'"" "
169 $! Close The [.CRYPTO]DATE.H File.
173 $! That's All, Time To RETURN.
177 $! Copy a lot of files around.
181 $! Tell The User We Are Partly Rebuilding The [.TEST] Directory.
183 $ WRITE SYS$OUTPUT "Rebuilding The '[.APPS]MD5.C' And '[.APPS]RMD160.C' Files."
185 $ DELETE SYS$DISK:[.APPS]MD5.C;*,RMD160.C;*
187 $! Copy MD5.C from [.CRYPTO.MD5] into [.APPS]
189 $ COPY SYS$DISK:[.CRYPTO.MD5]MD5.C SYS$DISK:[.APPS]
191 $! Copy RMD160.C from [.CRYPTO.RIPEMD] into [.APPS]
193 $ COPY SYS$DISK:[.CRYPTO.RIPEMD]RMD160.C SYS$DISK:[.APPS]
195 $! Tell The User We Are Partly Rebuilding The [.TEST] Directory.
197 $ WRITE SYS$OUTPUT "Rebuilding The '[.TEST]*.C' Files."
199 $! First, We Have To "Rebuild" The "[.TEST]" Directory, So Delete
200 $! All The "C" Files That Are Currently There Now.
202 $ DELETE SYS$DISK:[.TEST]*.C;*
204 $! Copy all the *TEST.C files from [.CRYPTO...] into [.TEST]
206 $ COPY SYS$DISK:[.CRYPTO.*]%*TEST.C SYS$DISK:[.TEST]
208 $! Copy all the *TEST.C files from [.SSL...] into [.TEST]
210 $ COPY SYS$DISK:[.SSL]%*TEST.C SYS$DISK:[.TEST]
212 $! Tell The User We Are Rebuilding The [.INCLUDE.OPENSSL] Directory.
214 $ WRITE SYS$OUTPUT "Rebuilding The '[.INCLUDE.OPENSSL]' Directory."
216 $! First, make sure the directory exists
218 $ IF F$PARSE("SYS$DISK:[.INCLUDE.OPENSSL]") .EQS. "" THEN -
219 CREATE/DIRECTORY SYS$DISK:[.INCLUDE.OPENSSL]
221 $! Copy All The ".H" Files From The Main Directory.
224 $ COPY 'EXHEADER' SYS$DISK:[.INCLUDE.OPENSSL]
226 $! Copy All The ".H" Files From The [.CRYPTO] Directory Tree.
228 $ SDIRS := ,MD2,MD5,SHA,MDC2,HMAC,RIPEMD,-
229 DES,RC2,RC4,RC5,IDEA,BF,CAST,-
231 BUFFER,BIO,STACK,LHASH,RAND,ERR,OBJECTS,-
232 EVP,ASN1,PEM,X509,X509V3,-
233 CONF,TXT_DB,PKCS7,PKCS12,COMP
234 $ EXHEADER_ := crypto.h,tmdiff.h,opensslv.h,opensslconf.h
235 $ EXHEADER_MD2 := md2.h
236 $ EXHEADER_MD5 := md5.h
237 $ EXHEADER_SHA := sha.h
238 $ EXHEADER_MDC2 := mdc2.h
239 $ EXHEADER_HMAC := hmac.h
240 $ EXHEADER_RIPEMD := ripemd.h
241 $ EXHEADER_DES := des.h
242 $ EXHEADER_RC2 := rc2.h
243 $ EXHEADER_RC4 := rc4.h
244 $ EXHEADER_RC5 := rc5.h
245 $ EXHEADER_IDEA := idea.h
246 $ EXHEADER_BF := blowfish.h
247 $ EXHEADER_CAST := cast.h
248 $ EXHEADER_BN := bn.h
249 $ EXHEADER_RSA := rsa.h
250 $ EXHEADER_DSA := dsa.h
251 $ EXHEADER_DH := dh.h
252 $ EXHEADER_BUFFER := buffer.h
253 $ EXHEADER_BIO := bio.h
254 $ EXHEADER_STACK := stack.h,safestack.h
255 $ EXHEADER_LHASH := lhash.h
256 $ EXHEADER_RAND := rand.h
257 $ EXHEADER_ERR := err.h
258 $ EXHEADER_OBJECTS := objects.h
259 $ EXHEADER_EVP := evp.h
260 $ EXHEADER_ASN1 := asn1.h,asn1_mac.h
261 $ EXHEADER_PEM := pem.h,pem2.h
262 $ EXHEADER_X509 := x509.h,x509_vfy.h
263 $ EXHEADER_X509V3 := x509v3.h
264 $ EXHEADER_CONF := conf.h
265 $ EXHEADER_TXT_DB := txt_db.h
266 $ EXHEADER_PKCS7 := pkcs7.h
267 $ EXHEADER_PKCS12 := pkcs12.h
268 $ EXHEADER_COMP := comp.h
272 $ D = F$EDIT(F$ELEMENT(I, ",", SDIRS),"TRIM")
274 $ IF D .EQS. "," THEN GOTO LOOP_SDIRS_END
278 $ COPY [.CRYPTO]'tmp' SYS$DISK:[.INCLUDE.OPENSSL] /LOG
280 $ COPY [.CRYPTO.'D']'tmp' SYS$DISK:[.INCLUDE.OPENSSL] /LOG
285 $! Copy All The ".H" Files From The [.RSAREF] Directory.
287 $ EXHEADER := rsaref.h
288 $ COPY SYS$DISK:[.RSAREF]'EXHEADER' SYS$DISK:[.INCLUDE.OPENSSL]
290 $! Copy All The ".H" Files From The [.SSL] Directory.
292 $ EXHEADER := ssl.h,ssl2.h,ssl3.h,ssl23.h,tls1.h
293 $ COPY SYS$DISK:[.SSL]'EXHEADER' SYS$DISK:[.INCLUDE.OPENSSL]
297 $ PURGE SYS$DISK:[.INCLUDE.OPENSSL]*.H
299 $! That's All, Time To RETURN.
303 $! Build The "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB" Library.
307 $! Tell The User What We Are Doing.
309 $ WRITE SYS$OUTPUT ""
310 $ WRITE SYS$OUTPUT "Building The [.",ARCH,".EXE.CRYPTO]LIBCRYPTO.OLB Library."
312 $! Go To The [.CRYPTO] Directory.
314 $ SET DEFAULT SYS$DISK:[.CRYPTO]
316 $! Build The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library.
318 $ @CRYPTO-LIB 'RSAREF' 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" 'ISSEVEN'
320 $! Go Back To The Main Directory.
328 $! Build The [.xxx.EXE.RSAREF]LIBRSAGLUE Library.
332 $! Tell The User What We Are Doing.
334 $ WRITE SYS$OUTPUT ""
335 $ WRITE SYS$OUTPUT "Building The [.",ARCH,".EXE.RSAREF]LIBRSAGLUE.OLB Library."
337 $! Go To The [.RSAREF] Directory.
339 $ SET DEFAULT SYS$DISK:[.RSAREF]
341 $! Build The [.xxx.EXE.RSAREF]LIBRSAGLUE.OLB Library.
343 $ @RSAREF-LIB LIBRARY 'DEBUGGER' "''COMPILER'" 'ISSEVEN'
345 $! Go Back To The Main Directory.
353 $! Build The "[.xxx.EXE.SSL]LIBSSL.OLB" Library.
357 $! Tell The User What We Are Doing.
359 $ WRITE SYS$OUTPUT ""
360 $ WRITE SYS$OUTPUT "Building The [.",ARCH,".EXE.SSL]LIBSSL.OLB Library."
362 $! Go To The [.SSL] Directory.
364 $ SET DEFAULT SYS$DISK:[.SSL]
366 $! Build The [.xxx.EXE.SSL]LIBSSL.OLB Library.
368 $ @SSL-LIB LIBRARY 'RSAREF' 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" 'ISSEVEN'
370 $! Go Back To The Main Directory.
378 $! Build The "[.xxx.EXE.SSL]SSL_TASK.EXE" Program.
382 $! Tell The User What We Are Doing.
384 $ WRITE SYS$OUTPUT ""
385 $ WRITE SYS$OUTPUT "Building DECNet Based SSL Engine, [.",ARCH,".EXE.SSL]SSL_TASK.EXE"
387 $! Go To The [.SSL] Directory.
389 $ SET DEFAULT SYS$DISK:[.SSL]
391 $! Build The [.xxx.EXE.SSL]SSL_TASK.EXE
393 $ @SSL-LIB SSL_TASK 'RSAREF' 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" 'ISSEVEN'
395 $! Go Back To The Main Directory.
399 $! That's All, Time To RETURN.
403 $! Build The OpenSSL Test Programs.
407 $! Tell The User What We Are Doing.
409 $ WRITE SYS$OUTPUT ""
410 $ WRITE SYS$OUTPUT "Building The OpenSSL [.",ARCH,".EXE.TEST] Test Utilities."
412 $! Go To The [.TEST] Directory.
414 $ SET DEFAULT SYS$DISK:[.TEST]
416 $! Build The Test Programs.
418 $ @MAKETESTS 'RSAREF' 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" 'ISSEVEN'
420 $! Go Back To The Main Directory.
424 $! That's All, Time To RETURN.
428 $! Build The OpenSSL Application Programs.
432 $! Tell The User What We Are Doing.
434 $ WRITE SYS$OUTPUT ""
435 $ WRITE SYS$OUTPUT "Building OpenSSL [.",ARCH,".EXE.APPS] Applications."
437 $! Go To The [.APPS] Directory.
439 $ SET DEFAULT SYS$DISK:[.APPS]
441 $! Build The Application Programs.
443 $ @MAKEAPPS 'RSAREF' 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" 'ISSEVEN'
445 $! Go Back To The Main Directory.
449 $! That's All, Time To RETURN.
453 $! Check The User's Options.
457 $! Check To See If P1 Is Blank.
462 $! P1 Is ALL, So Build Everything.
470 $! Else, Check To See If P1 Has A Valid Arguement.
472 $ IF (P1.EQS."DATE").OR.(P1.EQS."SOFTLINKS").OR.(P1.EQS."CRYPTO") -
473 .OR.(P1.EQS."SSL").OR.(P1.EQS."RSAREF").OR.(P1.EQS."SSL_TASK") -
474 .OR.(P1.EQS."TEST").OR.(P1.EQS."APPS")
477 $! A Valid Arguement.
485 $! Tell The User We Don't Know What They Want.
487 $ WRITE SYS$OUTPUT ""
488 $ WRITE SYS$OUTPUT "The Option ",P1," Is Invalid. The Valid Options Are:"
489 $ WRITE SYS$OUTPUT ""
490 $ WRITE SYS$OUTPUT " ALL : Just Build Everything."
491 $ WRITE SYS$OUTPUT " DATE : Just build the [.INCLUDE.OPENSSL]DATE.H file."
492 $ WRITE SYS$OUTPUT " SOFTLINKS: Just Fix The Unix soft links."
493 $ WRITE SYS$OUTPUT " RSAREF : To Build Just The [.xxx.EXE.RSAREF]LIBRSAGLUE.OLB Library."
494 $ WRITE SYS$OUTPUT " CRYPTO : To Build Just The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library."
495 $ WRITE SYS$OUTPUT " SSL : To Build Just The [.xxx.EXE.SSL]LIBSSL.OLB Library."
496 $ WRITE SYS$OUTPUT " SSL_TASK : To Build Just The [.xxx.EXE.SSL]SSL_TASK.EXE Program."
497 $ WRITE SYS$OUTPUT " TEST : To Build Just The OpenSSL Test Programs."
498 $ WRITE SYS$OUTPUT " APPS : To Build Just The OpenSSL Application Programs."
499 $ WRITE SYS$OUTPUT ""
500 $ WRITE SYS$OUTPUT " Where 'xxx' Stands For:"
501 $ WRITE SYS$OUTPUT ""
502 $ WRITE SYS$OUTPUT " AXP : Alpha Architecture."
503 $ WRITE SYS$OUTPUT " VAX : VAX Architecture."
504 $ WRITE SYS$OUTPUT ""
510 $! End The Valid Argument Check.
518 $! Check To See If P2 Is Blank.
520 $ IF (P2.EQS."NORSAREF")
523 $! P2 Is NORSAREF, So Compile Without RSAREF.
525 $ RSAREF = "NORSAREF"
531 $! Check To See If We Are To Compile Using The RSAREF Library.
533 $ IF (P2.EQS."RSAREF")
536 $! Compile With RSAREF Library.
544 $! Tell The User Entered An Invalid Option..
546 $ WRITE SYS$OUTPUT ""
547 $ WRITE SYS$OUTPUT "The Option ",P2," Is Invalid. The Valid Options Are:"
548 $ WRITE SYS$OUTPUT ""
549 $ WRITE SYS$OUTPUT " RSAREF : To Compile With The RSAREF Library."
550 $ WRITE SYS$OUTPUT " NORSAREF : To Compile With The Regular RSA Library."
551 $ WRITE SYS$OUTPUT ""
557 $! End The Valid Arguemnt Check.
565 $! Check To See If P3 Is Blank.
567 $ IF (P3.EQS."NODEBUG")
570 $! P3 Is NODEBUG, So Compile Without Debugger Information.
572 $ DEBUGGER = "NODEBUG"
578 $! Check To See If We Are To Compile With Debugger Information.
580 $ IF (P3.EQS."DEBUG")
583 $! Compile With Debugger Information.
591 $! Tell The User Entered An Invalid Option..
593 $ WRITE SYS$OUTPUT ""
594 $ WRITE SYS$OUTPUT "The Option ",P3," Is Invalid. The Valid Options Are:"
595 $ WRITE SYS$OUTPUT ""
596 $ WRITE SYS$OUTPUT " DEBUG : Compile With The Debugger Information."
597 $ WRITE SYS$OUTPUT " NODEBUG : Compile Without The Debugger Information."
598 $ WRITE SYS$OUTPUT ""
604 $! End The Valid Arguement Check.
612 $! Check To See If P4 Is Blank.
617 $! O.K., The User Didn't Specify A Compiler, Let's Try To
618 $! Find Out Which One To Use.
620 $! Check To See If We Have GNU C.
622 $ IF (F$TRNLNM("GNU_CC").NES."")
625 $! Looks Like GNUC, Set To Use GNUC.
629 $! Tell The User We Are Using GNUC.
631 $ WRITE SYS$OUTPUT "Using GNU 'C' Compiler."
633 $! End The GNU C Compiler Check.
637 $! Check To See If We Have VAXC Or DECC.
639 $ IF (F$GETSYI("CPU").GE.128).OR.(F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC")
642 $! Looks Like DECC, Set To Use DECC.
646 $! Tell The User We Are Using DECC.
648 $ WRITE SYS$OUTPUT "Using DECC 'C' Compiler."
654 $! Looks Like VAXC, Set To Use VAXC.
658 $! Tell The User We Are Using VAX C.
660 $ WRITE SYS$OUTPUT "Using VAXC 'C' Compiler."
662 $! End The DECC & VAXC Compiler Check.
670 $! Check To See If The User Entered A Valid Paramter.
672 $ IF (P4.EQS."VAXC").OR.(P4.EQS."DECC").OR.(P4.EQS."GNUC").OR.(P4.EQS."LINK")
675 $! Check To See If The User Wanted To Just LINK.
680 $! Looks Like LINK-only
684 $! Tell The User We Are Only Linking.
686 $ WRITE SYS$OUTPUT "LINK Only. This actually NOT YET SUPPORTED!"
692 $! Check To See If The User Wanted DECC.
697 $! Looks Like DECC, Set To Use DECC.
701 $! Tell The User We Are Using DECC.
703 $ WRITE SYS$OUTPUT "Using DECC 'C' Compiler."
709 $! Check To See If We Are To Use VAXC.
714 $! Looks Like VAXC, Set To Use VAXC.
718 $! Tell The User We Are Using VAX C.
720 $ WRITE SYS$OUTPUT "Using VAXC 'C' Compiler."
726 $! Check To See If We Are To Use GNU C.
731 $! Looks Like GNUC, Set To Use GNUC.
735 $! Tell The User We Are Using GNUC.
737 $ WRITE SYS$OUTPUT "Using GNU 'C' Compiler."
739 $! End The GNU C Check.
743 $! Else The User Entered An Invalid Arguement.
747 $! Tell The User We Don't Know What They Want.
749 $ WRITE SYS$OUTPUT ""
750 $ WRITE SYS$OUTPUT "The Option ",P4," Is Invalid. The Valid Options Are:"
751 $ WRITE SYS$OUTPUT ""
752 $ WRITE SYS$OUTPUT " VAXC : To Compile With VAX C."
753 $ WRITE SYS$OUTPUT " DECC : To Compile With DEC C."
754 $ WRITE SYS$OUTPUT " GNUC : To Compile With GNU C."
755 $ WRITE SYS$OUTPUT ""
761 $! End The Valid Arguement Check.
769 $! Time to check the contents of P5, and to make sure we get the correct library.
771 $ IF P5.EQS."SOCKETSHR" .OR. P5.EQS."MULTINET" .OR. P5.EQS."UCX"
774 $! Check to see if SOCKETSHR was chosen
776 $ IF P5.EQS."SOCKETSHR"
779 $! Set the library to use SOCKETSHR
781 $ TCPIP_LIB = "[-.VMS]SOCKETSHR_SHR.OPT/OPT"
785 $ WRITE SYS$OUTPUT "Using SOCKETSHR for TCP/IP"
787 $! Done with SOCKETSHR
791 $! Check to see if MULTINET was chosen
793 $ IF P5.EQS."MULTINET"
796 $! Set the library to use UCX emulation.
802 $ WRITE SYS$OUTPUT "Using MultiNet via UCX emulation for TCP/IP"
804 $! Done with MULTINET
808 $! Check to see if UCX was chosen
813 $! Set the library to use UCX.
815 $ TCPIP_LIB = "[-.VMS]UCX_SHR_DECC.OPT/OPT"
819 $ WRITE SYS$OUTPUT "Using UCX or an emulation thereof for TCP/IP"
825 $! Set the TCPIP_TYPE symbol
831 $ WRITE SYS$OUTPUT "TCP/IP library spec: ", TCPIP_LIB
833 $! Else The User Entered An Invalid Arguement.
839 $! Tell The User We Don't Know What They Want.
841 $ WRITE SYS$OUTPUT ""
842 $ WRITE SYS$OUTPUT "The Option ",P5," Is Invalid. The Valid Options Are:"
843 $ WRITE SYS$OUTPUT ""
844 $ WRITE SYS$OUTPUT " SOCKETSHR : To link with SOCKETSHR TCP/IP library."
845 $ WRITE SYS$OUTPUT " UCX : To link with UCX TCP/IP library."
846 $ WRITE SYS$OUTPUT ""
853 $! Set the TCPIP_TYPE symbol
858 $! Done with TCP/IP libraries
862 $! Special Threads For OpenVMS v7.1 Or Later
864 $! Written By: Richard Levitte
865 $! richard@levitte.org
868 $! Check To See If We Have A Option For P6.
873 $! Get The Version Of VMS We Are Using.
876 $ TMP = F$ELEMENT(0,"-",F$EXTRACT(1,4,F$GETSYI("VERSION")))
877 $ TMP = F$INTEGER(F$ELEMENT(0,".",TMP)+F$ELEMENT(1,".",TMP))
879 $! Check To See If The VMS Version Is v7.1 Or Later.
884 $! We Have OpenVMS v7.1 Or Later, So Use The Special Threads.
886 $ ISSEVEN := ,PTHREAD_USE_D4
888 $! End The VMS Version Check.