123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- /*
- * 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 <sys/socket.h>
- #elif WEBRTC_WIN
- #include <winsock2.h> // NOLINT
- #endif
- #include <vector>
- #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<IPAddress>& addresses() const;
- private:
- void ResolveDone(std::vector<IPAddress> addresses, int error)
- RTC_EXCLUSIVE_LOCKS_REQUIRED(sequence_checker_);
- void MaybeSelfDestruct();
- SocketAddress addr_ RTC_GUARDED_BY(sequence_checker_);
- std::vector<IPAddress> addresses_ RTC_GUARDED_BY(sequence_checker_);
- int error_ RTC_GUARDED_BY(sequence_checker_);
- webrtc::ScopedTaskSafety safety_ RTC_GUARDED_BY(sequence_checker_);
- std::unique_ptr<Thread> 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_
|