/* Firewall Builder Copyright (C) 2000 NetCitadel, LLC Author: Vadim Kurland vadim@vk.crocodile.org $Id: RuleElement.h,v 1.6 2006/09/10 22:40:37 vkurland Exp $ This program is free software which we release under the GNU General Public License. You may redistribute and/or modify this program under the terms of that 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. To get a copy of the GNU General Public License, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef __RULEELEMENT_HH_FLAG__ #define __RULEELEMENT_HH_FLAG__ #include #include #include #include #include #include #include #ifdef _WIN32 // disable "warning C4250: 'libfwbuilder::RuleElementTDst' : inherits 'libfwbuilder::RuleElement::addRef' via dominance" # pragma warning(disable:4250) #endif namespace libfwbuilder { class Rule; class FWReference; class RuleElement : virtual public FWObject { protected: void _initialize(const FWObject *root); public: RuleElement(); RuleElement(const FWObject *root,bool prepopulate); DECLARE_FWOBJECT_SUBTYPE(RuleElement); virtual void fromXML(xmlNodePtr parent) throw(FWException); void setAnyElement(); void reset(); virtual std::string getAnyElementId(); bool isAny(); /** * Adds reference object pointing to 'obj' as a child of 'this'. If * RuleElement contained "any", it is removed */ virtual void addRef(FWObject *obj); /** * Removes reference to given object among children of 'this'. If * this object was the last one, appropriate "any" object is added * instead */ virtual void removeRef(FWObject *obj); bool getNeg(); void setNeg(bool flag); void toggleNeg(); }; class RuleElementSrc : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementSrc); RuleElementSrc(); RuleElementSrc(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementDst : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementDst); RuleElementDst(); RuleElementDst(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementSrv : public ServiceGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementSrv); RuleElementSrv(); RuleElementSrv(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementItf : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementItf); RuleElementItf(); RuleElementItf(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); virtual bool validateChild(FWObject *o); bool checkItfChildOfThisFw(FWObject *o); }; class RuleElementInterval : public IntervalGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementInterval); RuleElementInterval(); RuleElementInterval(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementOSrc : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementOSrc); RuleElementOSrc(); RuleElementOSrc(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementODst : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementODst); RuleElementODst(); RuleElementODst(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementOSrv : public ServiceGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementOSrv); RuleElementOSrv(); RuleElementOSrv(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementTSrc : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementTSrc); RuleElementTSrc(); RuleElementTSrc(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementTDst : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementTDst); RuleElementTDst(); RuleElementTDst(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementTSrv : public ServiceGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementTSrv); RuleElementTSrv(); RuleElementTSrv(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementRDst : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementRDst); RuleElementRDst(); RuleElementRDst(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); }; class RuleElementRGtw : public ObjectGroup, public RuleElement { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementRGtw); RuleElementRGtw(); RuleElementRGtw(const FWObject *root,bool prepopulate); virtual std::string getAnyElementId(); virtual bool validateChild(FWObject *o); bool checkSingleIPAdress(FWObject *o); bool checkReachableIPAdress(FWObject *o); }; class RuleElementRItf : public RuleElementItf { public: DECLARE_FWOBJECT_SUBTYPE(RuleElementRItf); RuleElementRItf(); RuleElementRItf(const FWObject *root,bool prepopulate); virtual bool validateChild(FWObject *o); }; } #endif