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>