radius_packet.h revision a6d42e7d71324c5193c3b94d57d96ba2925d52e1
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2008 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#ifndef _RADIUS_PACKET_H
#define _RADIUS_PACKET_H
#ifdef __cplusplus
extern "C" {
#endif
/* A total of RAD_RCV_TIMEOUT * RAD_RETRY_MAX seconds timeout. */
/* sec. */
/* packet. */
/* Describes a RADIUS attribute */
typedef struct radius_attr {
int attr_type_code; /* RADIUS attribute type code, */
/* e.g. RAD_USER_PASSWORD, etc. */
int attr_value_len;
/* Describes data fields of a RADIUS packet. */
typedef struct radius_packet_data {
int num_of_attrs;
/* outbound RADIUS packet will only */
/* have 3 attributes associated with */
/* it thus the chosen size should be */
/* good enough. */
/*
* Send a request to a RADIUS server.
*
* Returns > 0 on success, <= 0 on failure .
*
*/
int
iscsit_snd_radius_request(void *socket,
#define RAD_RSP_RCVD_SUCCESS 0
#define RAD_RSP_RCVD_NO_DATA 1
#define RAD_RSP_RCVD_TIMEOUT 2
#define RAD_RSP_RCVD_PROTOCOL_ERR 3
#define RAD_RSP_RCVD_AUTH_FAILED 4
/*
* Receives a response from a RADIUS server.
*
* Return receive status.
*/
int
iscsit_rcv_radius_response(void *socket,
#ifdef __cplusplus
}
#endif
#endif /* _RADIUS_PACKET_H */