diff options
Diffstat (limited to 'src/lib/dhcpsrv/mysql_host_data_source.h')
-rw-r--r-- | src/lib/dhcpsrv/mysql_host_data_source.h | 537 |
1 files changed, 0 insertions, 537 deletions
diff --git a/src/lib/dhcpsrv/mysql_host_data_source.h b/src/lib/dhcpsrv/mysql_host_data_source.h deleted file mode 100644 index 10643d1183..0000000000 --- a/src/lib/dhcpsrv/mysql_host_data_source.h +++ /dev/null @@ -1,537 +0,0 @@ -// Copyright (C) 2015-2023 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 MYSQL_HOST_DATA_SOURCE_H -#define MYSQL_HOST_DATA_SOURCE_H - -#include <database/database_connection.h> -#include <database/db_exceptions.h> -#include <dhcpsrv/base_host_data_source.h> -#include <mysql/mysql_connection.h> - -#include <stdint.h> - -#include <utility> -#include <string> - -namespace isc { -namespace dhcp { - -/// Forward declaration to the implementation of the @ref MySqlHostDataSource. -class MySqlHostDataSourceImpl; - -/// @brief Type of pointers to MySqlHostDataSourceImpl. -typedef boost::shared_ptr<MySqlHostDataSourceImpl> MySqlHostDataSourceImplPtr; - -/// Forward declaration for the thread context for the manager pool. -class MySqlHostContext; - -/// @brief Type of pointers to contexts. -typedef boost::shared_ptr<MySqlHostContext> MySqlHostContextPtr; - -/// @brief MySQL Host Data Source -/// -/// This class implements the @ref isc::dhcp::BaseHostDataSource interface to -/// the MySQL database. Use of this backend presupposes that a MySQL database -/// is available and that the Kea schema has been created within it. -class MySqlHostDataSource : public BaseHostDataSource { -public: - - /// @brief Constructor - /// - /// Uses the following keywords in the parameters passed to it to - /// connect to the database: - /// - name - Name of the database to which to connect (mandatory) - /// - host - Host to which to connect (optional, defaults to "localhost") - /// - user - Username under which to connect (optional) - /// - password - Password for "user" on the database (optional) - /// - /// If the database is successfully opened, the version number in the - /// schema_version table will be checked against hard-coded value in - /// the implementation file. - /// - /// Finally, all the SQL commands are pre-compiled. - /// - /// @param parameters A data structure relating keywords and values - /// concerned with the database. - /// - /// @throw isc::dhcp::NoDatabaseName Mandatory database name not given - /// @throw isc::db::DbOpenError Error opening the database or the - /// schema version is invalid. - /// @throw isc::db::DbOperationError An operation on the open database has - /// failed. - MySqlHostDataSource(const db::DatabaseConnection::ParameterMap& parameters); - - /// @brief Virtual destructor. - /// - /// Releases prepared MySQL statements used by the backend. - virtual ~MySqlHostDataSource(); - - /// @brief Return backend parameters - /// - /// Returns the backend parameters - /// - /// @return Parameters of the backend. - virtual isc::db::DatabaseConnection::ParameterMap getParameters() const; - - /// @brief Adds a new host to the collection. - /// - /// The implementations of this method should guard against duplicate - /// reservations for the same host, where possible. For example, when the - /// reservation for the same HW address and subnet id is added twice, the - /// addHost method should throw an DuplicateEntry exception. Note, that - /// usually it is impossible to guard against adding duplicated host, where - /// one instance is identified by HW address, another one by DUID. - /// - /// @param host Pointer to the new @c Host object being added. - virtual void add(const HostPtr& host); - - /// @brief Attempts to delete hosts by (subnet-id, address) - /// - /// This method supports both v4 and v6. - /// - /// @param subnet_id subnet identifier. - /// @param addr specified address. - /// @return true if deletion was successful, false if the host was not there. - /// @throw various exceptions in case of errors - virtual bool del(const SubnetID& subnet_id, - const asiolink::IOAddress& addr); - - /// @brief Attempts to delete a host by (subnet4-id, identifier type, identifier) - /// - /// This method supports v4 hosts only. - /// - /// @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 true if deletion was successful, false if the host was not there. - /// @throw various exceptions in case of errors - 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 a host by (subnet6-id, identifier type, identifier) - /// - /// This method supports v6 hosts only. - /// - /// @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 true if deletion was successful, false if the host was not there. - /// @throw various exceptions in case of errors - virtual bool del6(const SubnetID& subnet_id, - const Host::IdentifierType& identifier_type, - const uint8_t* identifier_begin, - const size_t identifier_len); - - /// @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 Identifier type. - /// @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 Return all hosts in a DHCPv4 subnet. - /// - /// This method returns all @ref Host objects which represent reservations - /// in a specified subnet. - /// - /// @param subnet_id subnet identifier to filter by - /// - /// @return Collection of const @ref Host objects. - virtual ConstHostCollection getAll4(const SubnetID& subnet_id) const; - - /// @brief Return all hosts in a DHCPv6 subnet. - /// - /// This method returns all @ref Host objects which represent reservations - /// in a specified subnet. - /// - /// @param subnet_id subnet identifier to filter by - /// - /// @return Collection of const @ref Host objects. - virtual ConstHostCollection getAll6(const SubnetID& subnet_id) const; - - /// @brief Return all hosts with a hostname. - /// - /// This method returns all @c Host objects which represent reservations - /// using a specified hostname. - /// - /// MySQL uses the case-insensitive hosts_by_hostname index on 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 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 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 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 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. - /// - /// 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 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 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 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 and having - /// a reservation for a specified IPv4 address. - /// - /// One of the use cases for this method is to detect collisions between - /// dynamically allocated addresses and reserved addresses. When the new - /// address is assigned to a client, the allocation mechanism should check - /// if this address is not reserved for some other host and do not allocate - /// this address if reservation is present. - /// - /// Implementations of this method should guard against invalid addresses, - /// such as IPv6 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 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 using a specified IPv6 prefix. - virtual ConstHostPtr get6(const asiolink::IOAddress& prefix, - const uint8_t prefix_len) const; - - /// @brief Returns a host connected to the IPv6 subnet and having - /// a reservation for a specified IPv6 address or prefix. - /// - /// @param subnet_id Subnet identifier. - /// @param address reserved IPv6 address/prefix. - /// - /// @return Const @c Host object using a specified IPv6 address/prefix. - virtual ConstHostPtr get6(const SubnetID& subnet_id, - const asiolink::IOAddress& address) const; - - /// @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 Returns all hosts having a reservation for a specified - /// address or delegated prefix (lease) in all subnets. - /// - /// 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. - /// - /// 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 per subnet. - /// - /// 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 address reserved IPv6 address/prefix. - /// - /// @return Collection of const @c Host objects. - virtual ConstHostCollection getAll6(const asiolink::IOAddress& address) const; - - /// @brief Implements @ref BaseHostDataSource::update() for MySQL. - /// - /// Attempts to update an existing host entry. - /// - /// @param host the host up to date with the requested changes - void update(HostPtr const& host); - - /// @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("mysql")); - } - - /// @brief Returns backend name. - /// - /// Each backend have specific name. - /// - /// @return "mysql". - virtual std::string getName() const; - - /// @brief Returns description of the backend. - /// - /// This description may be multiline text that describes the backend. - /// - /// @return Description of the backend. - virtual std::string getDescription() const; - - /// @brief Returns backend version. - /// - /// @param timer_name The DB reconnect timer name. - /// @return Version number stored in the database, as a pair of unsigned - /// integers. "first" is the major version number, "second" the - /// minor number. - /// - /// @throw isc::db::DbOperationError An operation on the open database - /// has failed. - virtual std::pair<uint32_t, uint32_t> getVersion(const std::string& timer_name = std::string()) const; - - /// @brief Commit Transactions - /// - /// Commits all pending database operations. - virtual void commit(); - - /// @brief Rollback Transactions - /// - /// Rolls back all pending database operations. - virtual void rollback(); - - /// @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 within the subnet or can be non-unique. - /// @return always true because this backend supports both the case when - /// the addresses must be unique and when they may be non-unique. - virtual bool setIPReservationsUnique(const bool unique); - - /// @brief Flag which indicates if the host manager has at least one - /// unusable connection. - /// - /// @return true if there is at least one unusable connection, false - /// otherwise - virtual bool isUnusable(); - - /// @brief Context RAII Allocator. - class MySqlHostContextAlloc { - public: - - /// @brief Constructor - /// - /// This constructor takes a context of the pool if one is available - /// or creates a new one. - /// - /// @param mgr A parent instance - MySqlHostContextAlloc(MySqlHostDataSourceImpl& mgr); - - /// @brief Destructor - /// - /// This destructor puts back the context in the pool. - ~MySqlHostContextAlloc(); - - /// @brief The context - MySqlHostContextPtr ctx_; - - private: - /// @brief The manager - MySqlHostDataSourceImpl& mgr_; - }; - -private: - /// @brief Pointer to the implementation of the @ref MySqlHostDataSource. - MySqlHostDataSourceImplPtr impl_; -}; - -} -} - -#endif // MYSQL_HOST_DATA_SOURCE_H |