📄 diameter_eap_server_fsm.hxx
字号:
/* BEGIN_COPYRIGHT *//* *//* Open Diameter: Open-source software for the Diameter and *//* Diameter related protocols *//* *//* Copyright (C) 2002-2004 Open Diameter Project *//* *//* 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.1 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, write to the Free Software *//* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 *//* USA. *//* *//* In addition, when you copy and redistribute some or the entire part of *//* the source code of this software with or without modification, you *//* MUST include this copyright notice in each copy. *//* *//* If you make any changes that are appeared to be useful, please send *//* sources that include the changed part to *//* diameter-developers@lists.sourceforge.net so that we can reflect your *//* changes to one unified version of this software. *//* *//* END_COPYRIGHT *//* $Id: *//* diameter_eap_server_fsm.hxx Server Statemachine definition for Diameter EAP Application Written by Yoshihiro Ohba Created December 16, 2003.*/#ifndef __EAP_SERVER_FSM_H__#define __EAP_SERVER_FSM_H__#include "framework.h"#include "diameter_eap_parser.hxx"#ifdef WIN32 #if defined(DIAMETER_EAP_SERVER_EXPORT) #define DIAMETER_EAP_SERVER_EXPORTS __declspec(dllexport) #else #define DIAMETER_EAP_SERVER_EXPORTS __declspec(dllimport) #endif#else #define DIAMETER_EAP_SERVER_EXPORTS #define DIAMETER_EAP_SERVER_EXPORTS#endiftypedef AAA_JobHandle<AAA_GroupedJob> DiameterJobHandle;class DiameterEapServerSession;/// State machine for Diameter EAP server. There are two types of/// procedures a Diameter EAP application server does: authentication/// and authorization. Authentication is an act to verify a client./// Authorization is an act to grant a service to a client. In many /// cases authentication occurs before authorization, but the order/// can be reversed in some cases. This server implementation/// supports both orders.////// Functions related to authentication (except for/// ForwardEapResponse() which is used for verifying EAP messages) have/// names starting "Validate" (e.g., ValidateUserName).////// Authorization is performed in the form of either validation of a/// requested attribute value, assignment of an attribute value. The/// assignment of an attribute value may be performed as a/// modification to a requested attribute value or as a new assignment/// without a requested value. It has many member functions for/// authorization of attributes (i.e., AuthorizeXYZ). The/// authorization functions return a boolean value indicating whether/// the authorization of the particular attribute succeeded or not./// Authorization functions for optionally set attributes MUST return/// true when the optional attributes are not set. When an attribute/// is specified as const, the application is not allowed to modify/// the attribute and expected to just judge on whether the given/// attribute value is accepted or not. When an attribute is not/// specified as const, the application is allowed to modify the/// attribute as well as judge on whether the given attribute value is/// accepted or not. Authorization functions with two arguments are/// used for attribute that can be included in both DER and DEA. DER/// and DEA attributes are contained in the first argument (which is/// const) and second argument, respectivily, where the former/// attribute contains a requested value and the latter contains an/// enforced value. The former attributes are not enveloped with/// AAA_ScholorAttribute or AAA_VectorAttributes since they are/// intended to be unmodified.class DIAMETER_EAP_SERVER_EXPORTS DiameterEapServerStateMachine : public AAA_StateMachine<DiameterEapServerStateMachine>, public AAA_EventQueueJob{ friend class DiameterJobMultiplexor; public: /// Constructor. DiameterEapServerStateMachine(DiameterEapServerSession& s, DiameterJobHandle &h); ~DiameterEapServerStateMachine() { handle.Job().Remove(this); } enum { EvSgStart, EvRxEapRequest, EvRxEapSuccess, EvRxEapFailure, EvSgAuthorizationSuccess, EvSgAuthorizationFailure, EvRxDER, EvSgSessionTimeout, EvSgAuthLifetimeTimeout, EvSgAuthGracePeriodTimeout, EvSgTimeout, EvSgDisconnect, EvSgValidDER, EvSgInvalidDER }; /// Store an event and notify the session. inline void Notify(AAA_Event ev) throw (int) { // Enqueue the event. if (AAA_EventQueueJob::Enqueue(ev) <= 0) Abort(); if (handle.Job().Schedule(this) < 0) Abort(); } /// This is used for obtaining the reference to the server session /// object. inline DiameterEapServerSession& Session() { return session; } /// This is used for aborting the state machine. Usually called /// when Notify() fails. virtual void Abort()=0; /// This virtual function is called when an EAP-Response message is /// passed to the EAP backend authenticator. virtual void ForwardEapResponse(std::string &eapMsg)=0; /// This virtual function is called when an EAP-Request message is /// passed from the EAP passthrough authenticator. void SignalContinue(std::string &eapMsg); /// This virtual function is called when an AAA success is signaled /// from the EAP backend authenticator. An EAP-Success message is /// contained in the argument if any. void SignalSuccess(std::string &eapMsg); /// This virtual function is called when an AAA success is signaled /// from the EAP backend authenticator. An EAP-Failure message is /// contained in the argument if any. void SignalFailure(std::string &eapMsg); /// This is used for constructing and sending a /// Diameter-EAP-Request. void SendDEA(); /// Check received DER message. It returns true when DER is valid. /// Otherwise, it returns false. When false is returned, it results /// in generating a DEA message with the Result-Code value set to /// DIAMETER_INVALID_AVP_VALUE. bool CheckDER(); /// Authorization function. This function can be called from an EAP /// server (more specifically, from an EAP method in the EAP server) so /// that authorization can be performed before completing /// authentication. If this function is not called from an EAP /// method, the Diameter EAP server will call this function when it /// receives an EAP-Success message from the EAP server via an EAP /// API. virtual bool Authorize(); /// Check if authorization has been completed successfully. bool AuthorizationDone() { return authorizationDone; } inline AAA_JobData& JobData() { return *handle.Job().Data(); } template <class T> inline T& JobData(Type2Type<T>) { return (T&)*handle.Job().Data(); } /// An authorization function called from Authorize() function. virtual bool AuthorizeOriginHost (const diameter_identity_t &originHost) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeOriginRealm (const diameter_identity_t &originRealm) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeMultiRoundTimeOut (AAA_ScholarAttribute<diameter_unsigned32_t> &multiRoundTimeout) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeServiceType (AAA_ScholarAttribute<diameter_enumerated_t> &serviceType) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeServiceType (const diameter_enumerated_t &serviceType1, AAA_ScholarAttribute<diameter_enumerated_t> &serviceType2) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeClass (AAA_VectorAttribute<diameter_octetstring_t> &Class) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeClass (const std::vector<diameter_octetstring_t> &Class1, AAA_VectorAttribute<diameter_octetstring_t> &Class2) { return true; } /// To be generated only by proxy servers. Derived class /// implementation must resize the vector if needed and fill the /// vector with appropriate set of vector elements when true is /// returned. virtual bool AuthorizeConfigurationToken (AAA_VectorAttribute<diameter_octetstring_t> &configurationToken) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeAcctInterimInterval (AAA_ScholarAttribute<diameter_unsigned32_t> &acctInterimInterval) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeIdleTimeout (AAA_ScholarAttribute<diameter_unsigned32_t> &idleTimeout) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeAuthorizationLifetime (AAA_ScholarAttribute<diameter_unsigned32_t> &authorizationLifetime) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeAuthGracePeriod (AAA_ScholarAttribute<diameter_unsigned32_t> &authGracePeriod) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeAuthSessionState (AAA_ScholarAttribute<diameter_enumerated_t> &authSessionState) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeReAuthRequestType (AAA_ScholarAttribute<diameter_enumerated_t> &reAuthRequestType) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeSessionTimeout (AAA_ScholarAttribute<diameter_unsigned32_t> &sessionTimeout) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizeFilterId (AAA_VectorAttribute<diameter_utf8string_t> &filterId) { return true; } /// An authorization function called from Authorize() function. virtual bool AuthorizePortLimit (AAA_ScholarAttribute<diameter_unsigned32_t> &portLimit)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -