disabled.hpp 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*
  2. * Copyright (c) 2014, Peter Thorson. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions are met:
  6. * * Redistributions of source code must retain the above copyright
  7. * notice, this list of conditions and the following disclaimer.
  8. * * Redistributions in binary form must reproduce the above copyright
  9. * notice, this list of conditions and the following disclaimer in the
  10. * documentation and/or other materials provided with the distribution.
  11. * * Neither the name of the WebSocket++ Project nor the
  12. * names of its contributors may be used to endorse or promote products
  13. * derived from this software without specific prior written permission.
  14. *
  15. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  16. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  17. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  18. * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
  19. * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  20. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  21. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  22. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  23. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  24. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  25. *
  26. */
  27. #ifndef WEBSOCKETPP_EXTENSION_PERMESSAGE_DEFLATE_DISABLED_HPP
  28. #define WEBSOCKETPP_EXTENSION_PERMESSAGE_DEFLATE_DISABLED_HPP
  29. #include <websocketpp/common/cpp11.hpp>
  30. #include <websocketpp/common/stdint.hpp>
  31. #include <websocketpp/common/system_error.hpp>
  32. #include <websocketpp/http/constants.hpp>
  33. #include <websocketpp/extensions/extension.hpp>
  34. #include <map>
  35. #include <string>
  36. #include <utility>
  37. namespace websocketpp {
  38. namespace extensions {
  39. namespace permessage_deflate {
  40. /// Stub class for use when disabling permessage_deflate extension
  41. /**
  42. * This class is a stub that implements the permessage_deflate interface
  43. * with minimal dependencies. It is used to disable permessage_deflate
  44. * functionality at compile time without loading any unnecessary code.
  45. */
  46. template <typename config>
  47. class disabled {
  48. typedef std::pair<lib::error_code,std::string> err_str_pair;
  49. public:
  50. /// Negotiate extension
  51. /**
  52. * The disabled extension always fails the negotiation with a disabled
  53. * error.
  54. *
  55. * @param offer Attribute from client's offer
  56. * @return Status code and value to return to remote endpoint
  57. */
  58. err_str_pair negotiate(http::attribute_list const &) {
  59. return make_pair(make_error_code(error::disabled),std::string());
  60. }
  61. /// Initialize state
  62. /**
  63. * For the disabled extension state initialization is a no-op.
  64. *
  65. * @param is_server True to initialize as a server, false for a client.
  66. * @return A code representing the error that occurred, if any
  67. */
  68. lib::error_code init(bool) {
  69. return lib::error_code();
  70. }
  71. /// Returns true if the extension is capable of providing
  72. /// permessage_deflate functionality
  73. bool is_implemented() const {
  74. return false;
  75. }
  76. /// Returns true if permessage_deflate functionality is active for this
  77. /// connection
  78. bool is_enabled() const {
  79. return false;
  80. }
  81. /// Generate extension offer
  82. /**
  83. * Creates an offer string to include in the Sec-WebSocket-Extensions
  84. * header of outgoing client requests.
  85. *
  86. * @return A WebSocket extension offer string for this extension
  87. */
  88. std::string generate_offer() const {
  89. return "";
  90. }
  91. /// Compress bytes
  92. /**
  93. * @param [in] in String to compress
  94. * @param [out] out String to append compressed bytes to
  95. * @return Error or status code
  96. */
  97. lib::error_code compress(std::string const &, std::string &) {
  98. return make_error_code(error::disabled);
  99. }
  100. /// Decompress bytes
  101. /**
  102. * @param buf Byte buffer to decompress
  103. * @param len Length of buf
  104. * @param out String to append decompressed bytes to
  105. * @return Error or status code
  106. */
  107. lib::error_code decompress(uint8_t const *, size_t, std::string &) {
  108. return make_error_code(error::disabled);
  109. }
  110. };
  111. } // namespace permessage_deflate
  112. } // namespace extensions
  113. } // namespace websocketpp
  114. #endif // WEBSOCKETPP_EXTENSION_PERMESSAGE_DEFLATE_DISABLED_HPP