/* -*-mode:c++; c-file-style: "gnu";-*- */ /* * $Id: HTTPHeader.h,v 1.10 2014/04/23 20:55:08 sebdiaz Exp $ * * Copyright (C) 1996 - 2004 Stephen F. Booth * 2007 Sebastien DIAZ * Part of the GNU cgicc library, http://www.gnu.org/software/cgicc * * 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 3 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA */ #ifndef _HTTPHEADER_H_ #define _HTTPHEADER_H_ 1 #ifdef __GNUG__ # pragma interface #endif /*! \file HTTPHeader.h * \brief Abstract base class for simple HTTP headers * */ #include #include #include "MStreamable.h" #include "HTTPCookie.h" namespace cgicc { // ============================================================ // Class HTTPHeader // ============================================================ /*! \class HTTPHeader HTTPHeader.h cgicc/HTTPHeader.h * \brief Abstract base class for all simple HTTP response headers. * */ class CGICC_API HTTPHeader : public MStreamable { public: /*! \name Constructors and Destructor */ //@{ /*! * \brief Constructor. * \param data The header data. */ HTTPHeader(const std::string& data); /*! * \brief Copy constructor. * \param header The HTTPHeader to copy. */ HTTPHeader(const HTTPHeader& header); /*! * \brief Destructor * */ virtual ~HTTPHeader(); //@} // ============================================================ /*! \name Cookie Management */ //@{ /*! * \brief Set a cookie to go out with this HTTPResponseHeader * \param cookie The HTTPCookie to set */ inline HTTPHeader& setCookie(const HTTPCookie& cookie) { fCookies.push_back(cookie); return *this; } /*! * \brief Get a list of all cookies associated with this header * \return All the cookies associated with this header */ inline const std::vector& getCookies() const { return fCookies; } //@} // ============================================================ /*! \name Accessor Method */ //@{ /*! * Get the data contained in this HTTP header. * @return The data contained in this header. */ inline std::string getData() const { return fData; } //@} // ============================================================ /*! \name Subclass Methods */ //@{ /*! * \brief Write this HTTPHeader to a stream. * * Subclasses must implement this function. * \param out The ostream to which to write. */ virtual void render(std::ostream& out) const = 0; //@} private: HTTPHeader(); std::string fData; std::vector fCookies; }; } // namespace cgicc #endif /* ! _HTTPHEADER_H_ */