/* * Copyright (c) Meta Platforms, Inc. and affiliates. * * 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 THRIFT_ASYNC_TUNFRAMEDASYNCCHANNEL_H_ #define THRIFT_ASYNC_TUNFRAMEDASYNCCHANNEL_H_ 1 #include #include namespace apache { namespace thrift { namespace async { namespace detail { /** * Encapsulation of one outstanding write request on a TUnframedAsyncChannel. */ class TUnframedACWriteRequest : public TAsyncChannelWriteRequestBase { public: typedef std::function VoidCallback; TUnframedACWriteRequest( const VoidCallback& callback, const VoidCallback& errorCallback, transport::TMemoryBuffer* message, TAsyncEventChannel* channel); void write( folly::AsyncTransport* transport, folly::AsyncTransport::WriteCallback* callback) noexcept; void writeSuccess() noexcept; void writeError( size_t bytesWritten, const transport::TTransportException& ex) noexcept; }; /** * Read state for TUnframedAsyncChannel */ template class TUnframedACReadState { public: typedef std::function VoidCallback; typedef ProtocolTraits_ ProtocolTraits; TUnframedACReadState(); ~TUnframedACReadState(); // Methods required by TStreamAsyncChannel void setCallbackBuffer(transport::TMemoryBuffer* buffer) { callbackBuffer_ = buffer; } void unsetCallbackBuffer() { callbackBuffer_ = nullptr; } bool hasReadAheadData() { return (memBuffer_.available_read() > 0); } bool hasPartialMessage() { return (memBuffer_.available_read() > 0); } void getReadBuffer(void** bufReturn, size_t* lenReturn); bool readDataAvailable(size_t len); // Methods specific to TUnframedACReadState void setMaxMessageSize(uint32_t size) { maxMessageSize_ = size; } uint32_t getMaxMessageSize() const { return maxMessageSize_; } ProtocolTraits_* getProtocolTraits() { return &protocolTraits_; } const ProtocolTraits_* getProtocolTraits() const { return &protocolTraits_; } private: bool getMessageLength( uint8_t* buffer, uint32_t bufferLength, uint32_t* messageLength); /// maximum frame size accepted uint32_t maxMessageSize_; apache::thrift::transport::TMemoryBuffer memBuffer_; apache::thrift::transport::TMemoryBuffer* callbackBuffer_; ProtocolTraits_ protocolTraits_; }; } // namespace detail /** * TUnframedAsyncChannel * * This is a TAsyncChannel implementation that reads and writes raw (unframed) * messages. When reading messages, ProtocolTraits_ is used to determine the * end of a message. */ template class TUnframedAsyncChannel : public TStreamAsyncChannel< apache::thrift::async::detail::TUnframedACWriteRequest, apache::thrift::async::detail::TUnframedACReadState< ProtocolTraits_>> { private: typedef TStreamAsyncChannel< apache::thrift::async::detail::TUnframedACWriteRequest, apache::thrift::async::detail::TUnframedACReadState> Parent; typedef TUnframedAsyncChannel Self; public: explicit TUnframedAsyncChannel( const std::shared_ptr& transport) : Parent(transport) {} /** * Helper function to create a shared_ptr. * * This passes in the correct destructor object, since TUnframedAsyncChannel's * destructor is protected and cannot be invoked directly. */ static std::shared_ptr newChannel( const std::shared_ptr& transport) { return std::shared_ptr( new Self(transport), typename Self::Destructor()); } /// size in bytes beyond which we'll reject a given message. void setMaxMessageSize(uint32_t size) { this->readState_.setMaxMessageSize(size); } uint32_t getMaxMessageSize() const { return this->readState_.getMaxMessageSize(); } protected: /** * Protected destructor. * * Users of TUnframedAsyncChannel must never delete it directly. Instead, * invoke destroy(). */ ~TUnframedAsyncChannel() override {} }; } // namespace async } // namespace thrift } // namespace apache #include #endif // THRIFT_ASYNC_TUNFRAMEDASYNCCHANNEL_H_