// Copyright (C) 2014-2020 Internet Systems Consortium, Inc. ("ISC") // // This Source Code Form is subject to the terms of the Mozilla Public // License, v. 2.0. If a copy of the MPL was not distributed with this // file, You can obtain one at http://mozilla.org/MPL/2.0/. #ifndef CFG_HOSTS_H #define CFG_HOSTS_H #include #include #include #include #include #include #include #include #include namespace isc { namespace dhcp { /// @brief Represents the host reservations specified in the configuration file. /// /// This class holds a collection of the host reservations (@c Host objects) /// which can be retrieved using different search criteria. /// /// In the typical case the reservations are searched using the client's MAC /// address or DUID and a subnet that the client is connected to. The /// reservations can be also retrieved using other parameters, such as reserved /// IP address. /// /// The reservations are added to this object by the configuration parsers, /// when the new configuration is applied for the server. The reservations /// are retrieved by the @c HostMgr class when the server is allocating or /// renewing an address or prefix for the particular client. class CfgHosts : public BaseHostDataSource, public WritableHostDataSource, public isc::data::CfgToElement { public: /// @brief Destructor. virtual ~CfgHosts() { } /// @brief Return all hosts connected to any subnet for which reservations /// have been made using a specified identifier. /// /// This method returns all @c Host objects which represent reservations /// for a specified identifier. This method may return multiple hosts /// because a particular client may have reservations in multiple subnets. /// /// @param identifier_type One of the supported identifier types. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll(const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len) const; /// @brief Non-const version of the @c getAll const method. /// /// This method returns all @c Host objects which represent reservations /// for a specified identifier. This method may return multiple hosts /// because a particular client may have reservations in multiple subnets. /// /// @param identifier_type One of the supported identifier types. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// /// @return Collection of non-const @c Host objects. virtual HostCollection getAll(const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len); /// @brief Return all hosts in a DHCPv4 subnet. /// /// This method returns all @c Host objects which represent reservations /// in a specified subnet. /// /// @param subnet_id Subnet identifier. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll4(const SubnetID& subnet_id) const; /// @brief Return all hosts in a DHCPv4 subnet. /// /// This method returns all @c Host objects which represent reservations /// in a specified subnet. /// /// @param subnet_id Subnet identifier. /// /// @return Collection of non-const @c Host objects. virtual HostCollection getAll4(const SubnetID& subnet_id); /// @brief Return all hosts in a DHCPv6 subnet. /// /// This method returns all @c Host objects which represent reservations /// in a specified subnet. /// /// @param subnet_id Subnet identifier. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll6(const SubnetID& subnet_id) const; /// @brief Return all hosts in a DHCPv6 subnet. /// /// This method returns all @c Host objects which represent reservations /// in a specified subnet. /// /// @param subnet_id Subnet identifier. /// /// @return Collection of non-const @c Host objects. virtual HostCollection getAll6(const SubnetID& subnet_id); /// @brief Return all hosts with a hostname. /// /// This method returns all @c Host objects which represent reservations /// using a specified hostname. /// /// @param hostname The lower case hostname. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAllbyHostname(const std::string& hostname) const; /// @brief Return all hosts with a hostname. /// /// This method returns all @c Host objects which represent reservations /// using a specified hostname. /// /// @param hostname The lower case hostname. /// /// @return Collection of @c Host objects. virtual HostCollection getAllbyHostname(const std::string& hostname); /// @brief Return all hosts with a hostname in a DHCPv4 subnet. /// /// This method returns all @c Host objects which represent reservations /// using a specified hostname in a specified subnet. /// /// @param hostname The lower case hostname. /// @param subnet_id Subnet identifier. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAllbyHostname4(const std::string& hostname, const SubnetID& subnet_id) const; /// @brief Return all hosts with a hostname in a DHCPv4 subnet. /// /// This method returns all @c Host objects which represent reservations /// using a specified hostname in a specified subnet. /// /// @param hostname The lower case hostname. /// @param subnet_id Subnet identifier. /// /// @return Collection of @c Host objects. virtual HostCollection getAllbyHostname4(const std::string& hostname, const SubnetID& subnet_id); /// @brief Return all hosts with a hostname in a DHCPv6 subnet. /// /// This method returns all @c Host objects which represent reservations /// using a specified hostname in a specified subnet. /// /// @param hostname The lower case hostname. /// @param subnet_id Subnet identifier. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAllbyHostname6(const std::string& hostname, const SubnetID& subnet_id) const; /// @brief Return all hosts with a hostname in a DHCPv6 subnet. /// /// This method returns all @c Host objects which represent reservations /// using a specified hostname in a specified subnet. /// /// @param hostname The lower case hostname. /// @param subnet_id Subnet identifier. /// /// @return Collection of @c Host objects. virtual HostCollection getAllbyHostname6(const std::string& hostname, const SubnetID& subnet_id); /// @brief Returns range of hosts in a DHCPv4 subnet. /// /// This method returns a page of @c Host objects which represent /// reservations in a specified subnet. /// /// @param subnet_id Subnet identifier. /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of const @c Host objects (may be empty). virtual ConstHostCollection getPage4(const SubnetID& subnet_id, size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size) const; /// @brief Returns range of hosts in a DHCPv4 subnet. /// /// This method returns a page of @c Host objects which represent /// reservations in a specified subnet. /// /// @param subnet_id Subnet identifier. /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of non-const @c Host objects (may be empty). virtual HostCollection getPage4(const SubnetID& subnet_id, size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size); /// @brief Returns range of hosts in a DHCPv6 subnet. /// /// This method returns a page of @c Host objects which represent /// reservations in a specified subnet. /// /// @param subnet_id Subnet identifier. /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of const @c Host objects (may be empty). virtual ConstHostCollection getPage6(const SubnetID& subnet_id, size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size) const; /// @brief Returns range of hosts in a DHCPv6 subnet. /// /// This method returns a page of @c Host objects which represent /// reservations in a specified subnet. /// /// @param subnet_id Subnet identifier. /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of non-const @c Host objects (may be empty). virtual HostCollection getPage6(const SubnetID& subnet_id, size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size); /// @brief Returns range of hosts. /// /// This method returns a page of @c Host objects which represent /// reservations. /// /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of const @c Host objects (may be empty). virtual ConstHostCollection getPage4(size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size) const; /// @brief Returns range of hosts. /// /// This method returns a page of @c Host objects which represent /// reservations. /// /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of non-const @c Host objects (may be empty). virtual HostCollection getPage4(size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size); /// @brief Returns range of hosts. /// /// This method returns a page of @c Host objects which represent /// reservations. /// /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of const @c Host objects (may be empty). virtual ConstHostCollection getPage6(size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size) const; /// @brief Returns range of hosts. /// /// This method returns a page of @c Host objects which represent /// reservations. /// /// @param source_index Index of the source (unused). /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// /// @return Collection of non-const @c Host objects (may be empty). virtual HostCollection getPage6(size_t& source_index, uint64_t lower_host_id, const HostPageSize& page_size); /// @brief Returns a collection of hosts using the specified IPv4 address. /// /// This method may return multiple @c Host objects if they are connected /// to different subnets. /// /// @param address IPv4 address for which the @c Host object is searched. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll4(const asiolink::IOAddress& address) const; /// @brief Returns a collection of hosts using the specified IPv4 address. /// /// This method may return multiple @c Host objects if they are connected /// to different subnets. /// /// @param address IPv4 address for which the @c Host object is searched. /// /// @return Collection of const @c Host objects. virtual HostCollection getAll4(const asiolink::IOAddress& address); /// @brief Returns a collection of hosts using the specified IPv6 address. /// /// This method may return multiple @c Host objects if they are connected /// to different subnets. /// /// @param address IPv6 address for which the @c Host object is searched. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll6(const asiolink::IOAddress& address) const; /// @brief Returns a collection of hosts using the specified IPv6 address. /// /// This method may return multiple @c Host objects if they are connected /// to different subnets. /// /// @param address IPv6 address for which the @c Host object is searched. /// /// @return Collection of const @c Host objects. virtual HostCollection getAll6(const asiolink::IOAddress& address); /// @brief Returns a host connected to the IPv4 subnet. /// /// @param subnet_id Subnet identifier. /// @param identifier_type Identifier type. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// /// @return Const @c Host object for which reservation has been made using /// the specified identifier. virtual ConstHostPtr get4(const SubnetID& subnet_id, const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len) const; /// @brief Returns a host connected to the IPv4 subnet. /// /// @param subnet_id Subnet identifier. /// @param identifier_type Identifier type. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// /// @return Non-const @c Host object for which reservation has been made /// using the specified identifier. virtual HostPtr get4(const SubnetID& subnet_id, const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len); /// @brief Returns a host connected to the IPv4 subnet and having /// a reservation for a specified IPv4 address. /// /// @param subnet_id Subnet identifier. /// @param address reserved IPv4 address. /// /// @return Const @c Host object using a specified IPv4 address. virtual ConstHostPtr get4(const SubnetID& subnet_id, const asiolink::IOAddress& address) const; /// @brief Returns all hosts connected to the IPv4 subnet and having /// a reservation for a specified address. /// /// In most cases it is desired that there is at most one reservation /// for a given IPv4 address within a subnet. In a default configuration, /// the backend does not allow for inserting more than one host with /// the same IPv4 reservation. In that case, the number of hosts returned /// by this function is 0 or 1. /// /// If the backend is configured to allow multiple hosts with reservations /// for the same IPv4 address in the given subnet, this method can return /// more than one host. /// /// The typical use case when a single IPv4 address is reserved for multiple /// hosts is when these hosts represent different interfaces of the same /// machine and each interface comes with a different MAC address. In that /// case, the same IPv4 address is assigned regardless of which interface is /// used by the DHCP client to communicate with the server. /// /// @param subnet_id Subnet identifier. /// @param address reserved IPv4 address. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll4(const SubnetID& subnet_id, const asiolink::IOAddress& address) const; /// @brief Returns a host connected to the IPv6 subnet. /// /// @param subnet_id Subnet identifier. /// @param identifier_type Identifier type. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// /// @return Const @c Host object for which reservation has been made using /// the specified identifier. virtual ConstHostPtr get6(const SubnetID& subnet_id, const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len) const; /// @brief Returns a host connected to the IPv6 subnet. /// /// @param subnet_id Subnet identifier. /// @param identifier_type Identifier type. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// /// @return Non-const @c Host object for which reservation has been made /// using the specified identifier. virtual HostPtr get6(const SubnetID& subnet_id, const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len); /// @brief Returns a host using the specified IPv6 prefix. /// /// @param prefix IPv6 prefix for which the @c Host object is searched. /// @param prefix_len IPv6 prefix length. /// /// @return Const @c Host object for which specified prefix is reserved. virtual ConstHostPtr get6(const asiolink::IOAddress& prefix, const uint8_t prefix_len) const; /// @brief Returns a host using the specified IPv6 prefix. /// /// @param prefix IPv6 prefix for which the @c Host object is searched. /// @param prefix_len IPv6 prefix length. /// /// @return Non-const @c Host object for which specified prefix is /// reserved. virtual HostPtr get6(const asiolink::IOAddress& prefix, const uint8_t prefix_len); /// @brief Returns a host connected to the IPv6 subnet and having /// a reservation for a specified IPv6 address. /// /// @param subnet_id Subnet identifier. /// @param address reserved IPv6 address. /// /// @return Const @c Host object using a specified IPv6 address. virtual ConstHostPtr get6(const SubnetID& subnet_id, const asiolink::IOAddress& address) const; /// @brief Returns a host connected to the IPv6 subnet and having /// a reservation for a specified IPv6 address. /// /// @param subnet_id Subnet identifier. /// @param address reserved IPv6 address. /// /// @return Const @c Host object using a specified IPv6 address. virtual HostPtr get6(const SubnetID& subnet_id, const asiolink::IOAddress& address); /// @brief Returns all hosts connected to the IPv6 subnet and having /// a reservation for a specified address or delegated prefix (lease). /// /// In most cases it is desired that there is at most one reservation /// for a given IPv6 lease within a subnet. In a default configuration, /// the backend does not allow for inserting more than one host with /// the same IPv6 address or prefix. In that case, the number of hosts /// returned by this function is 0 or 1. /// /// If the backend is configured to allow multiple hosts with reservations /// for the same IPv6 lease in the given subnet, this method can return /// more than one host. /// /// The typical use case when a single IPv6 lease is reserved for multiple /// hosts is when these hosts represent different interfaces of the same /// machine and each interface comes with a different MAC address. In that /// case, the same IPv6 lease is assigned regardless of which interface is /// used by the DHCP client to communicate with the server. /// /// @param subnet_id Subnet identifier. /// @param address reserved IPv6 address/prefix. /// /// @return Collection of const @c Host objects. virtual ConstHostCollection getAll6(const SubnetID& subnet_id, const asiolink::IOAddress& address) const; /// @brief Adds a new host to the collection. /// /// @param host Pointer to the new @c Host object being added. /// /// @throw DuplicateHost If a host for a particular HW address or DUID /// has already been added to the IPv4 or IPv6 subnet. virtual void add(const HostPtr& host); /// @brief Attempts to delete a hosts by address. /// /// This method supports both v4 and v6. /// @todo: Not implemented. /// /// @param subnet_id subnet identifier. /// @param addr specified address. virtual bool del(const SubnetID& subnet_id, const asiolink::IOAddress& addr); /// @brief Attempts to delete all hosts for a given IPv4 subnet. /// /// @param subnet_id Identifier of the subnet for which reservation should /// be deleted. /// @return Number of deleted hosts. virtual size_t delAll4(const SubnetID& subnet_id); /// @brief Attempts to delete a host by (subnet4-id, identifier, identifier-type) /// /// This method supports v4 only. /// @todo: Not implemented. /// /// @param subnet_id IPv4 Subnet identifier. /// @param identifier_type Identifier type. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// @return true if deletion was successful, false otherwise. virtual bool del4(const SubnetID& subnet_id, const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len); /// @brief Attempts to delete all hosts for a given IPv6 subnet. /// /// @param subnet_id Identifier of the subnet for which reservation should /// be deleted. /// @return Number of deleted hosts. virtual size_t delAll6(const SubnetID& subnet_id); /// @brief Attempts to delete a host by (subnet6-id, identifier, identifier-type) /// /// This method supports v6 only. /// @todo: Not implemented. /// /// @param subnet_id IPv6 Subnet identifier. /// @param identifier_type Identifier type. /// @param identifier_begin Pointer to a beginning of a buffer containing /// an identifier. /// @param identifier_len Identifier length. /// @return true if deletion was successful, false otherwise. virtual bool del6(const SubnetID& subnet_id, const Host::IdentifierType& identifier_type, const uint8_t* identifier_begin, const size_t identifier_len); /// @brief Return backend type /// /// Returns the type of the backend (e.g. "mysql", "memfile" etc.) /// /// @return Type of the backend. virtual std::string getType() const { return (std::string("configuration file")); } /// @brief Controls whether IP reservations are unique or non-unique. /// /// In a typical case, the IP reservations are unique and backends verify /// prior to adding a host reservation to the database that the reservation /// for a given IP address/subnet does not exist. In some cases it may be /// required to allow non-unique IP reservations, e.g. in the case when a /// host has several interfaces and independently of which interface is used /// by this host to communicate with the DHCP server the same IP address /// should be assigned. In this case the @c unique value should be set to /// false to disable the checks for uniqueness on the backend side. /// /// @param unique boolean flag indicating if the IP reservations must be /// unique or can be non-unique. /// @return always true because this data source supports both the case when /// the addresses must be unique and when they may be non-unique. virtual bool setIPReservationsUnique(const bool unique); /// @brief Unparse a configuration object /// /// host reservation lists are not autonomous so they are /// not returned directly but with the subnet where they are /// declared as: /// @code /// [ /// { "id": 123, "reservations": [ , ] }, /// { "id": 456, "reservations": [ void getAllInternal(const Host::IdentifierType& identifier_type, const uint8_t* identifier, const size_t identifier_len, Storage& storage) const; /// @brief Returns @c Host objects in a DHCPv4 subnet. /// /// This private method is called by the @c CfgHosts::getAll4 /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param subnet_id Subnet identifier. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getAllInternal4(const SubnetID& subnet_id, Storage& storage) const; /// @brief Returns @c Host objects in a DHCPv6 subnet. /// /// This private method is called by the @c CfgHosts::getAll6 /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param subnet_id Subnet identifier. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getAllInternal6(const SubnetID& subnet_id, Storage& storage) const; /// @brief Return all hosts with a hostname. /// /// This private method is called by the @c CfgHosts::getAllbyHostname /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param hostname The lower case hostname. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getAllbyHostnameInternal(const std::string& hostname, Storage& storage) const; /// @brief Return all hosts with a hostname and a DHCPv4 subnet. /// /// This private method is called by the @c CfgHosts::getAllbyHostname4 /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param hostname The lower case hostname. /// @param subnet_id Subnet identifier. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getAllbyHostnameInternal4(const std::string& hostname, const SubnetID& subnet_id, Storage& storage) const; /// @brief Return all hosts with a hostname and a DHCPv6 subnet. /// /// This private method is called by the @c CfgHosts::getAllbyHostname6 /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param hostname The lower case hostname. /// @param subnet_id Subnet identifier. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getAllbyHostnameInternal6(const std::string& hostname, const SubnetID& subnet_id, Storage& storage) const; /// @brief Returns a page of @c Host objects in a DHCPv4 subnet. /// /// This private method is called by the @c CfgHosts::getPage4 /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param subnet_id Subnet identifier. /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getPageInternal4(const SubnetID& subnet_id, uint64_t lower_host_id, const HostPageSize& page_size, Storage& storage) const; /// @brief Returns a page of @c Host objects in a DHCPv6 subnet. /// /// This private method is called by the @c CfgHosts::getPage6 /// method which finds the @c Host objects in a specified subnet. /// The retrieved objects are appended to the @c storage container. /// /// @param subnet_id Subnet identifier. /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getPageInternal6(const SubnetID& subnet_id, uint64_t lower_host_id, const HostPageSize& page_size, Storage& storage) const; /// @brief Returns a page of @c Host objects. /// /// This private method is called by the @c CfgHosts::getPage4 /// and @c CfgHosts::getPage6 methods which find the @c Host objects. /// The retrieved objects are appended to the @c storage container. /// /// @param lower_host_id Host identifier used as lower bound for the /// returned range. /// @param page_size maximum size of the page returned. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection of @c HostCollection. template void getPageInternal(uint64_t lower_host_id, const HostPageSize& page_size, Storage& storage) const; /// @brief Returns @c Host objects for the specified IPv4 address. /// /// This private method is called by the @c CfgHosts::getAll4 methods /// to retrieve the @c Host for which the specified IPv4 address is /// reserved. The retrieved objects are appended to the @c storage /// container. /// /// @param address IPv4 address. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection or @c HostCollection. template void getAllInternal4(const asiolink::IOAddress& address, Storage& storage) const; /// @brief Returns @c Host objects for the specified IPv6 address. /// /// This private method is called by the @c CfgHosts::getAll6 methods /// to retrieve the @c Host for which the specified IPv6 address is /// reserved. The retrieved objects are appended to the @c storage /// container. /// /// @param address IPv6 address. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection or @c HostCollection. template void getAllInternal6(const asiolink::IOAddress& address, Storage& storage) const; /// @brief Returns @c Host objects for the specified (Subnet-id,IPv6 address) tuple. /// /// This private method is called by the @c CfgHosts::getAll6 methods /// to retrieve the @c Host for which the specified IPv6 address is /// reserved and is in specified subnet-id. The retrieved objects are /// appended to the @c storage container. /// /// @param subnet_id Subnet Identifier. /// @param address IPv6 address. /// @param [out] storage Container to which the retrieved objects are /// appended. /// @tparam One of the @c ConstHostCollection or @c HostCollection. template void getAllInternal6(const SubnetID& subnet_id, const asiolink::IOAddress& address, Storage& storage) const; /// @brief Returns @c Host object connected to a subnet. /// /// This private method returns a pointer to the @c Host object using /// a specified identifier and connected to an IPv4 or IPv6 subnet. /// /// @param subnet_id IPv4 or IPv6 subnet identifier. /// @param subnet6 A boolean flag which indicates if the subnet identifier /// points to a IPv4 (if false) or IPv6 subnet (if true). /// @param identifier_type Identifier type. /// @param identifier Pointer to a first byte of the buffer holding an /// identifier. /// @param identifier_len Identifier length. /// /// @return Pointer to the found host, or NULL if no host found. /// @throw isc::dhcp::DuplicateHost if method found more than one matching /// @c Host object. HostPtr getHostInternal(const SubnetID& subnet_id, const bool subnet6, const Host::IdentifierType& identifier_type, const uint8_t* identifier, const size_t identifier_len) const; /// @brief Returns the @c Host object holding reservation for the IPv6 /// address and connected to the specific subnet. /// /// This private method is called by the public @c get6 method variants. /// /// @param subnet_id IPv6 subnet identifier. /// @param address IPv6 address. /// @tparam ReturnType One of @c HostPtr or @c ConstHostPtr /// @tparam One of the @c ConstHostCollection or @c HostCollection. /// /// @return Pointer to the found host, or NULL if no host found. /// @throw isc::dhcp::DuplicateHost if method found more than one matching /// @c Host object. template ReturnType getHostInternal6(const SubnetID& subnet_id, const asiolink::IOAddress& address) const; template ReturnType getHostInternal6(const asiolink::IOAddress& prefix, const uint8_t prefix_len) const; /// @brief Adds a new host to the collection. /// /// This is an internal method called by public @ref add. Contrary to its /// name, this is useful for both IPv4 and IPv6 hosts, as this adds the /// host to hosts_ storage that is shared by both families. Notes that /// for IPv6 host additional steps may be required (see @ref add6). /// /// @param host Pointer to the new @c Host object being added. /// /// @throw DuplicateHost If a host for a particular HW address or DUID /// has already been added to the IPv4 subnet. virtual void add4(const HostPtr& host); /// @brief Adds IPv6-specific reservation to hosts collection. /// /// This is an internal method called by public @ref add. This method adds /// IPv6 reservations (IPv6 addresses or prefixes reserved) to the hosts6_ /// storage. Note the host has been added to the hosts_ already (in @ref add4). /// /// @param host Pointer to the new @c Host object being added. /// /// @throw DuplicateHost If a host for a particular HW address or DUID /// or for the particular address or prefix has already been added to /// the IPv6 subnet. virtual void add6(const HostPtr& host); /// @brief Next host id. uint64_t next_host_id_ = 0; /// @brief Multi-index container holding @c Host objects. /// /// It can be used for finding hosts by the following criteria: /// - IPv4 address /// - DUID /// - HW/MAC address /// - subnet ID /// - host ID HostContainer hosts_; /// @brief Multi-index container holding @c Host objects with v6 reservations. /// /// It can be used for finding hosts by the following criteria: /// - IPv6 address /// - IPv6 prefix HostContainer6 hosts6_; /// @brief Holds the setting whether the IP reservations must be unique or /// may be non-unique. bool ip_reservations_unique_ = true; /// @brief Unparse a configuration object (DHCPv4 reservations) /// /// @return a pointer to unparsed configuration isc::data::ElementPtr toElement4() const; /// @brief Unparse a configuration object (DHCPv6 reservations) /// /// @return a pointer to unparsed configuration isc::data::ElementPtr toElement6() const; }; /// @name Pointers to the @c CfgHosts objects. //@{ /// @brief Non-const pointer. typedef boost::shared_ptr CfgHostsPtr; /// @brief Const pointer. typedef boost::shared_ptr ConstCfgHostsPtr; //@} } } #endif // CFG_HOSTS_H