/* * Copyright 2008 The WebRTC Project Authors. All rights reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef RTC_BASE_NET_HELPERS_H_ #define RTC_BASE_NET_HELPERS_H_ #if defined(WEBRTC_POSIX) #include #elif WEBRTC_WIN #include // NOLINT #endif #include #include "rtc_base/async_resolver_interface.h" #include "rtc_base/ip_address.h" #include "rtc_base/socket_address.h" #include "rtc_base/synchronization/sequence_checker.h" #include "rtc_base/system/no_unique_address.h" #include "rtc_base/system/rtc_export.h" #include "rtc_base/task_utils/pending_task_safety_flag.h" #include "rtc_base/thread.h" #include "rtc_base/thread_annotations.h" namespace rtc { // AsyncResolver will perform async DNS resolution, signaling the result on // the SignalDone from AsyncResolverInterface when the operation completes. // // This class is thread-compatible, and all methods and destruction needs to // happen from the same rtc::Thread, except for Destroy which is allowed to // happen on another context provided it's not happening concurrently to another // public API call, and is the last access to the object. class RTC_EXPORT AsyncResolver : public AsyncResolverInterface { public: AsyncResolver(); ~AsyncResolver() override; void Start(const SocketAddress& addr) override; bool GetResolvedAddress(int family, SocketAddress* addr) const override; int GetError() const override; void Destroy(bool wait) override; const std::vector& addresses() const; private: void ResolveDone(std::vector addresses, int error) RTC_EXCLUSIVE_LOCKS_REQUIRED(sequence_checker_); void MaybeSelfDestruct(); SocketAddress addr_ RTC_GUARDED_BY(sequence_checker_); std::vector addresses_ RTC_GUARDED_BY(sequence_checker_); int error_ RTC_GUARDED_BY(sequence_checker_); webrtc::ScopedTaskSafety safety_ RTC_GUARDED_BY(sequence_checker_); std::unique_ptr popup_thread_ RTC_GUARDED_BY(sequence_checker_); bool recursion_check_ = false; // Protects against SignalDone calling into Destroy. bool destroy_called_ = false; RTC_NO_UNIQUE_ADDRESS webrtc::SequenceChecker sequence_checker_; }; // rtc namespaced wrappers for inet_ntop and inet_pton so we can avoid // the windows-native versions of these. const char* inet_ntop(int af, const void* src, char* dst, socklen_t size); int inet_pton(int af, const char* src, void* dst); bool HasIPv4Enabled(); bool HasIPv6Enabled(); } // namespace rtc #endif // RTC_BASE_NET_HELPERS_H_