2000-10-31 21:11:28 +08:00
|
|
|
#
|
2005-03-21 13:24:52 +08:00
|
|
|
# $PostgreSQL: pgsql/contrib/pgcrypto/Makefile,v 1.14 2005/03/21 05:24:51 neilc Exp $
|
2000-10-31 21:11:28 +08:00
|
|
|
#
|
|
|
|
|
2005-03-21 13:17:16 +08:00
|
|
|
# either 'builtin', 'openssl'
|
2000-10-31 21:11:28 +08:00
|
|
|
cryptolib = builtin
|
|
|
|
|
/contrib/pgcrypto:
* remove support for encode() as it is in main tree now
* remove krb5.c
* new 'PX library' architecture
* remove BSD license from my code to let the general
PostgreSQL one to apply
* md5, sha1: ANSIfy, use const where appropriate
* various other formatting and clarity changes
* hmac()
* UN*X-like crypt() - system or internal crypt
* Internal crypt: DES, Extended DES, MD5, Blowfish
crypt-des.c, crypt-md5.c from FreeBSD
crypt-blowfish.c from Solar Designer
* gen_salt() for crypt() - Blowfish, MD5, DES, Extended DES
* encrypt(), decrypt(), encrypt_iv(), decrypt_iv()
* Cipher support in mhash.c, openssl.c
* internal: Blowfish, Rijndael-128 ciphers
* blf.[ch], rijndael.[ch] from OpenBSD
* there will be generated file rijndael-tbl.inc.
Marko Kreen
2001-08-21 08:42:41 +08:00
|
|
|
# either 'builtin', 'system'
|
|
|
|
cryptsrc = builtin
|
|
|
|
|
2001-09-23 12:12:44 +08:00
|
|
|
# Random source, preferred order:
|
|
|
|
# 'dev' - read from random device
|
|
|
|
#
|
|
|
|
# 'openssl' - use openssl PRNG.
|
|
|
|
# Note that currently pgcrypto does not do any
|
|
|
|
# entropy feeding to it
|
|
|
|
# This works ofcouse only with cryptolib = openssl
|
|
|
|
#
|
|
|
|
# 'silly' - use libc random() - very weak
|
2001-09-29 11:11:58 +08:00
|
|
|
random = silly
|
2001-09-23 12:12:44 +08:00
|
|
|
random_dev = \"/dev/urandom\"
|
|
|
|
|
2000-10-31 21:11:28 +08:00
|
|
|
##########################
|
|
|
|
|
|
|
|
ifeq ($(cryptolib), builtin)
|
2001-02-20 23:34:14 +08:00
|
|
|
CRYPTO_CFLAGS =
|
|
|
|
CRYPTO_LDFLAGS =
|
/contrib/pgcrypto:
* remove support for encode() as it is in main tree now
* remove krb5.c
* new 'PX library' architecture
* remove BSD license from my code to let the general
PostgreSQL one to apply
* md5, sha1: ANSIfy, use const where appropriate
* various other formatting and clarity changes
* hmac()
* UN*X-like crypt() - system or internal crypt
* Internal crypt: DES, Extended DES, MD5, Blowfish
crypt-des.c, crypt-md5.c from FreeBSD
crypt-blowfish.c from Solar Designer
* gen_salt() for crypt() - Blowfish, MD5, DES, Extended DES
* encrypt(), decrypt(), encrypt_iv(), decrypt_iv()
* Cipher support in mhash.c, openssl.c
* internal: Blowfish, Rijndael-128 ciphers
* blf.[ch], rijndael.[ch] from OpenBSD
* there will be generated file rijndael-tbl.inc.
Marko Kreen
2001-08-21 08:42:41 +08:00
|
|
|
SRCS = md5.c sha1.c internal.c blf.c rijndael.c
|
2005-03-21 13:24:52 +08:00
|
|
|
EXTRA_TESTS =
|
2000-10-31 21:11:28 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(cryptolib), openssl)
|
2001-02-20 23:34:14 +08:00
|
|
|
CRYPTO_CFLAGS = -I/usr/include/openssl
|
|
|
|
CRYPTO_LDFLAGS = -lcrypto
|
2000-10-31 21:11:28 +08:00
|
|
|
SRCS = openssl.c
|
2005-03-21 13:24:52 +08:00
|
|
|
EXTRA_TESTS = des 3des cast5
|
2000-10-31 21:11:28 +08:00
|
|
|
endif
|
|
|
|
|
/contrib/pgcrypto:
* remove support for encode() as it is in main tree now
* remove krb5.c
* new 'PX library' architecture
* remove BSD license from my code to let the general
PostgreSQL one to apply
* md5, sha1: ANSIfy, use const where appropriate
* various other formatting and clarity changes
* hmac()
* UN*X-like crypt() - system or internal crypt
* Internal crypt: DES, Extended DES, MD5, Blowfish
crypt-des.c, crypt-md5.c from FreeBSD
crypt-blowfish.c from Solar Designer
* gen_salt() for crypt() - Blowfish, MD5, DES, Extended DES
* encrypt(), decrypt(), encrypt_iv(), decrypt_iv()
* Cipher support in mhash.c, openssl.c
* internal: Blowfish, Rijndael-128 ciphers
* blf.[ch], rijndael.[ch] from OpenBSD
* there will be generated file rijndael-tbl.inc.
Marko Kreen
2001-08-21 08:42:41 +08:00
|
|
|
ifeq ($(cryptsrc), builtin)
|
|
|
|
SRCS += crypt-blowfish.c crypt-des.c crypt-md5.c
|
|
|
|
else
|
|
|
|
CRYPTO_CFLAGS += -DPX_SYSTEM_CRYPT
|
2000-10-31 21:11:28 +08:00
|
|
|
endif
|
|
|
|
|
2001-09-23 12:12:44 +08:00
|
|
|
ifeq ($(random), dev)
|
|
|
|
CRYPTO_CFLAGS += -DRAND_DEV=$(random_dev)
|
|
|
|
endif
|
|
|
|
ifeq ($(random), openssl)
|
|
|
|
CRYPTO_CFLAGS += -DRAND_OPENSSL
|
|
|
|
endif
|
|
|
|
ifeq ($(random), silly)
|
|
|
|
CRYPTO_CFLAGS += -DRAND_SILLY
|
|
|
|
endif
|
|
|
|
|
2001-09-29 11:11:58 +08:00
|
|
|
SRCS += pgcrypto.c px.c px-hmac.c px-crypt.c misc.c \
|
|
|
|
crypt-gensalt.c random.c
|
2000-10-31 21:11:28 +08:00
|
|
|
|
2004-08-21 04:13:10 +08:00
|
|
|
MODULE_big = pgcrypto
|
|
|
|
OBJS = $(SRCS:.c=.o)
|
|
|
|
DOCS = README.pgcrypto
|
|
|
|
DATA_built = pgcrypto.sql
|
|
|
|
EXTRA_CLEAN = gen-rtab
|
2000-10-31 21:11:28 +08:00
|
|
|
|
2004-08-21 04:13:10 +08:00
|
|
|
PG_CPPFLAGS = $(CRYPTO_CFLAGS) -I$(srcdir)
|
|
|
|
SHLIB_LINK = $(CRYPTO_LDFLAGS)
|
|
|
|
|
|
|
|
REGRESS = init md5 sha1 hmac-md5 hmac-sha1 blowfish rijndael \
|
2005-03-21 13:24:52 +08:00
|
|
|
$(EXTRA_TESTS) \
|
2001-10-01 06:18:29 +08:00
|
|
|
crypt-des crypt-md5 crypt-blowfish crypt-xdes
|
|
|
|
|
2004-08-21 04:13:10 +08:00
|
|
|
|
|
|
|
ifdef USE_PGXS
|
|
|
|
PGXS = $(shell pg_config --pgxs)
|
|
|
|
include $(PGXS)
|
|
|
|
else
|
|
|
|
subdir = contrib/pgcrypto
|
|
|
|
top_builddir = ../..
|
|
|
|
include $(top_builddir)/src/Makefile.global
|
2001-09-29 11:11:58 +08:00
|
|
|
include $(top_srcdir)/contrib/contrib-global.mk
|
2004-08-21 04:13:10 +08:00
|
|
|
endif
|
|
|
|
|
2004-09-14 11:39:55 +08:00
|
|
|
# to make ws2_32.lib the last library (must occur after definition of PORTNAME)
|
|
|
|
ifeq ($(PORTNAME),win32)
|
|
|
|
SHLIB_LINK += -lwsock32 -lws2_32
|
|
|
|
endif
|
|
|
|
|
2000-10-31 21:11:28 +08:00
|
|
|
|
/contrib/pgcrypto:
* remove support for encode() as it is in main tree now
* remove krb5.c
* new 'PX library' architecture
* remove BSD license from my code to let the general
PostgreSQL one to apply
* md5, sha1: ANSIfy, use const where appropriate
* various other formatting and clarity changes
* hmac()
* UN*X-like crypt() - system or internal crypt
* Internal crypt: DES, Extended DES, MD5, Blowfish
crypt-des.c, crypt-md5.c from FreeBSD
crypt-blowfish.c from Solar Designer
* gen_salt() for crypt() - Blowfish, MD5, DES, Extended DES
* encrypt(), decrypt(), encrypt_iv(), decrypt_iv()
* Cipher support in mhash.c, openssl.c
* internal: Blowfish, Rijndael-128 ciphers
* blf.[ch], rijndael.[ch] from OpenBSD
* there will be generated file rijndael-tbl.inc.
Marko Kreen
2001-08-21 08:42:41 +08:00
|
|
|
rijndael.o: rijndael.tbl
|
|
|
|
|
|
|
|
rijndael.tbl:
|
|
|
|
$(CC) $(CPPFLAGS) $(CFLAGS) -DPRINT_TABS rijndael.c -o gen-rtab
|
|
|
|
./gen-rtab > rijndael.tbl
|