Annotation of embedaddon/strongswan/src/libradius/radius_client.h, revision 1.1
1.1 ! misho 1: /*
! 2: * Copyright (C) 2009 Martin Willi
! 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 radius_client radius_client
! 18: * @{ @ingroup libradius
! 19: */
! 20:
! 21: #ifndef RADIUS_CLIENT_H_
! 22: #define RADIUS_CLIENT_H_
! 23:
! 24: #include "radius_message.h"
! 25: #include "radius_config.h"
! 26:
! 27: typedef struct radius_client_t radius_client_t;
! 28:
! 29: /**
! 30: * RADIUS client functionality.
! 31: *
! 32: * To communicate with a RADIUS server, create a client and send messages over
! 33: * it. The client allocates a socket from the best RADIUS server available.
! 34: */
! 35: struct radius_client_t {
! 36:
! 37: /**
! 38: * Send a RADIUS request and wait for the response.
! 39: *
! 40: * The client fills in NAS-Identifier nad NAS-Port-Type
! 41: *
! 42: * @param msg RADIUS request message to send
! 43: * @return response, NULL if timed out/verification failed
! 44: */
! 45: radius_message_t* (*request)(radius_client_t *this, radius_message_t *msg);
! 46:
! 47: /**
! 48: * Get the EAP MSK after successful RADIUS authentication.
! 49: *
! 50: * @return MSK, allocated
! 51: */
! 52: chunk_t (*get_msk)(radius_client_t *this);
! 53:
! 54: /**
! 55: * Destroy the client, release the socket.
! 56: */
! 57: void (*destroy)(radius_client_t *this);
! 58: };
! 59:
! 60: /**
! 61: * Create a RADIUS client.
! 62: *
! 63: * @param config reference to a server configuration, gets owned
! 64: * @return radius_client_t object
! 65: */
! 66: radius_client_t *radius_client_create(radius_config_t *config);
! 67:
! 68: #endif /** RADIUS_CLIENT_H_ @}*/
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>