49 lines
1.5 KiB
C
49 lines
1.5 KiB
C
|
|
// Copyright 2012 The Chromium Authors
|
||
|
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
|
// found in the LICENSE file.
|
||
|
|
|
||
|
|
#ifndef NET_DNS_ADDRESS_SORTER_H_
|
||
|
|
#define NET_DNS_ADDRESS_SORTER_H_
|
||
|
|
|
||
|
|
#include <memory>
|
||
|
|
#include <vector>
|
||
|
|
|
||
|
|
#include "base/functional/callback.h"
|
||
|
|
#include "net/base/ip_endpoint.h"
|
||
|
|
#include "net/base/net_export.h"
|
||
|
|
|
||
|
|
namespace net {
|
||
|
|
|
||
|
|
class AddressList;
|
||
|
|
|
||
|
|
// Sorts AddressList according to RFC3484, by likelihood of successful
|
||
|
|
// connection. Depending on the platform, the sort could be performed
|
||
|
|
// asynchronously by the OS, or synchronously by local implementation.
|
||
|
|
// AddressSorter does not necessarily preserve port numbers on the sorted list.
|
||
|
|
class NET_EXPORT AddressSorter {
|
||
|
|
public:
|
||
|
|
using CallbackType =
|
||
|
|
base::OnceCallback<void(bool success, std::vector<IPEndPoint> sorted)>;
|
||
|
|
|
||
|
|
AddressSorter(const AddressSorter&) = delete;
|
||
|
|
AddressSorter& operator=(const AddressSorter&) = delete;
|
||
|
|
|
||
|
|
virtual ~AddressSorter() = default;
|
||
|
|
|
||
|
|
// Sorts `endpoints`, which must include at least one IPv6 address.
|
||
|
|
// Calls `callback` upon completion. Could complete synchronously. Could
|
||
|
|
// complete after this AddressSorter is destroyed.
|
||
|
|
virtual void Sort(const std::vector<IPEndPoint>& endpoints,
|
||
|
|
CallbackType callback) const = 0;
|
||
|
|
|
||
|
|
// Creates platform-dependent AddressSorter.
|
||
|
|
static std::unique_ptr<AddressSorter> CreateAddressSorter();
|
||
|
|
|
||
|
|
protected:
|
||
|
|
AddressSorter() = default;
|
||
|
|
};
|
||
|
|
|
||
|
|
} // namespace net
|
||
|
|
|
||
|
|
#endif // NET_DNS_ADDRESS_SORTER_H_
|