| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 | /** * Copyright (c) 2019-2021 Paul-Louis Ageneau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */#ifndef RTC_CHANNEL_H#define RTC_CHANNEL_H#include "common.hpp"#include <atomic>#include <functional>namespace rtc {namespace impl {struct Channel;}class RTC_CPP_EXPORT Channel : private CheshireCat<impl::Channel> {public:	virtual ~Channel();	virtual void close() = 0;	virtual bool send(message_variant data) = 0; // returns false if buffered	virtual bool send(const byte *data, size_t size) = 0;	virtual bool isOpen() const = 0;	virtual bool isClosed() const = 0;	virtual size_t maxMessageSize() const; // max message size in a call to send	virtual size_t bufferedAmount() const; // total size buffered to send	void onOpen(std::function<void()> callback);	void onClosed(std::function<void()> callback);	void onError(std::function<void(string error)> callback);	void onMessage(std::function<void(message_variant data)> callback);	void onMessage(std::function<void(binary data)> binaryCallback,	               std::function<void(string data)> stringCallback);	void onBufferedAmountLow(std::function<void()> callback);	void setBufferedAmountLowThreshold(size_t amount);	void resetCallbacks();	// Extended API	optional<message_variant> receive(); // only if onMessage unset	optional<message_variant> peek();    // only if onMessage unset	size_t availableAmount() const;      // total size available to receive	void onAvailable(std::function<void()> callback);protected:	Channel(impl_ptr<impl::Channel> impl);};} // namespace rtc#endif // RTC_CHANNEL_H
 |