summaryrefslogtreecommitdiffstats
path: root/phosphor-ldap-config/ldap_configuration.hpp
diff options
context:
space:
mode:
authorNagaraju Goruganti <ngorugan@in.ibm.com>2018-08-30 03:05:11 -0500
committerBrad Bishop <bradleyb@fuzziesquirrel.com>2018-10-04 15:14:12 -0400
commit997f5e0087568a17dc1434fdaccb553dbcaa7b0e (patch)
tree22ad00a4ae8d5bd7288ba7e578f54ef15a9c85c4 /phosphor-ldap-config/ldap_configuration.hpp
parent0b14c471fc77cbcb93f435a46878b25f57741e0e (diff)
downloadphosphor-user-manager-997f5e0087568a17dc1434fdaccb553dbcaa7b0e.tar.gz
phosphor-user-manager-997f5e0087568a17dc1434fdaccb553dbcaa7b0e.zip
phosphor-ldap-conf: add application to configure LDAP
The application implements the xyz.openbmc_project.User.Ldap.Config and xyz.openbmc_project.User.Ldap.Create D-Bus interfaces to create LDAP config file(for example generate nslcd.conf) Change-Id: Idc7cc643c4143f9bc51182019926e1dd6125da2f Signed-off-by: Nagaraju Goruganti <ngorugan@in.ibm.com>
Diffstat (limited to 'phosphor-ldap-config/ldap_configuration.hpp')
-rw-r--r--phosphor-ldap-config/ldap_configuration.hpp184
1 files changed, 184 insertions, 0 deletions
diff --git a/phosphor-ldap-config/ldap_configuration.hpp b/phosphor-ldap-config/ldap_configuration.hpp
new file mode 100644
index 0000000..f2bf02a
--- /dev/null
+++ b/phosphor-ldap-config/ldap_configuration.hpp
@@ -0,0 +1,184 @@
+#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
OpenPOWER on IntegriCloud