Annotation of embedaddon/strongswan/src/libstrongswan/plugins/bliss/bliss_plugin.c, revision 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>