1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_TEST_EMBEDDED_TEST_SERVER_CREATE_WEBSOCKET_HANDLER_H_
#define NET_TEST_EMBEDDED_TEST_SERVER_CREATE_WEBSOCKET_HANDLER_H_
#include <memory>
#include <string_view>
#include "base/functional/callback_forward.h"
#include "base/memory/scoped_refptr.h"
#include "net/test/embedded_test_server/embedded_test_server.h"
#include "net/test/embedded_test_server/websocket_handler.h"
namespace net::test_server {
class WebSocketHandler;
class WebSocketConnection;
using WebSocketHandlerCreator =
base::RepeatingCallback<std::unique_ptr<WebSocketHandler>(
scoped_refptr<WebSocketConnection> connection)>;
// Creates a handler that can be passed to
// EmbeddedTestServer::RegisterUpgradeRequestHandler() to implement a
// WebSocket protocol endpoint on `handle_path`, which should start with
// '/'. `websocket_handler_creator` is called for every valid incoming WebSocket
// handshake request on this path. It should create a subclass of
// WebSocketHandler and return it.
EmbeddedTestServer::HandleUpgradeRequestCallback CreateWebSocketHandler(
std::string_view handle_path,
WebSocketHandlerCreator websocket_handler_creator,
EmbeddedTestServer* server);
// Registers a WebSocket handler for the specified subclass of WebSocketHandler.
// This template function streamlines registration by eliminating the need for
// a separate CreateHandler() method for each handler subclass. Instead, it
// binds the subclass directly to the embedded test server's upgrade request
// handler.
//
// Usage Example:
// RegisterWebSocketHandler<MyWebSocketHandler>(embedded_test_server,
// "/mypath");
// This registers `MyWebSocketHandler` with `embedded_test_server` so that a new
// instance is created for each WebSocket handshake on the specified path.
//
// Template Parameters:
// - Handler: Subclass of WebSocketHandler defining the connection behavior.
//
// Parameters:
// - embedded_test_server: The EmbeddedTestServer to register with.
// - handle_path: Path where the handler responds to WebSocket requests
// (starts with '/').
//
// Requirements:
// - `Handler` must derive from `WebSocketHandler`.
template <typename Handler>
requires std::is_base_of_v<WebSocketHandler, Handler>
void RegisterWebSocketHandler(EmbeddedTestServer* server,
std::string_view handle_path) {
const auto websocket_handler_creator =
base::BindRepeating([](scoped_refptr<WebSocketConnection> connection)
-> std::unique_ptr<WebSocketHandler> {
return std::make_unique<Handler>(std::move(connection));
});
const auto callback =
CreateWebSocketHandler(handle_path, websocket_handler_creator, server);
server->RegisterUpgradeRequestHandler(callback);
}
} // namespace net::test_server
#endif // NET_TEST_EMBEDDED_TEST_SERVER_CREATE_WEBSOCKET_HANDLER_H_
|