Return to bliss_plugin.c CVS log | Up to [ELWIX - Embedded LightWeight unIX -] / embedaddon / strongswan / src / libstrongswan / plugins / bliss |
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: }