Return to sshkey_builder.h CVS log | Up to [ELWIX - Embedded LightWeight unIX -] / embedaddon / strongswan / src / libstrongswan / plugins / sshkey |
1.1 misho 1: /* 2: * Copyright (C) 2013-2014 Tobias Brunner 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: /** 17: * @defgroup sshkey_public_key sshkey_public_key 18: * @{ @ingroup sshkey_p 19: */ 20: 21: #ifndef SSHKEY_BUILDER_H_ 22: #define SSHKEY_BUILDER_H_ 23: 24: #include <credentials/builder.h> 25: #include <credentials/keys/public_key.h> 26: 27: typedef struct sshkey_public_key_t sshkey_public_key_t; 28: 29: /** 30: * Public key implementation supporting RFC 4253/RFC 5656 decoding. 31: */ 32: struct sshkey_public_key_t { 33: 34: /** 35: * Implements public_key_t interface. 36: */ 37: public_key_t interface; 38: }; 39: 40: /** 41: * Load a public key in RFC 4253 format. 42: * 43: * Takes a BUILD_BLOB_SSHKEY to parse the public key. 44: * 45: * @param type type of the key, must be KEY_ANY 46: * @param args builder_part_t argument list 47: * @return built key, NULL on failure 48: */ 49: sshkey_public_key_t *sshkey_public_key_load(key_type_t type, va_list args); 50: 51: /** 52: * Load a public key in RFC 4253 format as certificate. 53: * 54: * Takes a BUILD_FROM_FILE and BUILD_SUBJECT argument. 55: * 56: * @param type type of the certificate, must be CERT_TRUSTED_PUBKEY 57: * @param args builder_part_t argument list 58: * @return built certificate, NULL on failure 59: */ 60: certificate_t *sshkey_certificate_load(certificate_type_t type, va_list args); 61: 62: #endif /** SSHKEY_BUILDER_H_ @}*/