blob: 6542413f5ad0472995c8fc56e64d8a4921746d94 [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_BASE_ADDRESS_LIST_H_
#define NET_BASE_ADDRESS_LIST_H_
#include <stdint.h>
#include <string>
#include <vector>
#include "base/compiler_specific.h"
#include "net/base/ip_endpoint.h"
#include "net/base/net_export.h"
struct addrinfo;
namespace base {
class Value;
}
namespace net {
class IPAddress;
class NET_EXPORT AddressList {
public:
AddressList();
AddressList(const AddressList&);
AddressList& operator=(const AddressList&);
AddressList(AddressList&&);
AddressList& operator=(AddressList&&);
~AddressList();
// Creates an address list for a single IP literal.
explicit AddressList(const IPEndPoint& endpoint);
// Creates an address list for a single IP literal and a list of DNS aliases.
AddressList(const IPEndPoint& endpoint, std::vector<std::string> aliases);
static AddressList CreateFromIPAddress(const IPAddress& address,
uint16_t port);
static AddressList CreateFromIPAddressList(const IPAddressList& addresses,
std::vector<std::string> aliases);
// Copies the data from `head` and the chained list into an AddressList.
static AddressList CreateFromAddrinfo(const struct addrinfo* head);
// Returns a copy of `list` with port on each element set to |port|.
static AddressList CopyWithPort(const AddressList& list, uint16_t port);
// TODO(crbug.com/126134): Remove all references to canonical name
// in net::AddressList.
// Here and below, by "canonical name", we mean the value of the name for
// the DNS record that contained the stored-order first IP address stored
// by this class. Note that the canonical name, if set, is now stored as
// the first entry in the vector `dns_aliases_` below.
// Returns the first entry, if it exists, of `dns_aliases_` or an empty
// string otherwise.
const std::string& GetCanonicalName() const;
// Sets the first entry of `dns_aliases_` to the literal of the first IP
// address on the list. Assumes that `dns_aliases_` is empty.
void SetDefaultCanonicalName();
// The alias chain is preserved in reverse order, from canonical name (i.e.
// address record name) through to query name.
const std::vector<std::string>& dns_aliases() const { return dns_aliases_; }
void SetDnsAliases(std::vector<std::string> aliases);
void AppendDnsAliases(std::vector<std::string> aliases);
// Creates a value representation of the address list, appropriate for
// inclusion in a NetLog.
base::Value NetLogParams() const;
// Deduplicates the stored addresses while otherwise preserving their order.
void Deduplicate();
using iterator = std::vector<IPEndPoint>::iterator;
using const_iterator = std::vector<IPEndPoint>::const_iterator;
size_t size() const { return endpoints_.size(); }
bool empty() const { return endpoints_.empty(); }
void clear() { endpoints_.clear(); }
void reserve(size_t count) { endpoints_.reserve(count); }
size_t capacity() const { return endpoints_.capacity(); }
IPEndPoint& operator[](size_t index) { return endpoints_[index]; }
const IPEndPoint& operator[](size_t index) const { return endpoints_[index]; }
IPEndPoint& front() { return endpoints_.front(); }
const IPEndPoint& front() const { return endpoints_.front(); }
IPEndPoint& back() { return endpoints_.back(); }
const IPEndPoint& back() const { return endpoints_.back(); }
void push_back(const IPEndPoint& val) { endpoints_.push_back(val); }
template <typename InputIt>
void insert(iterator pos, InputIt first, InputIt last) {
endpoints_.insert(pos, first, last);
}
iterator begin() { return endpoints_.begin(); }
const_iterator begin() const { return endpoints_.begin(); }
iterator end() { return endpoints_.end(); }
const_iterator end() const { return endpoints_.end(); }
const std::vector<net::IPEndPoint>& endpoints() const { return endpoints_; }
std::vector<net::IPEndPoint>& endpoints() { return endpoints_; }
private:
std::vector<IPEndPoint> endpoints_;
// The first entry, if it exists, is the canonical name.
// The alias chain is preserved in reverse order, from canonical name (i.e.
// address record name) through to query name.
std::vector<std::string> dns_aliases_;
};
} // namespace net
#endif // NET_BASE_ADDRESS_LIST_H_