henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2004 The WebRTC Project Authors. All rights reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
deadbeef | cbecd35 | 2015-09-23 11:50:27 -0700 | [diff] [blame] | 11 | #include "webrtc/base/checks.h" |
henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 12 | #include "webrtc/p2p/base/portallocator.h" |
| 13 | |
henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 14 | namespace cricket { |
| 15 | |
| 16 | PortAllocatorSession::PortAllocatorSession(const std::string& content_name, |
| 17 | int component, |
| 18 | const std::string& ice_ufrag, |
| 19 | const std::string& ice_pwd, |
Peter Boström | 0c4e06b | 2015-10-07 12:23:21 +0200 | [diff] [blame] | 20 | uint32_t flags) |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 21 | : flags_(flags), |
deadbeef | c55fb30 | 2016-05-12 12:51:38 -0700 | [diff] [blame] | 22 | generation_(0), |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 23 | content_name_(content_name), |
| 24 | component_(component), |
deadbeef | cbecd35 | 2015-09-23 11:50:27 -0700 | [diff] [blame] | 25 | ice_ufrag_(ice_ufrag), |
| 26 | ice_pwd_(ice_pwd) { |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 27 | // Pooled sessions are allowed to be created with empty content name, |
| 28 | // component, ufrag and password. |
| 29 | RTC_DCHECK(ice_ufrag.empty() == ice_pwd.empty()); |
henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 30 | } |
| 31 | |
deadbeef | 6de92f9 | 2016-12-12 18:49:32 -0800 | [diff] [blame^] | 32 | bool PortAllocator::SetConfiguration( |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 33 | const ServerAddresses& stun_servers, |
| 34 | const std::vector<RelayServerConfig>& turn_servers, |
Honghai Zhang | b9e7b4a | 2016-06-30 20:52:02 -0700 | [diff] [blame] | 35 | int candidate_pool_size, |
| 36 | bool prune_turn_ports) { |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 37 | bool ice_servers_changed = |
| 38 | (stun_servers != stun_servers_ || turn_servers != turn_servers_); |
| 39 | stun_servers_ = stun_servers; |
| 40 | turn_servers_ = turn_servers; |
Honghai Zhang | b9e7b4a | 2016-06-30 20:52:02 -0700 | [diff] [blame] | 41 | prune_turn_ports_ = prune_turn_ports; |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 42 | |
deadbeef | 6de92f9 | 2016-12-12 18:49:32 -0800 | [diff] [blame^] | 43 | bool candidate_pool_drain_began = |
| 44 | static_cast<int>(pooled_sessions_.size()) != candidate_pool_size_; |
| 45 | if (candidate_pool_drain_began && |
| 46 | candidate_pool_size != candidate_pool_size_) { |
| 47 | LOG(LS_ERROR) << "Trying to change candidate pool size after pool started " |
| 48 | "to be drained."; |
| 49 | return false; |
| 50 | } |
| 51 | if (candidate_pool_size < 0) { |
| 52 | LOG(LS_ERROR) << "Can't set negative pool size."; |
| 53 | return false; |
| 54 | } |
| 55 | candidate_pool_size_ = candidate_pool_size; |
| 56 | |
| 57 | // If sessions need to be recreated, only recreate as many as the current |
| 58 | // pool size if the pool has begun to be drained. |
| 59 | int sessions_needed = candidate_pool_drain_began |
| 60 | ? static_cast<int>(pooled_sessions_.size()) |
| 61 | : candidate_pool_size_; |
| 62 | |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 63 | // If ICE servers changed, throw away any existing pooled sessions and create |
| 64 | // new ones. |
| 65 | if (ice_servers_changed) { |
| 66 | pooled_sessions_.clear(); |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 67 | } |
| 68 | |
deadbeef | 6de92f9 | 2016-12-12 18:49:32 -0800 | [diff] [blame^] | 69 | // If |sessions_needed| is less than the number of pooled sessions, get rid |
| 70 | // of the extras. |
| 71 | while (sessions_needed < static_cast<int>(pooled_sessions_.size())) { |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 72 | pooled_sessions_.front().reset(nullptr); |
| 73 | pooled_sessions_.pop_front(); |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 74 | } |
deadbeef | 6de92f9 | 2016-12-12 18:49:32 -0800 | [diff] [blame^] | 75 | |
| 76 | // If |sessions_needed| is greater than the number of pooled sessions, |
| 77 | // create new sessions. |
| 78 | while (static_cast<int>(pooled_sessions_.size()) < sessions_needed) { |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 79 | PortAllocatorSession* pooled_session = CreateSessionInternal("", 0, "", ""); |
| 80 | pooled_session->StartGettingPorts(); |
| 81 | pooled_sessions_.push_back( |
| 82 | std::unique_ptr<PortAllocatorSession>(pooled_session)); |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 83 | } |
deadbeef | 6de92f9 | 2016-12-12 18:49:32 -0800 | [diff] [blame^] | 84 | return true; |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 85 | } |
| 86 | |
| 87 | std::unique_ptr<PortAllocatorSession> PortAllocator::CreateSession( |
henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 88 | const std::string& content_name, |
| 89 | int component, |
| 90 | const std::string& ice_ufrag, |
| 91 | const std::string& ice_pwd) { |
Taylor Brandstetter | 417eebe | 2016-05-23 16:02:19 -0700 | [diff] [blame] | 92 | auto session = std::unique_ptr<PortAllocatorSession>( |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 93 | CreateSessionInternal(content_name, component, ice_ufrag, ice_pwd)); |
Taylor Brandstetter | 417eebe | 2016-05-23 16:02:19 -0700 | [diff] [blame] | 94 | session->SetCandidateFilter(candidate_filter()); |
| 95 | return session; |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 96 | } |
| 97 | |
| 98 | std::unique_ptr<PortAllocatorSession> PortAllocator::TakePooledSession( |
| 99 | const std::string& content_name, |
| 100 | int component, |
| 101 | const std::string& ice_ufrag, |
| 102 | const std::string& ice_pwd) { |
| 103 | RTC_DCHECK(!ice_ufrag.empty()); |
| 104 | RTC_DCHECK(!ice_pwd.empty()); |
| 105 | if (pooled_sessions_.empty()) { |
| 106 | return nullptr; |
| 107 | } |
| 108 | std::unique_ptr<PortAllocatorSession> ret = |
| 109 | std::move(pooled_sessions_.front()); |
| 110 | ret->SetIceParameters(content_name, component, ice_ufrag, ice_pwd); |
Taylor Brandstetter | 417eebe | 2016-05-23 16:02:19 -0700 | [diff] [blame] | 111 | // According to JSEP, a pooled session should filter candidates only after |
| 112 | // it's taken out of the pool. |
| 113 | ret->SetCandidateFilter(candidate_filter()); |
Taylor Brandstetter | a1c3035 | 2016-05-13 08:15:11 -0700 | [diff] [blame] | 114 | pooled_sessions_.pop_front(); |
| 115 | return ret; |
| 116 | } |
| 117 | |
| 118 | const PortAllocatorSession* PortAllocator::GetPooledSession() const { |
| 119 | if (pooled_sessions_.empty()) { |
| 120 | return nullptr; |
| 121 | } |
| 122 | return pooled_sessions_.front().get(); |
henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 123 | } |
| 124 | |
henrike@webrtc.org | 269fb4b | 2014-10-28 22:20:11 +0000 | [diff] [blame] | 125 | } // namespace cricket |