Cleanup RuntimeEnabledFeatures includes
[WebKit.git] / Source / WebCore / Modules / mediastream / RTCRtpSender.cpp
1 /*
2  * Copyright (C) 2015 Ericsson AB. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer
12  *    in the documentation and/or other materials provided with the
13  *    distribution.
14  * 3. Neither the name of Ericsson nor the names of its contributors
15  *    may be used to endorse or promote products derived from this
16  *    software without specific prior written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30
31 #include "config.h"
32 #include "RTCRtpSender.h"
33
34 #if ENABLE(WEB_RTC)
35
36 #include "JSDOMPromiseDeferred.h"
37 #include "RTCDTMFSender.h"
38 #include "RTCDTMFSenderBackend.h"
39 #include "RTCRtpCapabilities.h"
40 #include "RTCRtpTransceiver.h"
41 #include <wtf/IsoMallocInlines.h>
42
43 namespace WebCore {
44
45 WTF_MAKE_ISO_ALLOCATED_IMPL(RTCRtpSender);
46
47 Ref<RTCRtpSender> RTCRtpSender::create(PeerConnectionBackend& connection, Ref<MediaStreamTrack>&& track, Vector<String>&& mediaStreamIds, std::unique_ptr<RTCRtpSenderBackend>&& backend)
48 {
49     auto sender = adoptRef(*new RTCRtpSender(connection, String(track->kind()), WTFMove(mediaStreamIds), WTFMove(backend)));
50     sender->setTrack(WTFMove(track));
51     return sender;
52 }
53
54 Ref<RTCRtpSender> RTCRtpSender::create(PeerConnectionBackend& connection, String&& trackKind, Vector<String>&& mediaStreamIds, std::unique_ptr<RTCRtpSenderBackend>&& backend)
55 {
56     return adoptRef(*new RTCRtpSender(connection, WTFMove(trackKind), WTFMove(mediaStreamIds), WTFMove(backend)));
57 }
58
59 RTCRtpSender::RTCRtpSender(PeerConnectionBackend& connection, String&& trackKind, Vector<String>&& mediaStreamIds, std::unique_ptr<RTCRtpSenderBackend>&& backend)
60     : m_trackKind(WTFMove(trackKind))
61     , m_mediaStreamIds(WTFMove(mediaStreamIds))
62     , m_backend(WTFMove(backend))
63     , m_connection(makeWeakPtr(&connection))
64 {
65     ASSERT(m_backend);
66 }
67
68 RTCRtpSender::~RTCRtpSender() = default;
69
70 void RTCRtpSender::setTrackToNull()
71 {
72     ASSERT(m_track);
73     m_trackId = { };
74     m_track = nullptr;
75 }
76
77 void RTCRtpSender::stop()
78 {
79     m_trackId = { };
80     m_track = nullptr;
81     m_backend = nullptr;
82 }
83
84 void RTCRtpSender::setTrack(Ref<MediaStreamTrack>&& track)
85 {
86     ASSERT(!isStopped());
87     if (!m_track)
88         m_trackId = track->id();
89     m_track = WTFMove(track);
90 }
91
92 void RTCRtpSender::replaceTrack(ScriptExecutionContext& context, RefPtr<MediaStreamTrack>&& withTrack, DOMPromiseDeferred<void>&& promise)
93 {
94     if (isStopped()) {
95         promise.reject(InvalidStateError);
96         return;
97     }
98
99     if (withTrack && m_trackKind != withTrack->kind()) {
100         promise.reject(TypeError);
101         return;
102     }
103
104     // FIXME: This whole function should be executed as part of the RTCPeerConnection operation queue.
105     m_backend->replaceTrack(context, *this, WTFMove(withTrack), WTFMove(promise));
106 }
107
108 RTCRtpSendParameters RTCRtpSender::getParameters()
109 {
110     if (isStopped())
111         return { };
112     return m_backend->getParameters();
113 }
114
115 void RTCRtpSender::setParameters(const RTCRtpSendParameters& parameters, DOMPromiseDeferred<void>&& promise)
116 {
117     if (isStopped()) {
118         promise.reject(InvalidStateError);
119         return;
120     }
121     return m_backend->setParameters(parameters, WTFMove(promise));
122 }
123
124 void RTCRtpSender::getStats(Ref<DeferredPromise>&& promise)
125 {
126     if (!m_connection) {
127         promise->reject(InvalidStateError);
128         return;
129     }
130     m_connection->getStats(*this, WTFMove(promise));
131 }
132
133 bool RTCRtpSender::isCreatedBy(const PeerConnectionBackend& connection) const
134 {
135     return &connection == m_connection.get();
136 }
137
138 Optional<RTCRtpCapabilities> RTCRtpSender::getCapabilities(ScriptExecutionContext& context, const String& kind)
139 {
140     return PeerConnectionBackend::senderCapabilities(context, kind);
141 }
142
143 RTCDTMFSender* RTCRtpSender::dtmf()
144 {
145     if (!m_dtmfSender && m_connection && m_connection->context() && m_backend)
146         m_dtmfSender = RTCDTMFSender::create(*m_connection->context(), *this, m_backend->createDTMFBackend());
147
148     return m_dtmfSender.get();
149 }
150
151 Optional<RTCRtpTransceiverDirection> RTCRtpSender::currentTransceiverDirection() const
152 {
153     if (!m_connection)
154         return { };
155
156     auto* transceiver = m_connection->transceiverFromSender(*this);
157     if (!transceiver)
158         return { };
159
160     return transceiver->currentDirection();
161 }
162
163 } // namespace WebCore
164
165 #endif // ENABLE(WEB_RTC)