1 | dnl Process this file with autoconf to produce a configure script. |
1 | dnl Process this file with autoconf to produce a configure script. |
2 | |
2 | |
3 | AC_PREREQ(2.59) |
3 | AC_PREREQ(2.69) |
4 | AC_INIT |
4 | AC_INIT |
5 | AC_CONFIG_SRCDIR([src/gvpe.C]) |
5 | AC_CONFIG_SRCDIR([src/gvpe.C]) |
6 | AC_CANONICAL_TARGET |
6 | AC_CANONICAL_TARGET |
7 | AM_INIT_AUTOMAKE(gvpe, 2.24) |
7 | AM_INIT_AUTOMAKE(gvpe, 2.25) |
8 | AC_CONFIG_HEADERS([config.h]) |
8 | AC_CONFIG_HEADERS([config.h]) |
9 | AM_MAINTAINER_MODE |
9 | AM_MAINTAINER_MODE |
10 | |
10 | |
11 | AH_TOP([ |
11 | AH_TOP([ |
12 | #ifndef CONFIG_H__ |
12 | #ifndef CONFIG_H__ |
… | |
… | |
45 | # define CLOCALE <clocale> |
45 | # define CLOCALE <clocale> |
46 | #else |
46 | #else |
47 | # define CLOCALE <locale.h> |
47 | # define CLOCALE <locale.h> |
48 | #endif |
48 | #endif |
49 | ]) |
49 | ]) |
50 | |
|
|
51 | dnl Include the macros from the m4/ directory |
|
|
52 | AM_ACLOCAL_INCLUDE(m4) |
|
|
53 | |
50 | |
54 | AM_GNU_GETTEXT([external]) |
51 | AM_GNU_GETTEXT([external]) |
55 | AM_GNU_GETTEXT_VERSION(0.11.5) |
52 | AM_GNU_GETTEXT_VERSION(0.11.5) |
56 | |
53 | |
57 | # Enable GNU extensions. |
54 | # Enable GNU extensions. |
… | |
… | |
330 | |
327 | |
331 | AC_DEFINE_UNQUOTED(ENABLE_DNS, 1, [DNS tunnel protocol support.]) |
328 | AC_DEFINE_UNQUOTED(ENABLE_DNS, 1, [DNS tunnel protocol support.]) |
332 | ] |
329 | ] |
333 | ) |
330 | ) |
334 | |
331 | |
|
|
332 | RSA=3072 |
|
|
333 | AC_ARG_ENABLE(rsa-length, |
|
|
334 | [AS_HELP_STRING(--enable-rsa-length=BITS,[ |
|
|
335 | use BITS rsa keys (default 3072). Allowed values are 2048-10240.])], |
|
|
336 | RSA=$enableval |
|
|
337 | ) |
|
|
338 | AC_DEFINE_UNQUOTED(RSABITS, $RSA, [Size of RSA keys.]) |
|
|
339 | |
335 | HMAC=12 |
340 | HMACSIZE=12 |
336 | AC_ARG_ENABLE(hmac-length, |
341 | AC_ARG_ENABLE(hmac-length, |
337 | [AS_HELP_STRING(--enable-hmac-length=BYTES,[ |
342 | [AS_HELP_STRING(--enable-hmac-length=BYTES,[ |
338 | use a hmac of length BYTES bytes (default 12). Allowed values are 4, 8, 12, 16.])], |
343 | use a hmac of length BYTES bytes (default 12). Allowed values are 4, 8, 12, 16.])], |
339 | HMAC=$enableval |
344 | HMACSIZE=$enableval |
340 | ) |
345 | ) |
341 | AC_DEFINE_UNQUOTED(HMACLENGTH, $HMAC, [Size of HMAC in each packet in bytes.]) |
346 | AC_DEFINE_UNQUOTED(HMACLENGTH, $HMACSIZE, [Size of HMAC in each packet in bytes.]) |
342 | |
347 | |
343 | RAND=8 |
348 | RANDSIZE=12 |
344 | AC_ARG_ENABLE(rand-length, |
349 | AC_ARG_ENABLE(rand-length, |
345 | [AS_HELP_STRING(--enable-rand-length=BYTES, |
350 | [AS_HELP_STRING(--enable-rand-length=BYTES, |
346 | [use BYTES bytes of extra randomness (default 8). Allowed values are 0, 4, 8.])], |
351 | [use BYTES bytes of extra randomness (default 12). Allowed values are 0, 4, 8, 12.])], |
347 | RAND=$enableval |
352 | RANDSIZE=$enableval |
348 | ) |
353 | ) |
349 | AC_DEFINE_UNQUOTED(RAND_SIZE, $RAND, [Add this many bytes of randomness to each packet.]) |
354 | AC_DEFINE_UNQUOTED(RAND_SIZE, $RANDSIZE, [Add this many bytes of randomness to each packet.]) |
350 | |
355 | |
351 | MTU=1500 |
356 | MTU=1500 |
352 | AC_ARG_ENABLE(max-mtu, |
357 | AC_ARG_ENABLE(max-mtu, |
353 | [AS_HELP_STRING(--enable-max-mtu=BYTES,enable mtu sizes upto BYTES bytes (default 1500). Use 9100 for jumbogram support.)], |
358 | [AS_HELP_STRING(--enable-max-mtu=BYTES,enable mtu sizes upto BYTES bytes (default 1500). Use 9100 for jumbogram support.)], |
354 | MTU=$enableval |
359 | MTU=$enableval |
355 | ) |
360 | ) |
356 | AC_DEFINE_UNQUOTED(MAX_MTU, $MTU + 14, [Maximum MTU supported.]) |
361 | AC_DEFINE_UNQUOTED(MAX_MTU, ($MTU + 14), [Maximum MTU supported.]) |
357 | |
362 | |
358 | COMPRESS=1 |
363 | COMPRESS=1 |
359 | AC_ARG_ENABLE(compression, |
364 | AC_ARG_ENABLE(compression, |
360 | [AS_HELP_STRING(--disable-compression,Disable compression support.)], |
365 | [AS_HELP_STRING(--disable-compression,Disable compression support.)], |
361 | if test "x$enableval" = xno; then |
366 | if test "x$enableval" = xno; then |
… | |
… | |
366 | |
371 | |
367 | CIPHER=aes_128_cbc |
372 | CIPHER=aes_128_cbc |
368 | AC_ARG_ENABLE(cipher, |
373 | AC_ARG_ENABLE(cipher, |
369 | [AS_HELP_STRING(--enable-cipher=CIPHER,[ |
374 | [AS_HELP_STRING(--enable-cipher=CIPHER,[ |
370 | Select the symmetric cipher (default "aes-128"). |
375 | Select the symmetric cipher (default "aes-128"). |
371 | Must be one of "bf" (blowfish), "aes-128" (rijndael), "aes-192" or "aes-256".])], |
376 | Must be one of "bf" (blowfish), "aes-128" (rijndael), "aes-192", "aes-256", "camellia-128" or "camellia-256".])], |
372 | if test "x$enableval" = xbf ; then CIPHER=bf_cbc ; fi |
377 | if test "x$enableval" = xbf ; then CIPHER=bf_cbc ; fi |
373 | if test "x$enableval" = xaes-128; then CIPHER=aes_128_cbc; fi |
378 | if test "x$enableval" = xaes-128 ; then CIPHER=aes_128_cbc ; fi |
374 | if test "x$enableval" = xaes-192; then CIPHER=aes_192_cbc; fi |
379 | if test "x$enableval" = xaes-192 ; then CIPHER=aes_192_cbc ; fi |
375 | if test "x$enableval" = xaes-256; then CIPHER=aes_256_cbc; fi |
380 | if test "x$enableval" = xaes-256 ; then CIPHER=aes_256_cbc ; fi |
|
|
381 | if test "x$enableval" = xcamellia-128; then CIPHER=camellia_128_cbc; fi |
|
|
382 | if test "x$enableval" = xcamellia-256; then CIPHER=camellia_256_cbc; fi |
376 | ) |
383 | ) |
377 | AC_DEFINE_UNQUOTED(ENABLE_CIPHER, EVP_${CIPHER}, [Select the symmetric cipher to use.]) |
384 | AC_DEFINE_UNQUOTED(ENABLE_CIPHER, EVP_${CIPHER}, [Select the symmetric cipher to use.]) |
378 | |
385 | |
379 | DIGEST=ripemd160 |
386 | HMAC=sha1 |
380 | AC_ARG_ENABLE(digest, |
387 | AC_ARG_ENABLE(hmac-digest, |
381 | [AS_HELP_STRING(--enable-digest=CIPHER,[ |
388 | [AS_HELP_STRING(--enable-hmac-digest=HMAC,[ |
382 | Select the digest algorithm to use (default "ripemd160"). Must be one of |
389 | Select the HMAC digest algorithm to use (default "sha1"). Must be one of |
383 | "sha512", "sha256", "sha1" (somewhat insecure), "ripemd160", "md5" (insecure) or "md4" (insecure).])], |
390 | "sha512", "sha256", "sha1", "ripemd160", "whirlpool".])], |
|
|
391 | if test "x$enableval" = xwhirlpool; then HMAC=whirlpool; fi |
|
|
392 | if test "x$enableval" = xsha512 ; then HMAC=sha512 ; fi |
|
|
393 | if test "x$enableval" = xsha256 ; then HMAC=sha256 ; fi |
|
|
394 | if test "x$enableval" = xsha1 ; then HMAC=sha1 ; fi |
|
|
395 | if test "x$enableval" = xripemd160; then HMAC=ripemd160; fi |
|
|
396 | ) |
|
|
397 | AC_DEFINE_UNQUOTED(ENABLE_HMAC, EVP_${HMAC}, [Select the HMAC digest algorithm to use.]) |
|
|
398 | |
|
|
399 | AUTH=sha512 |
|
|
400 | AC_ARG_ENABLE(auth-digest, |
|
|
401 | [AS_HELP_STRING(--enable-auth-digest=DIGEST,[ |
|
|
402 | Select the hmac algorithm to use (default "sha512"). Must be one of |
|
|
403 | "sha512", "sha256", "whirlpool".])], |
|
|
404 | if test "x$enableval" = xwhirlpool; then AUTH=whirlpool; fi |
384 | if test "x$enableval" = xsha512 ; then DIGEST=sha512 ; fi |
405 | if test "x$enableval" = xsha512 ; then AUTH=sha512 ; fi |
385 | if test "x$enableval" = xsha256 ; then DIGEST=sha256 ; fi |
406 | if test "x$enableval" = xsha256 ; then AUTH=sha256 ; fi |
386 | if test "x$enableval" = xsha1 ; then DIGEST=sha1 ; fi |
|
|
387 | if test "x$enableval" = xripemd160; then DIGEST=ripemd160; fi |
|
|
388 | if test "x$enableval" = xmd5 ; then DIGEST=md5 ; fi |
|
|
389 | if test "x$enableval" = xmd4 ; then DIGEST=md4 ; fi |
|
|
390 | ) |
407 | ) |
391 | AC_DEFINE_UNQUOTED(ENABLE_DIGEST, EVP_${DIGEST}, [Select the digest algorithm to use.]) |
408 | AC_DEFINE_UNQUOTED(ENABLE_AUTH, EVP_${AUTH}, [Select the auth digest algorithm to use.]) |
392 | |
409 | |
393 | if $CXX -v --help 2>&1 | grep -q fno-rtti; then |
410 | if $CXX -v --help 2>&1 | grep -q fno-rtti; then |
394 | CXXFLAGS="$CXXFLAGS -fno-rtti" |
411 | CXXFLAGS="$CXXFLAGS -fno-rtti" |
395 | fi |
412 | fi |
396 | |
413 | |
… | |
… | |
421 | echo |
438 | echo |
422 | echo "***" |
439 | echo "***" |
423 | echo "*** Configuration Summary" |
440 | echo "*** Configuration Summary" |
424 | echo "***" |
441 | echo "***" |
425 | echo "*** Kernel Iface: $IFTYPE/$IFSUBTYPE" |
442 | echo "*** Kernel Iface: $IFTYPE/$IFSUBTYPE" |
|
|
443 | echo "*** RSA size: $RSA" |
426 | echo "*** Cipher used: $CIPHER" |
444 | echo "*** Cipher used: $CIPHER" |
427 | echo "*** Digest used: $DIGEST" |
445 | echo "*** Digest used: $DIGEST" |
|
|
446 | echo "*** Authdigest: $AUTH" |
428 | echo "*** HMAC length: $HMAC" |
447 | echo "*** HMAC length: $HMAC" |
429 | echo "*** RAND used: $RAND" |
448 | echo "*** RAND used: $RAND" |
430 | echo "*** Max. MTU: $MTU" |
449 | echo "*** Max. MTU: $MTU" |
431 | |
450 | |
432 | echo "***" |
451 | echo "***" |
433 | echo "*** Enable options:" |
452 | echo "*** Enable options:" |
434 | grep ENABLE_ config.h | sed -e 's/^/*** /' |
453 | grep ENABLE_ config.h | sed -e 's/^/*** /' |
435 | |
454 | |
436 | if test "x$DIGEST" = xmd4; then |
|
|
437 | echo "***" |
|
|
438 | echo "*** WARNING: The digest you have chosen ($DIGEST) is known to be insecure" |
|
|
439 | fi |
|
|
440 | |
|
|
441 | if test "x$DIGEST" = xmd5; then |
|
|
442 | echo "***" |
|
|
443 | echo "*** WARNING: The digest you have chosen ($DIGEST) is probably insecure" |
|
|
444 | fi |
|
|
445 | |
|
|
446 | if test "$HMAC" -lt 12; then |
455 | if test "$HMACSIZE" -lt 12; then |
447 | echo "***" |
456 | echo "***" |
448 | echo "*** WARNING: The hmac length you have chosen ($HMAC) is probably insecure" |
457 | echo "*** WARNING: The hmac length you have chosen ($HMACSIZE) is quite insecure" |
449 | fi |
458 | fi |
450 | |
459 | |
451 | if test "$RAND" -lt 8; then |
460 | if test "$RANDSIZE" -lt 12; then |
452 | echo "***" |
461 | echo "***" |
453 | echo "*** WARNING: The random prefix you have chosen ($RAND) is probably insecure" |
462 | echo "*** WARNING: The random prefix you have chosen ($RANDSIZE) is probably insecure" |
454 | fi |
463 | fi |
455 | |
464 | |
456 | echo "***" |
465 | echo "***" |
457 | echo |
466 | echo |
458 | |
467 | |