Annotation of embedaddon/strongswan/src/libstrongswan/plugins/gmp/gmp_plugin.c, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * Copyright (C) 2008-2009 Martin Willi
                      3:  * HSR Hochschule fuer Technik Rapperswil
                      4:  *
                      5:  * This program is free software; you can redistribute it and/or modify it
                      6:  * under the terms of the GNU General Public License as published by the
                      7:  * Free Software Foundation; either version 2 of the License, or (at your
                      8:  * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
                      9:  *
                     10:  * This program is distributed in the hope that it will be useful, but
                     11:  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
                     12:  * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
                     13:  * for more details.
                     14:  */
                     15: 
                     16: #include "gmp_plugin.h"
                     17: 
                     18: #include <library.h>
                     19: #include "gmp_diffie_hellman.h"
                     20: #include "gmp_rsa_private_key.h"
                     21: #include "gmp_rsa_public_key.h"
                     22: 
                     23: typedef struct private_gmp_plugin_t private_gmp_plugin_t;
                     24: 
                     25: /**
                     26:  * private data of gmp_plugin
                     27:  */
                     28: struct private_gmp_plugin_t {
                     29: 
                     30:        /**
                     31:         * public functions
                     32:         */
                     33:        gmp_plugin_t public;
                     34: };
                     35: 
                     36: METHOD(plugin_t, get_name, char*,
                     37:        private_gmp_plugin_t *this)
                     38: {
                     39:        return "gmp";
                     40: }
                     41: 
                     42: METHOD(plugin_t, get_features, int,
                     43:        private_gmp_plugin_t *this, plugin_feature_t *features[])
                     44: {
                     45:        static plugin_feature_t f[] = {
                     46:                /* DH groups */
                     47:                PLUGIN_REGISTER(DH, gmp_diffie_hellman_create),
                     48:                        PLUGIN_PROVIDE(DH, MODP_3072_BIT),
                     49:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     50:                        PLUGIN_PROVIDE(DH, MODP_4096_BIT),
                     51:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     52:                        PLUGIN_PROVIDE(DH, MODP_6144_BIT),
                     53:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     54:                        PLUGIN_PROVIDE(DH, MODP_8192_BIT),
                     55:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     56:                        PLUGIN_PROVIDE(DH, MODP_2048_BIT),
                     57:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     58:                        PLUGIN_PROVIDE(DH, MODP_2048_224),
                     59:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     60:                        PLUGIN_PROVIDE(DH, MODP_2048_256),
                     61:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     62:                        PLUGIN_PROVIDE(DH, MODP_1536_BIT),
                     63:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     64:                        PLUGIN_PROVIDE(DH, MODP_1024_BIT),
                     65:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     66:                        PLUGIN_PROVIDE(DH, MODP_1024_160),
                     67:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     68:                        PLUGIN_PROVIDE(DH, MODP_768_BIT),
                     69:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     70:                PLUGIN_REGISTER(DH, gmp_diffie_hellman_create_custom),
                     71:                        PLUGIN_PROVIDE(DH, MODP_CUSTOM),
                     72:                                PLUGIN_DEPENDS(RNG, RNG_STRONG),
                     73:                        /* private/public keys */
                     74:                PLUGIN_REGISTER(PRIVKEY, gmp_rsa_private_key_load, TRUE),
                     75:                        PLUGIN_PROVIDE(PRIVKEY, KEY_RSA),
                     76:                PLUGIN_REGISTER(PRIVKEY_GEN, gmp_rsa_private_key_gen, FALSE),
                     77:                        PLUGIN_PROVIDE(PRIVKEY_GEN, KEY_RSA),
                     78:                                PLUGIN_DEPENDS(RNG, RNG_TRUE),
                     79:                PLUGIN_REGISTER(PUBKEY, gmp_rsa_public_key_load, TRUE),
                     80:                        PLUGIN_PROVIDE(PUBKEY, KEY_RSA),
                     81:                /* signature schemes, private */
                     82:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PSS),
                     83:                        PLUGIN_SDEPEND(HASHER, HASH_SHA1),
                     84:                        PLUGIN_SDEPEND(HASHER, HASH_SHA256),
                     85:                        PLUGIN_SDEPEND(HASHER, HASH_SHA512),
                     86:                        PLUGIN_SDEPEND(RNG, RNG_STRONG),
                     87:                        PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA1),
                     88:                        PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA256),
                     89:                        PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA512),
                     90:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_NULL),
                     91:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_224),
                     92:                        PLUGIN_DEPENDS(HASHER, HASH_SHA224),
                     93:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_256),
                     94:                        PLUGIN_DEPENDS(HASHER, HASH_SHA256),
                     95:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_384),
                     96:                        PLUGIN_DEPENDS(HASHER, HASH_SHA384),
                     97:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_512),
                     98:                        PLUGIN_DEPENDS(HASHER, HASH_SHA512),
                     99:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA3_224),
                    100:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_224),
                    101:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA3_256),
                    102:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_256),
                    103:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA3_384),
                    104:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_384),
                    105:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA3_512),
                    106:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_512),
                    107:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA1),
                    108:                        PLUGIN_DEPENDS(HASHER, HASH_SHA1),
                    109:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_MD5),
                    110:                        PLUGIN_DEPENDS(HASHER, HASH_MD5),
                    111:                /* signature verification schemes */
                    112:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PSS),
                    113:                        PLUGIN_SDEPEND(HASHER, HASH_SHA1),
                    114:                        PLUGIN_SDEPEND(HASHER, HASH_SHA256),
                    115:                        PLUGIN_SDEPEND(HASHER, HASH_SHA512),
                    116:                        PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA1),
                    117:                        PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA256),
                    118:                        PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA512),
                    119:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_NULL),
                    120:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_224),
                    121:                        PLUGIN_DEPENDS(HASHER, HASH_SHA224),
                    122:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_256),
                    123:                        PLUGIN_DEPENDS(HASHER, HASH_SHA256),
                    124:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_384),
                    125:                        PLUGIN_DEPENDS(HASHER, HASH_SHA384),
                    126:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_512),
                    127:                        PLUGIN_DEPENDS(HASHER, HASH_SHA512),
                    128:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA3_224),
                    129:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_224),
                    130:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA3_256),
                    131:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_256),
                    132:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA3_384),
                    133:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_384),
                    134:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA3_512),
                    135:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_512),
                    136:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA1),
                    137:                        PLUGIN_DEPENDS(HASHER, HASH_SHA1),
                    138:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_MD5),
                    139:                        PLUGIN_DEPENDS(HASHER, HASH_MD5),
                    140:                /* en-/decryption schemes */
                    141:                PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_PKCS1),
                    142:                PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_PKCS1),
                    143:                        PLUGIN_DEPENDS(RNG, RNG_WEAK),
                    144:        };
                    145:        *features = f;
                    146:        return countof(f);
                    147: }
                    148: 
                    149: METHOD(plugin_t, destroy, void,
                    150:        private_gmp_plugin_t *this)
                    151: {
                    152:        free(this);
                    153: }
                    154: 
                    155: /*
                    156:  * see header file
                    157:  */
                    158: plugin_t *gmp_plugin_create()
                    159: {
                    160:        private_gmp_plugin_t *this;
                    161: 
                    162:        INIT(this,
                    163:                .public = {
                    164:                        .plugin = {
                    165:                                .get_name = _get_name,
                    166:                                .get_features = _get_features,
                    167:                                .destroy = _destroy,
                    168:                        },
                    169:                },
                    170:        );
                    171: 
                    172:        return &this->public.plugin;
                    173: }
                    174: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>