mirror of https://github.com/grpc/grpc.git
An EventEngine subclass that may be implemented by posix based event engines (#31816)
* An EventEngine subclass to be implemented by all posix based event engines * sanity * comments * update * review comments * re-word * update * review comments * regenerate projects * syntax fix * update class name to avoid conflict * update * rename * rename * update * review comments * rename * update * updatepull/31948/head
parent
1482bf9d18
commit
d370151009
2 changed files with 175 additions and 0 deletions
@ -0,0 +1,159 @@ |
|||||||
|
// Copyright 2022 gRPC Authors
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
#ifndef GRPC_CORE_LIB_EVENT_ENGINE_POSIX_H |
||||||
|
#define GRPC_CORE_LIB_EVENT_ENGINE_POSIX_H |
||||||
|
|
||||||
|
#include <grpc/support/port_platform.h> |
||||||
|
|
||||||
|
#include <functional> |
||||||
|
#include <vector> |
||||||
|
|
||||||
|
#include "absl/functional/any_invocable.h" |
||||||
|
#include "absl/status/status.h" |
||||||
|
|
||||||
|
#include <grpc/event_engine/endpoint_config.h> |
||||||
|
#include <grpc/event_engine/event_engine.h> |
||||||
|
#include <grpc/event_engine/memory_allocator.h> |
||||||
|
#include <grpc/event_engine/port.h> |
||||||
|
#include <grpc/event_engine/slice_buffer.h> |
||||||
|
|
||||||
|
namespace grpc_event_engine { |
||||||
|
namespace experimental { |
||||||
|
|
||||||
|
/// This defines an interface that posix specific event engines endpoints
|
||||||
|
/// may implement to support additional file descriptor related functionality.
|
||||||
|
class PosixEndpointWithFdSupport : public EventEngine::Endpoint { |
||||||
|
public: |
||||||
|
/// Returns the file descriptor associated with the posix endpoint.
|
||||||
|
virtual int GetWrappedFd() = 0; |
||||||
|
|
||||||
|
/// Shutdown the endpoint. This function call should trigger execution of
|
||||||
|
/// any pending endpoint Read/Write callbacks with appropriate error
|
||||||
|
/// absl::Status. After this function call any subsequent endpoint
|
||||||
|
/// Read/Write operations until endpoint deletion should fail with an
|
||||||
|
/// appropriate absl::Status.
|
||||||
|
///
|
||||||
|
/// \a on_release_fd - If specifed, the callback is invoked when the
|
||||||
|
/// endpoint is destroyed/deleted. The underlying file descriptor is
|
||||||
|
/// released instead of being closed. The callback will get the released
|
||||||
|
/// file descriptor as its argument if the release operation is successful.
|
||||||
|
/// Otherwise it would get an appropriate error status as its argument.
|
||||||
|
virtual void Shutdown(absl::AnyInvocable<void(absl::StatusOr<int> release_fd)> |
||||||
|
on_release_fd) = 0; |
||||||
|
}; |
||||||
|
|
||||||
|
/// Defines an interface that posix event engine listeners may implement to
|
||||||
|
/// support additional file descriptor related functionality.
|
||||||
|
class PosixListenerWithFdSupport : public EventEngine::Listener { |
||||||
|
public: |
||||||
|
/// Called when a posix listener bind operation completes. A single bind
|
||||||
|
/// operation may trigger creation of multiple listener fds. This callback
|
||||||
|
/// should be invoked once on each newly created and bound fd. If the
|
||||||
|
/// corresponding bind operation fails for a particular fd, this callback
|
||||||
|
/// must be invoked with a absl::FailedPreConditionError status.
|
||||||
|
///
|
||||||
|
/// \a listener_fd - The listening socket fd that was bound to the specified
|
||||||
|
/// address.
|
||||||
|
using OnPosixBindNewFdCallback = |
||||||
|
absl::AnyInvocable<void(absl::StatusOr<int> listener_fd)>; |
||||||
|
/// Bind an address/port to this Listener.
|
||||||
|
///
|
||||||
|
/// It is expected that multiple addresses/ports can be bound to this
|
||||||
|
/// Listener before Listener::Start has been called. Returns either the
|
||||||
|
/// bound port or an appropriate error status.
|
||||||
|
/// \a addr - The address to listen for incoming connections.
|
||||||
|
/// \a on_bind_new_fd The callback is invoked once for each newly bound
|
||||||
|
/// listener fd that may be created by this Bind operation.
|
||||||
|
virtual absl::StatusOr<int> BindWithFd( |
||||||
|
const EventEngine::ResolvedAddress& addr, |
||||||
|
OnPosixBindNewFdCallback on_bind_new_fd) = 0; |
||||||
|
|
||||||
|
/// Handle an externally accepted client connection. It must return an
|
||||||
|
/// appropriate error status in case of failure.
|
||||||
|
///
|
||||||
|
/// This may be invoked to process a new client connection accepted by an
|
||||||
|
/// external listening fd.
|
||||||
|
/// \a listener_fd - The external listening socket fd that accepted the new
|
||||||
|
/// client connection.
|
||||||
|
/// \a fd - The socket file descriptor representing the new client
|
||||||
|
/// connection.
|
||||||
|
/// \a pending_data - If specified, it holds any pending data that may have
|
||||||
|
/// already been read over the externally accepted client connection.
|
||||||
|
/// Otherwise, it is assumed that no data has been read over the new client
|
||||||
|
/// connection.
|
||||||
|
virtual absl::Status HandleExternalConnection(int listener_fd, int fd, |
||||||
|
SliceBuffer* pending_data) = 0; |
||||||
|
|
||||||
|
/// Shutdown/stop listening on all bind Fds.
|
||||||
|
virtual void ShutdownListeningFds() = 0; |
||||||
|
}; |
||||||
|
|
||||||
|
/// Defines an interface that posix event engines may implement to
|
||||||
|
/// support additional file descriptor related functionality.
|
||||||
|
class PosixEventEngineWithFdSupport : public EventEngine { |
||||||
|
public: |
||||||
|
/// Creates a posix specific EventEngine::Endpoint from an fd which is already
|
||||||
|
/// assumed to be connected to a remote peer. \a fd - The connected socket
|
||||||
|
/// file descriptor. \a config - Additional configuration to applied to the
|
||||||
|
/// endpoint. \a memory_allocator - The endpoint may use the provided memory
|
||||||
|
/// allocator to track memory allocations.
|
||||||
|
virtual std::unique_ptr<PosixEndpointWithFdSupport> CreatePosixEndpointFromFd( |
||||||
|
int fd, const EndpointConfig& config, |
||||||
|
MemoryAllocator memory_allocator) = 0; |
||||||
|
|
||||||
|
/// Called when the posix listener has accepted a new client connection.
|
||||||
|
/// \a listener_fd - The listening socket fd that accepted the new client
|
||||||
|
/// connection.
|
||||||
|
/// \a endpoint - The EventEngine endpoint to handle data exchange over the
|
||||||
|
/// new client connection.
|
||||||
|
/// \a is_external - A boolean indicating whether the new client connection
|
||||||
|
/// is accepted by an external listener_fd or by a listener_fd that is
|
||||||
|
/// managed by the event engine listener.
|
||||||
|
/// \a memory_allocator - The callback may use the provided memory
|
||||||
|
/// allocator to handle memory allocation operations.
|
||||||
|
/// \a pending_data - If specified, it holds any pending data that may have
|
||||||
|
/// already been read over the new client connection. Otherwise, it is
|
||||||
|
/// assumed that no data has been read over the new client connection.
|
||||||
|
using PosixAcceptCallback = absl::AnyInvocable<void( |
||||||
|
int listener_fd, std::unique_ptr<EventEngine::Endpoint> endpoint, |
||||||
|
bool is_external, MemoryAllocator memory_allocator, |
||||||
|
SliceBuffer* pending_data)>; |
||||||
|
|
||||||
|
/// Factory method to create a posix specific network listener / server with
|
||||||
|
/// fd support.
|
||||||
|
///
|
||||||
|
/// Once a \a Listener is created and started, the \a on_accept callback will
|
||||||
|
/// be called once asynchronously for each established connection. This method
|
||||||
|
/// may return a non-OK status immediately if an error was encountered in any
|
||||||
|
/// synchronous steps required to create the Listener. In this case,
|
||||||
|
/// \a on_shutdown will never be called.
|
||||||
|
///
|
||||||
|
/// If this method returns a Listener, then \a on_shutdown will be invoked
|
||||||
|
/// exactly once, when the Listener is shut down. The status passed to it will
|
||||||
|
/// indicate if there was a problem during shutdown.
|
||||||
|
///
|
||||||
|
/// The provided \a MemoryAllocatorFactory is used to create \a
|
||||||
|
/// MemoryAllocators for Endpoint construction.
|
||||||
|
virtual absl::StatusOr<std::unique_ptr<PosixListenerWithFdSupport>> |
||||||
|
CreatePosixListener( |
||||||
|
PosixAcceptCallback on_accept, |
||||||
|
absl::AnyInvocable<void(absl::Status)> on_shutdown, |
||||||
|
const EndpointConfig& config, |
||||||
|
std::unique_ptr<MemoryAllocatorFactory> memory_allocator_factory) = 0; |
||||||
|
}; |
||||||
|
|
||||||
|
} // namespace experimental
|
||||||
|
} // namespace grpc_event_engine
|
||||||
|
|
||||||
|
#endif // GRPC_CORE_LIB_EVENT_ENGINE_POSIX_H
|
Loading…
Reference in new issue