Calling removeTrack on different RTCPeerConnection should throw InvalidAccessError
[WebKit-https.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 "RTCRtpCapabilities.h"
37 #include "RuntimeEnabledFeatures.h"
38
39 namespace WebCore {
40
41 Ref<RTCRtpSender> RTCRtpSender::create(PeerConnectionBackend& connection, Ref<MediaStreamTrack>&& track, Vector<String>&& mediaStreamIds, std::unique_ptr<RTCRtpSenderBackend>&& backend)
42 {
43     auto sender = adoptRef(*new RTCRtpSender(connection, String(track->kind()), WTFMove(mediaStreamIds), WTFMove(backend)));
44     sender->setTrack(WTFMove(track));
45     return sender;
46 }
47
48 Ref<RTCRtpSender> RTCRtpSender::create(PeerConnectionBackend& connection, String&& trackKind, Vector<String>&& mediaStreamIds, std::unique_ptr<RTCRtpSenderBackend>&& backend)
49 {
50     return adoptRef(*new RTCRtpSender(connection, WTFMove(trackKind), WTFMove(mediaStreamIds), WTFMove(backend)));
51 }
52
53 RTCRtpSender::RTCRtpSender(PeerConnectionBackend& connection, String&& trackKind, Vector<String>&& mediaStreamIds, std::unique_ptr<RTCRtpSenderBackend>&& backend)
54     : m_trackKind(WTFMove(trackKind))
55     , m_mediaStreamIds(WTFMove(mediaStreamIds))
56     , m_backend(WTFMove(backend))
57     , m_connection(makeWeakPtr(&connection))
58 {
59     ASSERT(!RuntimeEnabledFeatures::sharedFeatures().webRTCUnifiedPlanEnabled() || m_backend);
60 }
61
62 void RTCRtpSender::setTrackToNull()
63 {
64     ASSERT(m_track);
65     m_trackId = { };
66     m_track = nullptr;
67 }
68
69 void RTCRtpSender::stop()
70 {
71     m_trackId = { };
72     m_track = nullptr;
73     m_backend = nullptr;
74 }
75
76 void RTCRtpSender::setTrack(Ref<MediaStreamTrack>&& track)
77 {
78     ASSERT(!isStopped());
79     if (!m_track)
80         m_trackId = track->id();
81     m_track = WTFMove(track);
82 }
83
84 void RTCRtpSender::replaceTrack(ScriptExecutionContext& context, RefPtr<MediaStreamTrack>&& withTrack, DOMPromiseDeferred<void>&& promise)
85 {
86     if (isStopped()) {
87         promise.reject(InvalidStateError);
88         return;
89     }
90
91     if (withTrack && m_trackKind != withTrack->kind()) {
92         promise.reject(TypeError);
93         return;
94     }
95
96     // FIXME: This whole function should be executed as part of the RTCPeerConnection operation queue.
97     m_backend->replaceTrack(context, *this, WTFMove(withTrack), WTFMove(promise));
98 }
99
100 RTCRtpSendParameters RTCRtpSender::getParameters()
101 {
102     if (isStopped())
103         return { };
104     return m_backend->getParameters();
105 }
106
107 void RTCRtpSender::setParameters(const RTCRtpSendParameters& parameters, DOMPromiseDeferred<void>&& promise)
108 {
109     if (isStopped()) {
110         promise.reject(InvalidStateError);
111         return;
112     }
113     return m_backend->setParameters(parameters, WTFMove(promise));
114 }
115
116 void RTCRtpSender::getStats(Ref<DeferredPromise>&& promise)
117 {
118     if (!m_connection) {
119         promise->reject(InvalidStateError);
120         return;
121     }
122     m_connection->getStats(*this, WTFMove(promise));
123 }
124
125 bool RTCRtpSender::isCreatedBy(const PeerConnectionBackend& connection) const
126 {
127     return &connection == m_connection.get();
128 }
129
130 std::optional<RTCRtpCapabilities> RTCRtpSender::getCapabilities(ScriptExecutionContext& context, const String& kind)
131 {
132     return PeerConnectionBackend::senderCapabilities(context, kind);
133 }
134
135 } // namespace WebCore
136
137 #endif // ENABLE(WEB_RTC)