Annotation of embedaddon/strongswan/src/libstrongswan/plugins/bliss/bliss_plugin.c, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * Copyright (C) 2014-2016 Andreas Steffen
                      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 "bliss_plugin.h"
                     17: #include "bliss_private_key.h"
                     18: #include "bliss_public_key.h"
                     19: 
                     20: #include <library.h>
                     21: 
                     22: typedef struct private_bliss_plugin_t private_bliss_plugin_t;
                     23: 
                     24: /**
                     25:  * private data of bliss_plugin
                     26:  */
                     27: struct private_bliss_plugin_t {
                     28: 
                     29:        /**
                     30:         * public functions
                     31:         */
                     32:        bliss_plugin_t public;
                     33: };
                     34: 
                     35: METHOD(plugin_t, get_name, char*,
                     36:        private_bliss_plugin_t *this)
                     37: {
                     38:        return "bliss";
                     39: }
                     40: 
                     41: METHOD(plugin_t, get_features, int,
                     42:        private_bliss_plugin_t *this, plugin_feature_t *features[])
                     43: {
                     44:        static plugin_feature_t f[] = {
                     45:                /* private/public keys */
                     46:                PLUGIN_REGISTER(PRIVKEY, bliss_private_key_load, TRUE),
                     47:                        PLUGIN_PROVIDE(PRIVKEY, KEY_BLISS),
                     48:                PLUGIN_REGISTER(PRIVKEY, bliss_private_key_load, TRUE),
                     49:                        PLUGIN_PROVIDE(PRIVKEY, KEY_ANY),
                     50:                PLUGIN_REGISTER(PRIVKEY_GEN, bliss_private_key_gen, FALSE),
                     51:                        PLUGIN_PROVIDE(PRIVKEY_GEN, KEY_BLISS),
                     52:                                PLUGIN_DEPENDS(RNG, RNG_TRUE),
                     53:                                PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA1),
                     54:                                PLUGIN_SDEPEND(XOF, XOF_MGF1_SHA256),
                     55:                PLUGIN_REGISTER(PUBKEY, bliss_public_key_load, TRUE),
                     56:                        PLUGIN_PROVIDE(PUBKEY, KEY_BLISS),
                     57:                PLUGIN_REGISTER(PUBKEY, bliss_public_key_load, TRUE),
                     58:                        PLUGIN_PROVIDE(PUBKEY, KEY_ANY),
                     59:                /* signature schemes, private */
                     60:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_BLISS_WITH_SHA2_256),
                     61:                        PLUGIN_DEPENDS(HASHER, HASH_SHA256),
                     62:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     63:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_BLISS_WITH_SHA2_384),
                     64:                        PLUGIN_DEPENDS(HASHER, HASH_SHA384),
                     65:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     66:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_BLISS_WITH_SHA2_512),
                     67:                        PLUGIN_DEPENDS(HASHER, HASH_SHA512),
                     68:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     69:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_BLISS_WITH_SHA3_256),
                     70:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_256),
                     71:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     72:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_BLISS_WITH_SHA3_384),
                     73:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_384),
                     74:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     75:                PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_BLISS_WITH_SHA3_512),
                     76:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_512),
                     77:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     78:                /* signature verification schemes */
                     79:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_BLISS_WITH_SHA2_256),
                     80:                        PLUGIN_DEPENDS(HASHER, HASH_SHA256),
                     81:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     82:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_BLISS_WITH_SHA2_384),
                     83:                        PLUGIN_DEPENDS(HASHER, HASH_SHA384),
                     84:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     85:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_BLISS_WITH_SHA2_512),
                     86:                        PLUGIN_DEPENDS(HASHER, HASH_SHA512),
                     87:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     88:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_BLISS_WITH_SHA3_256),
                     89:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_256),
                     90:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     91:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_BLISS_WITH_SHA3_384),
                     92:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_384),
                     93:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     94:                PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_BLISS_WITH_SHA3_512),
                     95:                        PLUGIN_DEPENDS(HASHER, HASH_SHA3_512),
                     96:                        PLUGIN_DEPENDS(XOF, XOF_MGF1_SHA512),
                     97:        };
                     98:        *features = f;
                     99: 
                    100:        return countof(f);
                    101: }
                    102: 
                    103: METHOD(plugin_t, destroy, void,
                    104:        private_bliss_plugin_t *this)
                    105: {
                    106:        free(this);
                    107: }
                    108: 
                    109: /*
                    110:  * see header file
                    111:  */
                    112: plugin_t *bliss_plugin_create()
                    113: {
                    114:        private_bliss_plugin_t *this;
                    115: 
                    116:        INIT(this,
                    117:                .public = {
                    118:                        .plugin = {
                    119:                                .get_name = _get_name,
                    120:                                .get_features = _get_features,
                    121:                                .destroy = _destroy,
                    122:                        },
                    123:                },
                    124:        );
                    125: 
                    126:        return &this->public.plugin;
                    127: }

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