diff options
author | Martin Willi <martin@strongswan.org> | 2009-06-05 11:43:57 +0200 |
---|---|---|
committer | Martin Willi <martin@strongswan.org> | 2009-06-09 11:18:57 +0200 |
commit | 1111088aa7cc6a2ebb577c028da490103e3a663c (patch) | |
tree | 52f6412ce9d976197dd4634cf12661557d63dd59 /src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c | |
parent | a41d0932c2eff104a4702045c7a0662e4469e4fa (diff) | |
download | strongswan-1111088aa7cc6a2ebb577c028da490103e3a663c.tar.bz2 strongswan-1111088aa7cc6a2ebb577c028da490103e3a663c.tar.xz |
gcrypt mpi based Diffie-Hellman implementation
Diffstat (limited to 'src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c')
-rw-r--r-- | src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c b/src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c index 4d1137d44..04eb512d3 100644 --- a/src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c +++ b/src/libstrongswan/plugins/gcrypt/gcrypt_plugin.c @@ -18,6 +18,7 @@ #include "gcrypt_hasher.h" #include "gcrypt_crypter.h" #include "gcrypt_rng.h" +#include "gcrypt_dh.h" #include <library.h> #include <debug.h> @@ -101,6 +102,8 @@ static void destroy(private_gcrypt_plugin_t *this) (crypter_constructor_t)gcrypt_crypter_create); lib->crypto->remove_rng(lib->crypto, (rng_constructor_t)gcrypt_rng_create); + lib->crypto->remove_dh(lib->crypto, + (dh_constructor_t)gcrypt_dh_create); free(this); } @@ -173,6 +176,24 @@ plugin_t *plugin_create() lib->crypto->add_rng(lib->crypto, RNG_TRUE, (rng_constructor_t)gcrypt_rng_create); + /* diffie hellman groups, using modp */ + lib->crypto->add_dh(lib->crypto, MODP_2048_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_1536_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_3072_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_4096_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_6144_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_8192_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_1024_BIT, + (dh_constructor_t)gcrypt_dh_create); + lib->crypto->add_dh(lib->crypto, MODP_768_BIT, + (dh_constructor_t)gcrypt_dh_create); + return &this->public.plugin; } |