mirror of
https://github.com/pocoproject/poco.git
synced 2025-12-27 02:39:59 +01:00
244 lines
6.1 KiB
C++
244 lines
6.1 KiB
C++
//
|
|
// HTTPCookie.h
|
|
//
|
|
// $Id: //poco/1.3/Net/include/Poco/Net/HTTPCookie.h#1 $
|
|
//
|
|
// Library: Net
|
|
// Package: HTTP
|
|
// Module: HTTPCookie
|
|
//
|
|
// Definition of the HTTPCookie class.
|
|
//
|
|
// Copyright (c) 2005-2006, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person or organization
|
|
// obtaining a copy of the software and accompanying documentation covered by
|
|
// this license (the "Software") to use, reproduce, display, distribute,
|
|
// execute, and transmit the Software, and to prepare derivative works of the
|
|
// Software, and to permit third-parties to whom the Software is furnished to
|
|
// do so, all subject to the following:
|
|
//
|
|
// The copyright notices in the Software and this entire statement, including
|
|
// the above license grant, this restriction and the following disclaimer,
|
|
// must be included in all copies of the Software, in whole or in part, and
|
|
// all derivative works of the Software, unless such copies or derivative
|
|
// works are solely in the form of machine-executable object code generated by
|
|
// a source language processor.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
|
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
|
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
|
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
// DEALINGS IN THE SOFTWARE.
|
|
//
|
|
|
|
|
|
#ifndef Net_HTTPCookie_INCLUDED
|
|
#define Net_HTTPCookie_INCLUDED
|
|
|
|
|
|
#include "Poco/Net/Net.h"
|
|
|
|
|
|
namespace Poco {
|
|
namespace Net {
|
|
|
|
|
|
class NameValueCollection;
|
|
|
|
|
|
class Net_API HTTPCookie
|
|
/// This class represents a HTTP Cookie.
|
|
///
|
|
/// A cookie is a small amount of information sent by a Web
|
|
/// server to a Web browser, saved by the browser, and later sent back
|
|
/// to the server. A cookie's value can uniquely identify a client, so
|
|
/// cookies are commonly used for session management.
|
|
///
|
|
/// A cookie has a name, a single value, and optional attributes such
|
|
/// as a comment, path and domain qualifiers, a maximum age, and a
|
|
/// version number.
|
|
///
|
|
/// This class supports both the Version 0 (by Netscape) and Version 1
|
|
/// (by RFC 2109) cookie specifications. By default, cookies are created
|
|
/// using Version 0 to ensure the best interoperability.
|
|
{
|
|
public:
|
|
HTTPCookie();
|
|
/// Creates an empty HTTPCookie.
|
|
|
|
explicit HTTPCookie(const std::string& name);
|
|
/// Creates a cookie with the given name.
|
|
/// The cookie never expires.
|
|
|
|
explicit HTTPCookie(const NameValueCollection& nvc);
|
|
/// Creates a cookie from the given NameValueCollection.
|
|
|
|
HTTPCookie(const std::string& name, const std::string& value);
|
|
/// Creates a cookie with the given name and value.
|
|
/// The cookie never expires.
|
|
|
|
HTTPCookie(const HTTPCookie& cookie);
|
|
/// Creates the HTTPCookie by copying another one.
|
|
|
|
~HTTPCookie();
|
|
/// Destroys the HTTPCookie.
|
|
|
|
HTTPCookie& operator = (const HTTPCookie& cookie);
|
|
/// Assigns a cookie.
|
|
|
|
void setVersion(int version);
|
|
/// Sets the version of the cookie.
|
|
///
|
|
/// Version must be either 0 (denoting a Netscape cookie)
|
|
/// or 1 (denoting a RFC 2109 cookie).
|
|
|
|
int getVersion() const;
|
|
/// Returns the version of the cookie, which is
|
|
/// either 0 or 1.
|
|
|
|
void setName(const std::string& name);
|
|
/// Sets the name of the cookie.
|
|
|
|
const std::string& getName() const;
|
|
/// Returns the name of the cookie.
|
|
|
|
void setValue(const std::string& value);
|
|
/// Sets the value of the cookie.
|
|
///
|
|
/// According to the cookie specification, the
|
|
/// size of the value should not exceed 4 Kbytes.
|
|
|
|
const std::string& getValue() const;
|
|
/// Returns the value of the cookie.
|
|
|
|
void setComment(const std::string& comment);
|
|
/// Sets the comment for the cookie.
|
|
///
|
|
/// Comments are only supported for version 1 cookies.
|
|
|
|
const std::string& getComment() const;
|
|
/// Returns the comment for the cookie.
|
|
|
|
void setDomain(const std::string& domain);
|
|
/// Sets the domain for the cookie.
|
|
|
|
const std::string& getDomain() const;
|
|
/// Returns the domain for the cookie.
|
|
|
|
void setPath(const std::string& path);
|
|
/// Sets the path for the cookie.
|
|
|
|
const std::string& getPath() const;
|
|
/// Returns the path for the cookie.
|
|
|
|
void setSecure(bool secure);
|
|
/// Sets the value of the secure flag for
|
|
/// the cookie.
|
|
|
|
bool getSecure() const;
|
|
/// Returns the value of the secure flag
|
|
/// for the cookie.
|
|
|
|
void setMaxAge(int maxAge);
|
|
/// Sets the maximum age in seconds for
|
|
/// the cookie.
|
|
///
|
|
/// A value of -1 causes the cookie to
|
|
/// never expire on the client.
|
|
///
|
|
/// A value of 0 deletes the cookie on
|
|
/// the client.
|
|
|
|
int getMaxAge() const;
|
|
/// Returns the maximum age in seconds for
|
|
/// the cookie.
|
|
|
|
void setHttpOnly(bool flag = true);
|
|
/// Sets the HttpOnly flag for the cookie.
|
|
|
|
bool getHttpOnly() const;
|
|
/// Returns true iff the cookie's HttpOnly flag is set.
|
|
|
|
std::string toString() const;
|
|
/// Returns a string representation of the cookie,
|
|
/// suitable for use in a Set-Cookie header.
|
|
|
|
private:
|
|
int _version;
|
|
std::string _name;
|
|
std::string _value;
|
|
std::string _comment;
|
|
std::string _domain;
|
|
std::string _path;
|
|
bool _secure;
|
|
int _maxAge;
|
|
bool _httpOnly;
|
|
};
|
|
|
|
|
|
//
|
|
// inlines
|
|
//
|
|
inline int HTTPCookie::getVersion() const
|
|
{
|
|
return _version;
|
|
}
|
|
|
|
|
|
inline const std::string& HTTPCookie::getName() const
|
|
{
|
|
return _name;
|
|
}
|
|
|
|
|
|
inline const std::string& HTTPCookie::getValue() const
|
|
{
|
|
return _value;
|
|
}
|
|
|
|
|
|
inline const std::string& HTTPCookie::getComment() const
|
|
{
|
|
return _comment;
|
|
}
|
|
|
|
|
|
inline const std::string& HTTPCookie::getDomain() const
|
|
{
|
|
return _domain;
|
|
}
|
|
|
|
|
|
inline const std::string& HTTPCookie::getPath() const
|
|
{
|
|
return _path;
|
|
}
|
|
|
|
|
|
inline bool HTTPCookie::getSecure() const
|
|
{
|
|
return _secure;
|
|
}
|
|
|
|
|
|
inline int HTTPCookie::getMaxAge() const
|
|
{
|
|
return _maxAge;
|
|
}
|
|
|
|
|
|
inline bool HTTPCookie::getHttpOnly() const
|
|
{
|
|
return _httpOnly;
|
|
}
|
|
|
|
|
|
} } // namespace Poco::Net
|
|
|
|
|
|
#endif // Net_HTTPCookie_INCLUDED
|