// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_QUIC_QUIC_IN_MEMORY_CACHE_H_ #define NET_QUIC_QUIC_IN_MEMORY_CACHE_H_ #include #include "base/containers/hash_tables.h" #include "base/files/file_util.h" #include "base/memory/singleton.h" #include "base/strings/string_piece.h" #include "net/http/http_response_headers.h" template struct DefaultSingletonTraits; class GURL; namespace net { extern base::FilePath::StringType g_quic_in_memory_cache_dir; namespace test { class QuicInMemoryCachePeer; } // namespace class QuicServer; // In-memory cache for HTTP responses. // Reads from disk cache generated by: // `wget -p --save_headers ` class QuicInMemoryCache { public: enum SpecialResponseType { REGULAR_RESPONSE, // Send the headers and body like a server should. CLOSE_CONNECTION, // Close the connection (sending the close packet). IGNORE_REQUEST, // Do nothing, expect the client to time out. }; // Container for response header/body pairs. class Response { public: Response(); ~Response(); SpecialResponseType response_type() const { return response_type_; } const HttpResponseHeaders& headers() const { return *headers_.get(); } const base::StringPiece body() const { return base::StringPiece(body_); } private: friend class QuicInMemoryCache; void set_headers(scoped_refptr headers) { headers_ = headers; } void set_body(base::StringPiece body) { body.CopyToString(&body_); } SpecialResponseType response_type_; scoped_refptr headers_; std::string body_; DISALLOW_COPY_AND_ASSIGN(Response); }; // Returns the singleton instance of the cache. static QuicInMemoryCache* GetInstance(); // Retrieve a response from this cache for a given request. // If no appropriate response exists, nullptr is returned. // Currently, responses are selected based on request URI only. const Response* GetResponse(const GURL& url) const; // Adds a simple response to the cache. The response headers will // only contain the "content-length" header with the length of |body|. void AddSimpleResponse(base::StringPiece path, base::StringPiece version, base::StringPiece response_code, base::StringPiece response_detail, base::StringPiece body); // Add a response to the cache. void AddResponse(const GURL& url, scoped_refptr response_headers, base::StringPiece response_body); // Simulate a special behavior at a particular path. void AddSpecialResponse(base::StringPiece path, SpecialResponseType response_type); private: typedef base::hash_map ResponseMap; friend struct DefaultSingletonTraits; friend class test::QuicInMemoryCachePeer; QuicInMemoryCache(); ~QuicInMemoryCache(); void ResetForTests(); void Initialize(); std::string GetKey(const GURL& url) const; // Cached responses. ResponseMap responses_; DISALLOW_COPY_AND_ASSIGN(QuicInMemoryCache); }; } // namespace net #endif // NET_QUIC_QUIC_IN_MEMORY_CACHE_H_