blob: f2bf02a3204fd8dae4bed66b6b48d3074e95a525 [file] [log] [blame]
#pragma once
#include <sdbusplus/bus.hpp>
#include <sdbusplus/server/object.hpp>
#include <xyz/openbmc_project/User/Ldap/Config/server.hpp>
#include <xyz/openbmc_project/User/Ldap/Create/server.hpp>
#include <string>
namespace phosphor
{
namespace ldap
{
static constexpr auto defaultNslcdFile = "/etc/nslcd.conf.default";
static constexpr auto nsSwitchFile = "/etc/nsswitch.conf";
static constexpr auto LDAPNsSwitchFile = "/etc/nsswitch_ldap.conf";
static constexpr auto linuxNsSwitchFile = "/etc/nsswitch_linux.conf";
namespace ldap_base = sdbusplus::xyz::openbmc_project::User::Ldap::server;
using ConfigIface = sdbusplus::server::object::object<ldap_base::Config>;
using CreateIface = sdbusplus::server::object::object<ldap_base::Create>;
class ConfigMgr;
/** @class Config
* @brief Configuration for LDAP.
* @details concrete implementation of xyz.openbmc_project.User.Ldap.Config
* API, in order to provide LDAP configuration.
*/
class Config : public ConfigIface
{
public:
Config() = delete;
~Config() = default;
Config(const Config&) = delete;
Config& operator=(const Config&) = delete;
Config(Config&&) = default;
Config& operator=(Config&&) = default;
/** @brief Constructor to put object onto bus at a D-Bus path.
* @param[in] bus - Bus to attach to.
* @param[in] path - The D-Bus object path to attach at.
* @param[in] filePath - LDAP configuration file.
* @param[in] secureLDAP - Specifies whether to use SSL or not.
* @param[in] lDAPServerURI - LDAP URI of the server.
* @param[in] lDAPBindDN - distinguished name with which to bind.
* @param[in] lDAPBaseDN - distinguished name to use as search base.
* @param[in] lDAPBindDNpassword - credentials with which to bind.
* @param[in] lDAPSearchScope - the search scope.
* @param[in] lDAPType - Specifies the LDAP server type which can be AD
or openLDAP.
* @param[in] parent - parent of config object.
*/
Config(sdbusplus::bus::bus& bus, const char* path, const char* filePath,
bool secureLDAP, std::string lDAPServerURI, std::string lDAPBindDN,
std::string lDAPBaseDN, std::string lDAPBindDNpassword,
ldap_base::Config::SearchScope lDAPSearchScope,
ldap_base::Config::Type lDAPType, ConfigMgr& parent);
using ConfigIface::lDAPBaseDN;
using ConfigIface::lDAPBindDN;
using ConfigIface::lDAPBINDDNpassword;
using ConfigIface::lDAPSearchScope;
using ConfigIface::lDAPServerURI;
using ConfigIface::lDAPType;
using ConfigIface::secureLDAP;
using ConfigIface::setPropertyByName;
/** @brief Update the secure LDAP property.
* @param[in] value - secureLDAP value to be updated.
* @returns value of changed secureLDAP.
*/
bool secureLDAP(bool value) override;
/** @brief Update the Server URI property.
* @param[in] value - lDAPServerURI value to be updated.
* @returns value of changed lDAPServerURI.
*/
std::string lDAPServerURI(std::string value) override;
/** @brief Update the BindDN property.
* @param[in] value - lDAPBindDN value to be updated.
* @returns value of changed lDAPBindDN.
*/
std::string lDAPBindDN(std::string value) override;
/** @brief Update the BaseDN property.
* @param[in] value - lDAPBaseDN value to be updated.
* @returns value of changed lDAPBaseDN.
*/
std::string lDAPBaseDN(std::string value) override;
/** @brief Update the BindDN password property.
* @param[in] value - lDAPBINDDNpassword value to be updated.
* @returns value of changed lDAPBINDDNpassword.
*/
std::string lDAPBINDDNpassword(std::string value) override;
/** @brief Update the Search scope property.
* @param[in] value - lDAPSearchScope value to be updated.
* @returns value of changed lDAPSearchScope.
*/
ldap_base::Config::SearchScope
lDAPSearchScope(ldap_base::Config::SearchScope value) override;
/** @brief Update the LDAP Type property.
* @param[in] value - lDAPType value to be updated.
* @returns value of changed lDAPType.
*/
ldap_base::Config::Type lDAPType(ldap_base::Config::Type value) override;
private:
std::string configFilePath{};
/** @brief Persistent sdbusplus D-Bus bus connection. */
sdbusplus::bus::bus& bus;
/** @brief Create a new LDAP config file.
*/
virtual void writeConfig();
/** @brief reference to config manager object */
ConfigMgr& parent;
};
/** @class ConfigMgr
* @brief Creates LDAP server configuration.
* @details concrete implementation of xyz.openbmc_project.User.Ldap.Create
* APIs, in order to create LDAP configuration.
*/
class ConfigMgr : public CreateIface
{
public:
ConfigMgr() = delete;
~ConfigMgr() = default;
ConfigMgr(const ConfigMgr&) = delete;
ConfigMgr& operator=(const ConfigMgr&) = delete;
ConfigMgr(ConfigMgr&&) = delete;
ConfigMgr& operator=(ConfigMgr&&) = delete;
/** @brief ConfigMgr to put object onto bus at a dbus path.
* @param[in] bus - Bus to attach to.
* @param[in] path - Path to attach at.
* @param[in] filePath - LDAP configuration file.
*/
ConfigMgr(sdbusplus::bus::bus& bus, const char* path) :
CreateIface(bus, path), bus(bus)
{
// TODO restore config object if config file exists.
}
/** @brief concrete implementation of the pure virtual funtion
xyz.openbmc_project.User.Ldap.Create.createConfig.
* @param[in] secureLDAP - Specifies whether to use SSL or not.
* @param[in] lDAPServerURI - LDAP URI of the server.
* @param[in] lDAPBindDN - distinguished name with which bind to bind
to the directory server for lookups.
* @param[in] lDAPBaseDN - distinguished name to use as search base.
* @param[in] lDAPBindDNpassword - credentials with which to bind.
* @param[in] lDAPSearchScope - the search scope.
* @param[in] lDAPType - Specifies the LDAP server type which can be AD
or openLDAP.
* @returns the object path of the D-Bus object created.
*/
std::string createConfig(bool secureLDAP, std::string lDAPServerURI,
std::string lDAPBindDN, std::string lDAPBaseDN,
std::string lDAPBindDNpassword,
ldap_base::Create::SearchScope lDAPSearchScope,
ldap_base::Create::Type lDAPType) override;
/** @brief restarts given service
* @param[in] service - Service to be restarted.
*/
virtual void restartService(const std::string& service);
private:
/** @brief Persistent sdbusplus D-Bus bus connection. */
sdbusplus::bus::bus& bus;
/** @brief Pointer to a Config D-Bus object */
std::unique_ptr<Config> configPtr = nullptr;
};
} // namespace ldap
} // namespace phosphor