107 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			107 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /*
 | ||
|  |  * QEMU crypto TLS Pre-Shared Key (PSK) support | ||
|  |  * | ||
|  |  * Copyright (c) 2018 Red Hat, Inc. | ||
|  |  * | ||
|  |  * This library is free software; you can redistribute it and/or | ||
|  |  * modify it under the terms of the GNU Lesser General Public | ||
|  |  * License as published by the Free Software Foundation; either | ||
|  |  * version 2 of the License, or (at your option) any later version. | ||
|  |  * | ||
|  |  * This library is distributed in the hope that it will be useful, | ||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||
|  |  * Lesser General Public License for more details. | ||
|  |  * | ||
|  |  * You should have received a copy of the GNU Lesser General Public | ||
|  |  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | ||
|  |  * | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef QCRYPTO_TLSCREDSPSK_H
 | ||
|  | #define QCRYPTO_TLSCREDSPSK_H
 | ||
|  | 
 | ||
|  | #include "crypto/tlscreds.h"
 | ||
|  | 
 | ||
|  | #define TYPE_QCRYPTO_TLS_CREDS_PSK "tls-creds-psk"
 | ||
|  | #define QCRYPTO_TLS_CREDS_PSK(obj)                  \
 | ||
|  |     OBJECT_CHECK(QCryptoTLSCredsPSK, (obj), TYPE_QCRYPTO_TLS_CREDS_PSK) | ||
|  | 
 | ||
|  | typedef struct QCryptoTLSCredsPSK QCryptoTLSCredsPSK; | ||
|  | typedef struct QCryptoTLSCredsPSKClass QCryptoTLSCredsPSKClass; | ||
|  | 
 | ||
|  | #define QCRYPTO_TLS_CREDS_PSKFILE "keys.psk"
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * QCryptoTLSCredsPSK: | ||
|  |  * | ||
|  |  * The QCryptoTLSCredsPSK object provides a representation | ||
|  |  * of the Pre-Shared Key credential used to perform a TLS handshake. | ||
|  |  * | ||
|  |  * This is a user creatable object, which can be instantiated | ||
|  |  * via object_new_propv(): | ||
|  |  * | ||
|  |  * <example> | ||
|  |  *   <title>Creating TLS-PSK credential objects in code</title> | ||
|  |  *   <programlisting> | ||
|  |  *   Object *obj; | ||
|  |  *   Error *err = NULL; | ||
|  |  *   obj = object_new_propv(TYPE_QCRYPTO_TLS_CREDS_PSK, | ||
|  |  *                          "tlscreds0", | ||
|  |  *                          &err, | ||
|  |  *                          "dir", "/path/to/dir", | ||
|  |  *                          "endpoint", "client", | ||
|  |  *                          NULL); | ||
|  |  *   </programlisting> | ||
|  |  * </example> | ||
|  |  * | ||
|  |  * Or via QMP: | ||
|  |  * | ||
|  |  * <example> | ||
|  |  *   <title>Creating TLS-PSK credential objects via QMP</title> | ||
|  |  *   <programlisting> | ||
|  |  *    { | ||
|  |  *       "execute": "object-add", "arguments": { | ||
|  |  *          "id": "tlscreds0", | ||
|  |  *          "qom-type": "tls-creds-psk", | ||
|  |  *          "props": { | ||
|  |  *             "dir": "/path/to/dir", | ||
|  |  *             "endpoint": "client" | ||
|  |  *          } | ||
|  |  *       } | ||
|  |  *    } | ||
|  |  *   </programlisting> | ||
|  |  * </example> | ||
|  |  * | ||
|  |  * Or via the CLI: | ||
|  |  * | ||
|  |  * <example> | ||
|  |  *   <title>Creating TLS-PSK credential objects via CLI</title> | ||
|  |  *   <programlisting> | ||
|  |  *  qemu-system-x86_64 --object tls-creds-psk,id=tlscreds0,\ | ||
|  |  *          endpoint=client,dir=/path/to/dir[,username=qemu] | ||
|  |  *   </programlisting> | ||
|  |  * </example> | ||
|  |  * | ||
|  |  * The PSK file can be created and managed using psktool. | ||
|  |  */ | ||
|  | 
 | ||
|  | struct QCryptoTLSCredsPSK { | ||
|  |     QCryptoTLSCreds parent_obj; | ||
|  |     char *username; | ||
|  | #ifdef CONFIG_GNUTLS
 | ||
|  |     union { | ||
|  |         gnutls_psk_server_credentials_t server; | ||
|  |         gnutls_psk_client_credentials_t client; | ||
|  |     } data; | ||
|  | #endif
 | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | struct QCryptoTLSCredsPSKClass { | ||
|  |     QCryptoTLSCredsClass parent_class; | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | #endif /* QCRYPTO_TLSCREDSPSK_H */
 |