⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 acct.c

📁 新的radius程序
💻 C
字号:
/* * acct.c	Accounting routines. * * Version:	$Id: acct.c,v 1.30.2.4.2.1 2007/03/05 14:22:04 aland Exp $ * *   This program is free software; you can redistribute it and/or modify *   it under the terms of the GNU General Public License as published by *   the Free Software Foundation; either version 2 of the License, or *   (at your option) any later version. * *   This program 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 General Public License for more details. * *   You should have received a copy of the GNU General Public License *   along with this program; if not, write to the Free Software *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * * Copyright 2000  The FreeRADIUS server project * Copyright 2000  Miquel van Smoorenburg <miquels@cistron.nl> * Copyright 2000  Alan DeKok <aland@ox.org> * Copyright 2000  Alan Curry <pacman@world.std.com> */static const char rcsid[] = "$Id: acct.c,v 1.30.2.4.2.1 2007/03/05 14:22:04 aland Exp $";#include "autoconf.h"#include <stdlib.h>#include "radiusd.h"#include "modules.h"/* *	rad_accounting: call modules. * *	The return value of this function isn't actually used right now, so *	it's not entirely clear if it is returning the right things. --Pac. */int rad_accounting(REQUEST *request){	int result = RLM_MODULE_OK;	/*	 *	Run the modules only once, before proxying.	 */	if (!request->proxy) {		char		*exec_program;		int		exec_wait;		VALUE_PAIR	*vp;		int		rcode;		int		acct_type = 0;		result = module_preacct(request);		switch (result) {			/*			 *	The module has a number of OK return codes.			 */			case RLM_MODULE_NOOP:			case RLM_MODULE_OK:			case RLM_MODULE_UPDATED:				break;			/*			 *	The module handled the request, stop here.			 */			case RLM_MODULE_HANDLED:				return result;			/*			 *	The module failed, or said the request is			 *	invalid, therefore we stop here.			 */			case RLM_MODULE_FAIL:			case RLM_MODULE_INVALID:			case RLM_MODULE_NOTFOUND:			case RLM_MODULE_REJECT:			case RLM_MODULE_USERLOCK:			default:				return result;		}		/*		 *	Do the data storage before proxying. This is to ensure		 *	that we log the packet, even if the proxy never does.		 */		vp = pairfind(request->config_items, PW_ACCT_TYPE);		if (vp) {			DEBUG2("  Found Acct-Type %s", vp->strvalue);			acct_type = vp->lvalue;		}		result = module_accounting(acct_type, request);		switch (result) {			/*			 *	In case the accounting module returns FAIL,			 *	it's still useful to send the data to the			 *	proxy.			 */			case RLM_MODULE_FAIL:			case RLM_MODULE_NOOP:			case RLM_MODULE_OK:			case RLM_MODULE_UPDATED:				break;			/*			 *	The module handled the request, don't reply.			 */			case RLM_MODULE_HANDLED:				return result;			/*			 *	Neither proxy, nor reply to invalid requests.			 */			case RLM_MODULE_INVALID:			case RLM_MODULE_NOTFOUND:			case RLM_MODULE_REJECT:			case RLM_MODULE_USERLOCK:			default:				return result;		}		/*		 *	See if we need to execute a program.		 *	FIXME: somehow cache this info, and only execute the		 *	program when we receive an Accounting-START packet.		 *	Only at that time we know dynamic IP etc.		 */		exec_program = NULL;		exec_wait = 0;		if ((vp = pairfind(request->reply->vps, PW_EXEC_PROGRAM)) != NULL) {			exec_wait = 0;			exec_program = strdup((char *)vp->strvalue);			pairdelete(&request->reply->vps, PW_EXEC_PROGRAM);		}		if ((vp = pairfind(request->reply->vps, PW_EXEC_PROGRAM_WAIT)) != NULL) {			free(exec_program);			exec_wait = 1;			exec_program = strdup((char *)vp->strvalue);			pairdelete(&request->reply->vps, PW_EXEC_PROGRAM_WAIT);		}		/*		 *	If we want to exec a program, but wait for it,		 *	do it first before sending the reply, or		 *	proxying the packet.		 *		 *	If we're NOT waiting, then also do this now, but		 *	don't check the return code.		 */		if (exec_program) {			/*			 *	Wait for the answer.			 *	Don't look for a user message.			 *	Do look for returned VP's.			 */			rcode = radius_exec_program(exec_program, request,						    exec_wait, NULL, 0,						    request->packet->vps, &vp);			free(exec_program);			/*			 *	Always add the value-pairs to the reply.			 *			 *	If we're not waiting, then the pairs			 *	will be empty, so this won't matter.			 */			pairmove(&request->reply->vps, &vp);			pairfree(&vp);			if (exec_wait) {				if (rcode != 0) {					return result;				}			}		}		/*		 *	Maybe one of the preacct modules has decided		 *	that a proxy should be used.		 */		if ((vp = pairfind(request->config_items, PW_PROXY_TO_REALM))) {			REALM *realm;			/*			 *	Check whether Proxy-To-Realm is			 *	a LOCAL realm.			 */			realm = realm_find(vp->strvalue, TRUE);			if (realm != NULL &&			    realm->acct_ipaddr == htonl(INADDR_NONE)) {				DEBUG("rad_accounting: Cancelling proxy to realm %s, as it is a LOCAL realm.", realm->realm);				pairdelete(&request->config_items, PW_PROXY_TO_REALM);			} else {				/*				 *	Don't reply to the NAS now because				 *	we have to send the proxied packet				 *	before that.				 */				return result;			}		}	}	/*	 *	We get here IF we're not proxying, OR if we've	 *	received the accounting reply from the end server,	 *	THEN we can reply to the NAS.	 *      If the accounting module returns NOOP, the data	 *      storage did not succeed, so radiusd should not send	 *      Accounting-Response.	 */	switch (result) {		/*		 *	Send back an ACK to the NAS.		 */		case RLM_MODULE_OK:		case RLM_MODULE_UPDATED:			request->reply->code = PW_ACCOUNTING_RESPONSE;			break;		/*		 *	The module handled the request, don't reply.		 */		case RLM_MODULE_HANDLED:			break;		/*		 *	Failed to log or to proxy the accounting data,		 *	therefore don't reply to the NAS.		 */		case RLM_MODULE_FAIL:		case RLM_MODULE_INVALID:		case RLM_MODULE_NOOP:		case RLM_MODULE_NOTFOUND:		case RLM_MODULE_REJECT:		case RLM_MODULE_USERLOCK:		default:			break;	}	return result;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -