blob: 8f332bde24ceec921fd46162c5060ea02593ce1d [file] [log] [blame]
/*
* Copyright (C) 2019-2022 Igalia S.L. All rights reserved.
* Copyright (C) 2022 Metrological Group B.V.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#pragma once
#if USE(GSTREAMER_WEBRTC)
#include "GRefPtrGStreamer.h"
#include "GUniquePtrGStreamer.h"
#include "RTCDataChannelHandler.h"
#include "RTCDataChannelState.h"
#include "SharedBuffer.h"
#include <wtf/Condition.h>
#include <wtf/Lock.h>
#include <wtf/WeakPtr.h>
namespace WebCore {
class Document;
class RTCDataChannelEvent;
class RTCDataChannelHandlerClient;
struct RTCDataChannelInit;
class GStreamerDataChannelHandler final : public RTCDataChannelHandler {
WTF_MAKE_FAST_ALLOCATED;
public:
explicit GStreamerDataChannelHandler(GRefPtr<GstWebRTCDataChannel>&&);
~GStreamerDataChannelHandler();
static GUniquePtr<GstStructure> fromRTCDataChannelInit(const RTCDataChannelInit&);
static Ref<RTCDataChannelEvent> createDataChannelEvent(Document&, GRefPtr<GstWebRTCDataChannel>&&);
private:
// RTCDataChannelHandler API
void setClient(RTCDataChannelHandlerClient&, ScriptExecutionContextIdentifier) final;
bool sendStringData(const CString&) final;
bool sendRawData(const uint8_t*, size_t) final;
void close() final;
void onMessageData(GBytes*);
void onMessageString(const char*);
void onError(GError*);
void onBufferedAmountLow();
void readyStateChanged();
void checkState();
void postTask(Function<void()>&&);
struct StateChange {
RTCDataChannelState state;
std::optional<GError*> error;
};
using Message = std::variant<StateChange, String, Ref<FragmentedSharedBuffer>>;
using PendingMessages = Vector<Message>;
Lock m_clientLock;
GRefPtr<GstWebRTCDataChannel> m_channel;
std::optional<WeakPtr<RTCDataChannelHandlerClient>> m_client WTF_GUARDED_BY_LOCK(m_clientLock);
ScriptExecutionContextIdentifier m_contextIdentifier;
std::optional<uint64_t> m_previousBufferedAmount;
PendingMessages m_pendingMessages WTF_GUARDED_BY_LOCK(m_clientLock);
Lock m_openLock;
Condition m_openCondition WTF_GUARDED_BY_LOCK(m_openLock);
};
} // namespace WebCore
#endif // USE(GSTREAMER_WEBRTC)