1*7836SJohn.Forte@Sun.COM /* 2*7836SJohn.Forte@Sun.COM * CDDL HEADER START 3*7836SJohn.Forte@Sun.COM * 4*7836SJohn.Forte@Sun.COM * The contents of this file are subject to the terms of the 5*7836SJohn.Forte@Sun.COM * Common Development and Distribution License (the "License"). 6*7836SJohn.Forte@Sun.COM * You may not use this file except in compliance with the License. 7*7836SJohn.Forte@Sun.COM * 8*7836SJohn.Forte@Sun.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*7836SJohn.Forte@Sun.COM * or http://www.opensolaris.org/os/licensing. 10*7836SJohn.Forte@Sun.COM * See the License for the specific language governing permissions 11*7836SJohn.Forte@Sun.COM * and limitations under the License. 12*7836SJohn.Forte@Sun.COM * 13*7836SJohn.Forte@Sun.COM * When distributing Covered Code, include this CDDL HEADER in each 14*7836SJohn.Forte@Sun.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*7836SJohn.Forte@Sun.COM * If applicable, add the following below this CDDL HEADER, with the 16*7836SJohn.Forte@Sun.COM * fields enclosed by brackets "[]" replaced with your own identifying 17*7836SJohn.Forte@Sun.COM * information: Portions Copyright [yyyy] [name of copyright owner] 18*7836SJohn.Forte@Sun.COM * 19*7836SJohn.Forte@Sun.COM * CDDL HEADER END 20*7836SJohn.Forte@Sun.COM */ 21*7836SJohn.Forte@Sun.COM /* 22*7836SJohn.Forte@Sun.COM * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23*7836SJohn.Forte@Sun.COM * Use is subject to license terms. 24*7836SJohn.Forte@Sun.COM */ 25*7836SJohn.Forte@Sun.COM 26*7836SJohn.Forte@Sun.COM #ifndef _RADIUS_PACKET_H 27*7836SJohn.Forte@Sun.COM #define _RADIUS_PACKET_H 28*7836SJohn.Forte@Sun.COM 29*7836SJohn.Forte@Sun.COM #ifdef __cplusplus 30*7836SJohn.Forte@Sun.COM extern "C" { 31*7836SJohn.Forte@Sun.COM #endif 32*7836SJohn.Forte@Sun.COM 33*7836SJohn.Forte@Sun.COM #include <netinet/in.h> 34*7836SJohn.Forte@Sun.COM #include <sys/types.h> 35*7836SJohn.Forte@Sun.COM 36*7836SJohn.Forte@Sun.COM #include <radius_protocol.h> 37*7836SJohn.Forte@Sun.COM 38*7836SJohn.Forte@Sun.COM /* A total of RAD_RCV_TIMEOUT * RAD_RETRY_MAX seconds timeout. */ 39*7836SJohn.Forte@Sun.COM #define RAD_RCV_TIMEOUT 5 /* Timeout for receiving RADIUS packet in */ 40*7836SJohn.Forte@Sun.COM /* sec. */ 41*7836SJohn.Forte@Sun.COM #define RAD_RETRY_MAX 2 /* Max. # of times to retry receiving */ 42*7836SJohn.Forte@Sun.COM /* packet. */ 43*7836SJohn.Forte@Sun.COM 44*7836SJohn.Forte@Sun.COM /* Describes a RADIUS attribute */ 45*7836SJohn.Forte@Sun.COM typedef struct radius_attr { 46*7836SJohn.Forte@Sun.COM int attr_type_code; /* RADIUS attribute type code, */ 47*7836SJohn.Forte@Sun.COM /* e.g. RAD_USER_PASSWORD, etc. */ 48*7836SJohn.Forte@Sun.COM int attr_value_len; 49*7836SJohn.Forte@Sun.COM uint8_t attr_value[MAX_RAD_ATTR_VALUE_LEN]; 50*7836SJohn.Forte@Sun.COM } radius_attr_t; 51*7836SJohn.Forte@Sun.COM 52*7836SJohn.Forte@Sun.COM /* Describes data fields of a RADIUS packet. */ 53*7836SJohn.Forte@Sun.COM typedef struct radius_packet_data { 54*7836SJohn.Forte@Sun.COM uint8_t code; /* RADIUS code, section 3, RFC 2865. */ 55*7836SJohn.Forte@Sun.COM uint8_t identifier; 56*7836SJohn.Forte@Sun.COM uint8_t authenticator[RAD_AUTHENTICATOR_LEN]; 57*7836SJohn.Forte@Sun.COM int num_of_attrs; 58*7836SJohn.Forte@Sun.COM radius_attr_t attrs[4]; /* For this implementation each */ 59*7836SJohn.Forte@Sun.COM /* outbound RADIUS packet will only */ 60*7836SJohn.Forte@Sun.COM /* have 3 attributes associated with */ 61*7836SJohn.Forte@Sun.COM /* it thus the chosen size should be */ 62*7836SJohn.Forte@Sun.COM /* good enough. */ 63*7836SJohn.Forte@Sun.COM } radius_packet_data_t; 64*7836SJohn.Forte@Sun.COM 65*7836SJohn.Forte@Sun.COM /* 66*7836SJohn.Forte@Sun.COM * Send a request to a RADIUS server. 67*7836SJohn.Forte@Sun.COM * 68*7836SJohn.Forte@Sun.COM * Returns > 0 on success, <= 0 on failure . 69*7836SJohn.Forte@Sun.COM * 70*7836SJohn.Forte@Sun.COM */ 71*7836SJohn.Forte@Sun.COM int 72*7836SJohn.Forte@Sun.COM snd_radius_request(void *socket, 73*7836SJohn.Forte@Sun.COM iscsi_ipaddr_t rsvr_ip_addr, 74*7836SJohn.Forte@Sun.COM uint32_t rsvr_port, 75*7836SJohn.Forte@Sun.COM radius_packet_data_t *packet_data); 76*7836SJohn.Forte@Sun.COM 77*7836SJohn.Forte@Sun.COM #define RAD_RSP_RCVD_SUCCESS 0 78*7836SJohn.Forte@Sun.COM #define RAD_RSP_RCVD_NO_DATA 1 79*7836SJohn.Forte@Sun.COM #define RAD_RSP_RCVD_TIMEOUT 2 80*7836SJohn.Forte@Sun.COM #define RAD_RSP_RCVD_PROTOCOL_ERR 3 81*7836SJohn.Forte@Sun.COM #define RAD_RSP_RCVD_AUTH_FAILED 4 82*7836SJohn.Forte@Sun.COM /* 83*7836SJohn.Forte@Sun.COM * Receives a response from a RADIUS server. 84*7836SJohn.Forte@Sun.COM * 85*7836SJohn.Forte@Sun.COM * Return receive status. 86*7836SJohn.Forte@Sun.COM */ 87*7836SJohn.Forte@Sun.COM int 88*7836SJohn.Forte@Sun.COM rcv_radius_response(void *socket, 89*7836SJohn.Forte@Sun.COM uint8_t *shared_secret, 90*7836SJohn.Forte@Sun.COM uint32_t shared_secret_len, 91*7836SJohn.Forte@Sun.COM uint8_t *req_authenticator, 92*7836SJohn.Forte@Sun.COM radius_packet_data_t *resp_data); 93*7836SJohn.Forte@Sun.COM 94*7836SJohn.Forte@Sun.COM #ifdef __cplusplus 95*7836SJohn.Forte@Sun.COM } 96*7836SJohn.Forte@Sun.COM #endif 97*7836SJohn.Forte@Sun.COM 98*7836SJohn.Forte@Sun.COM #endif /* _RADIUS_PACKET_H */ 99