Cookie.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /* <!-- copyright */
  2. /*
  3. * aria2 - The high speed download utility
  4. *
  5. * Copyright (C) 2006 Tatsuhiro Tsujikawa
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. *
  21. * In addition, as a special exception, the copyright holders give
  22. * permission to link the code of portions of this program with the
  23. * OpenSSL library under certain conditions as described in each
  24. * individual source file, and distribute linked combinations
  25. * including the two.
  26. * You must obey the GNU General Public License in all respects
  27. * for all of the code used other than OpenSSL. If you modify
  28. * file(s) with this exception, you may extend this exception to your
  29. * version of the file(s), but you are not obligated to do so. If you
  30. * do not wish to do so, delete this exception statement from your
  31. * version. If you delete this exception statement from all source
  32. * files in the program, then also delete it here.
  33. */
  34. /* copyright --> */
  35. #ifndef _D_COOKIE_H_
  36. #define _D_COOKIE_H_
  37. #include "common.h"
  38. #include <string>
  39. #include "a2time.h"
  40. namespace aria2 {
  41. class Cookie {
  42. private:
  43. std::string name_;
  44. std::string value_;
  45. time_t expiry_;
  46. std::string path_;
  47. std::string domain_;
  48. bool secure_;
  49. time_t creationTime_;
  50. time_t lastAccess_;
  51. public:
  52. /*
  53. * If expires = 0 is given, then the cookie becomes session cookie.
  54. * domain is normalized using normalizeDomain() function and
  55. * assigned to domain_. If domain is not specified in cookie, call
  56. * markOriginServerOnly() after construction.
  57. */
  58. Cookie(const std::string& name,
  59. const std::string& value,
  60. time_t expires,
  61. const std::string& path,
  62. const std::string& domain,
  63. bool secure);
  64. /*
  65. * Creates session cookie. This is equivalent to Cookie(name, value,
  66. * 0, path, domain, secure); domain is normalized using
  67. * normalizeDomain() function and assigned to domain_. If domain is
  68. * not specified in cookie, call markOriginServerOnly() after
  69. * construction.
  70. */
  71. Cookie(const std::string& name,
  72. const std::string& value,
  73. const std::string& path,
  74. const std::string& domain,
  75. bool secure);
  76. Cookie();
  77. ~Cookie();
  78. std::string toString() const;
  79. bool good() const;
  80. bool match(const std::string& requestHost, const std::string& requestPath,
  81. time_t date, bool secure) const;
  82. bool validate(const std::string& requestHost,
  83. const std::string& requestPath) const;
  84. bool operator==(const Cookie& cookie) const;
  85. bool isExpired() const;
  86. const std::string& getName() const
  87. {
  88. return name_;
  89. }
  90. const std::string& getValue() const
  91. {
  92. return value_;
  93. }
  94. const std::string& getPath() const
  95. {
  96. return path_;
  97. }
  98. const std::string& getDomain() const
  99. {
  100. return domain_;
  101. }
  102. time_t getExpiry() const
  103. {
  104. return expiry_;
  105. }
  106. bool isSecureCookie() const
  107. {
  108. return secure_;
  109. }
  110. bool isSessionCookie() const
  111. {
  112. return expiry_ == 0;
  113. }
  114. std::string toNsCookieFormat() const;
  115. // Makes this Cookie only sent to the origin server. This function
  116. // removes first "." from domain_ if domain_ starts with ".".
  117. void markOriginServerOnly();
  118. time_t getCreationTime() const
  119. {
  120. return creationTime_;
  121. }
  122. void updateLastAccess();
  123. time_t getLastAccess() const
  124. {
  125. return lastAccess_;
  126. }
  127. static std::string normalizeDomain(const std::string& domain);
  128. };
  129. } // namespace aria2
  130. #endif // _D_COOKIE_H_