summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2013-04-12 10:20:56 -0500
committerTimothy Pearson <[email protected]>2013-04-12 10:20:56 -0500
commit27b49086f03315c32d30a0658e44958abd47a3ef (patch)
treeb2334b80a04c4982c135a1ad228172ea2c8b3c66
parent3caa3ef1be6a44a10df19ab95d01f69528667368 (diff)
downloadkcmldap-27b49086f03315c32d30a0658e44958abd47a3ef.tar.gz
kcmldap-27b49086f03315c32d30a0658e44958abd47a3ef.zip
Add ability to control PAM options including credential caching and home directory creation
-rw-r--r--src/Makefile.am2
-rw-r--r--src/ldapbonding.cpp29
-rw-r--r--src/ldapconfigbase.ui84
-rw-r--r--src/tdeumaskinput.cpp61
-rw-r--r--src/tdeumaskinput.h83
5 files changed, 257 insertions, 2 deletions
diff --git a/src/Makefile.am b/src/Makefile.am
index 980e2b9..dc29cb1 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -4,7 +4,7 @@ METASOURCES = AUTO
# Install this plugin in the KDE modules directory
kde_module_LTLIBRARIES = kcm_ldapbonding.la
-kcm_ldapbonding_la_SOURCES = ldapbonding.cpp ldapconfigbase.ui realmpropertiesdialog.cpp bondintropage.cpp bondintropagedlg.ui bondrealmpage.cpp bondrealmpagedlg.ui bondfinishpage.cpp bondfinishpagedlg.ui bondwizard.cpp ldappasswddlg.cpp
+kcm_ldapbonding_la_SOURCES = tdeumaskinput.cpp ldapbonding.cpp ldapconfigbase.ui realmpropertiesdialog.cpp bondintropage.cpp bondintropagedlg.ui bondrealmpage.cpp bondrealmpagedlg.ui bondfinishpage.cpp bondfinishpagedlg.ui bondwizard.cpp ldappasswddlg.cpp
kcm_ldapbonding_la_LIBADD = $(LIB_KIO) $(LIB_TDEUI) -ltdeldap
kcm_ldapbonding_la_LDFLAGS = -avoid-version -module -no-undefined \
$(all_libraries)
diff --git a/src/ldapbonding.cpp b/src/ldapbonding.cpp
index fbf1006..9bc23db 100644
--- a/src/ldapbonding.cpp
+++ b/src/ldapbonding.cpp
@@ -44,6 +44,7 @@
#include <tdesu/process.h>
+#include "tdeumaskinput.h"
#include "ldapbonding.h"
#include "bondwizard.h"
#include "ldappasswddlg.h"
@@ -101,6 +102,12 @@ LDAPConfig::LDAPConfig(TQWidget *parent, const char *name, const TQStringList&)
connect(base->passwordHash, TQT_SIGNAL(activated(int)), this, TQT_SLOT(changed()));
connect(base->ignoredUsers, TQT_SIGNAL(textChanged(const TQString&)), this, TQT_SLOT(changed()));
+ connect(base->pamEnableCachedLogons, TQT_SIGNAL(clicked()), this, TQT_SLOT(changed()));
+ connect(base->pamCreateHomeDirectory, TQT_SIGNAL(clicked()), this, TQT_SLOT(changed()));
+ connect(base->pamCreateHomeDirectory, TQT_SIGNAL(clicked()), this, TQT_SLOT(processLockouts()));
+ connect(base->pamCreateHomeDirectoryUmask, TQT_SIGNAL(valueChanged(int)), this, TQT_SLOT(changed()));
+ connect(base->pamCreateHomeDirectorySkelDir, TQT_SIGNAL(textChanged(const TQString&)), this, TQT_SLOT(changed()));
+
hostFQDN = LDAPManager::getMachineFQDN();
base->hostFQDN->setEnabled(false);
base->hostFQDN->clear();
@@ -158,6 +165,11 @@ void LDAPConfig::load(bool useDefaults )
}
base->ignoredUsers->setText(m_clientRealmConfig.ignoredUsers);
+ base->pamEnableCachedLogons->setChecked(m_clientRealmConfig.pamConfig.enable_cached_credentials);
+ base->pamCreateHomeDirectory->setChecked(m_clientRealmConfig.pamConfig.autocreate_user_directories_enable);
+ base->pamCreateHomeDirectoryUmask->setValue(m_clientRealmConfig.pamConfig.autocreate_user_directories_umask);
+ base->pamCreateHomeDirectorySkelDir->setURL(m_clientRealmConfig.pamConfig.autocreate_user_directories_skel);
+
updateRealmList();
processLockouts();
@@ -205,6 +217,11 @@ void LDAPConfig::save() {
m_clientRealmConfig.passwordHash = base->passwordHash->currentText();
m_clientRealmConfig.ignoredUsers = base->ignoredUsers->text();
+ m_clientRealmConfig.pamConfig.enable_cached_credentials = base->pamEnableCachedLogons->isChecked();
+ m_clientRealmConfig.pamConfig.autocreate_user_directories_enable = base->pamCreateHomeDirectory->isChecked();
+ m_clientRealmConfig.pamConfig.autocreate_user_directories_umask = base->pamCreateHomeDirectoryUmask->value();
+ m_clientRealmConfig.pamConfig.autocreate_user_directories_skel = base->pamCreateHomeDirectorySkelDir->url();
+
// Write system configuration
if (LDAPManager::saveClientRealmConfig(m_clientRealmConfig, systemconfig, &errorstring) != 0) {
KMessageBox::error(this, i18n("<qt><b>Unable to save configuration!</b><p>Details: %2</qt>").arg(errorstring), i18n("Unable to Save Configuration"));
@@ -231,7 +248,7 @@ void LDAPConfig::save() {
return;
}
// Write the PAM configuration files
- if (LDAPManager::writePAMFiles(&errorstring) != 0) {
+ if (LDAPManager::writePAMFiles(m_clientRealmConfig.pamConfig, &errorstring) != 0) {
KMessageBox::error(this, i18n("<qt><b>Unable to save configuration!</b><p>Details: %2</qt>").arg(errorstring), i18n("Unable to Save Configuration"));
return;
}
@@ -284,6 +301,7 @@ void LDAPConfig::processLockouts() {
base->groupRealms->setEnabled(panelIsEnabled);
base->groupKrbDefaults->setEnabled(panelIsEnabled);
base->groupConnectionParameters->setEnabled(panelIsEnabled);
+ base->groupPamConfig->setEnabled(panelIsEnabled);
TQListViewItem *selrealm = base->ldapRealmList->selectedItem();
if (selrealm) {
@@ -308,6 +326,15 @@ void LDAPConfig::processLockouts() {
base->btnRemoveRealm->setEnabled(false);
base->btnRealmProperties->setEnabled(false);
}
+
+ if (base->pamCreateHomeDirectory->isChecked()) {
+ base->pamCreateHomeDirectoryUmask->setEnabled(true);
+ base->pamCreateHomeDirectorySkelDir->setEnabled(true);
+ }
+ else {
+ base->pamCreateHomeDirectoryUmask->setEnabled(false);
+ base->pamCreateHomeDirectorySkelDir->setEnabled(false);
+ }
}
void LDAPConfig::bondToNewRealm() {
diff --git a/src/ldapconfigbase.ui b/src/ldapconfigbase.ui
index bbc48fa..a889ac9 100644
--- a/src/ldapconfigbase.ui
+++ b/src/ldapconfigbase.ui
@@ -427,6 +427,89 @@
</widget>
</grid>
</widget>
+ <widget class="TQGroupBox" row="2" column="0">
+ <property name="name">
+ <cstring>groupPamConfig</cstring>
+ </property>
+ <property name="title">
+ <string>Authentication Settings</string>
+ </property>
+ <grid>
+ <property name="name">
+ <cstring>unnamed</cstring>
+ </property>
+ <widget class="TQCheckBox" row="0" column="0" colspan="1">
+ <property name="name">
+ <cstring>pamCreateHomeDirectory</cstring>
+ </property>
+ <property name="text">
+ <string>&amp;Create home directory on first logon</string>
+ </property>
+ </widget>
+ <widget class="TQCheckBox" row="1" column="0" colspan="2">
+ <property name="name">
+ <cstring>pamEnableCachedLogons</cstring>
+ </property>
+ <property name="text">
+ <string>&amp;Enable logon credentials cache</string>
+ </property>
+ </widget>
+ <widget class="TQLabel" row="0" column="2">
+ <property name="name">
+ <cstring>unnamed</cstring>
+ </property>
+ <property name="text">
+ <string>Home directory mode creation mask</string>
+ </property>
+ <property name="sizePolicy">
+ <sizepolicy>
+ <hsizetype>0</hsizetype>
+ <vsizetype>0</vsizetype>
+ <horstretch>0</horstretch>
+ <verstretch>0</verstretch>
+ </sizepolicy>
+ </property>
+ </widget>
+ <widget class="TDEUmaskInput" row="0" column="3" >
+ <property name="name">
+ <cstring>pamCreateHomeDirectoryUmask</cstring>
+ </property>
+ <property name="base">
+ <number>8</number>
+ </property>
+ <property name="minValue">
+ <number>0</number>
+ </property>
+ <property name="maxValue">
+ <number>7777</number>
+ </property>
+ </widget>
+ <widget class="TQLabel" row="1" column="2">
+ <property name="name">
+ <cstring>unnamed</cstring>
+ </property>
+ <property name="text">
+ <string>Home directory skeleton location</string>
+ </property>
+ <property name="sizePolicy">
+ <sizepolicy>
+ <hsizetype>0</hsizetype>
+ <vsizetype>0</vsizetype>
+ <horstretch>0</horstretch>
+ <verstretch>0</verstretch>
+ </sizepolicy>
+ </property>
+ </widget>
+ <widget class="KURLRequester" row="1" column="3" >
+ <property name="name">
+ <cstring>pamCreateHomeDirectorySkelDir</cstring>
+ </property>
+ <property name="mode">
+ <number>18</number>
+ </property>
+ </widget>
+ </grid>
+ </widget>
<spacer row="4" column="0">
<property name="name" stdset="0">
<cstring>Spacer4</cstring>
@@ -454,6 +537,7 @@
</includes>
<includes>
<include location="local" impldecl="in implementation">kdialog.h</include>
+ <include location="local" impldecl="in implementation">tdeumaskinput.h</include>
</includes>
<layoutdefaults spacing="3" margin="6"/>
<layoutfunctions spacing="KDialog::spacingHint" margin="KDialog::marginHint"/>
diff --git a/src/tdeumaskinput.cpp b/src/tdeumaskinput.cpp
new file mode 100644
index 0000000..b1b2513
--- /dev/null
+++ b/src/tdeumaskinput.cpp
@@ -0,0 +1,61 @@
+/*
+ * tdeumaskinput.cpp
+ *
+ * Copyright (c) 2013 Timothy Pearson <[email protected]>
+ *
+ * Requires the Qt widget libraries, available at no cost at
+ * http://www.troll.no/
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this library; see the file COPYING.LIB. If not, write to
+ * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+
+#include "tdeumaskinput.h"
+
+TDEUmaskInput::TDEUmaskInput(TQWidget *parent, const char *name)
+ : KIntSpinBox(parent, name)
+{
+ //
+}
+
+TDEUmaskInput::TDEUmaskInput(int lower, int upper, int step, int value, int base,
+ TQWidget* parent, const char* name)
+ : KIntSpinBox(lower, upper, step, value, base, parent, name)
+{
+ //
+}
+
+TDEUmaskInput::~TDEUmaskInput()
+{
+ //
+}
+
+void TDEUmaskInput::setBase(int base)
+{
+ KIntSpinBox::setBase(base);
+}
+
+int TDEUmaskInput::base() const
+{
+ return KIntSpinBox::base();
+}
+
+TQString TDEUmaskInput::mapValueToText (int v) {
+ TQString baseText = KIntSpinBox::mapValueToText(v);
+ while (baseText.length() < 4) {
+ baseText.prepend("0");
+ }
+ return baseText;
+} \ No newline at end of file
diff --git a/src/tdeumaskinput.h b/src/tdeumaskinput.h
new file mode 100644
index 0000000..e2c1898
--- /dev/null
+++ b/src/tdeumaskinput.h
@@ -0,0 +1,83 @@
+/*
+ * tdeumaskinput.h
+ *
+ * Copyright (c) 2013 Timothy Pearson <[email protected]>
+ *
+ * Requires the Qt widget libraries, available at no cost at
+ * http://www.troll.no/
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this library; see the file COPYING.LIB. If not, write to
+ * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+
+#ifndef TDE_UMASKINPUT_H
+#define TDE_UMASKINPUT_H
+
+#include <knuminput.h>
+
+class TDEUI_EXPORT TDEUmaskInput : public KIntSpinBox
+{
+ Q_OBJECT
+
+ TQ_PROPERTY( int base READ base WRITE setBase )
+
+ public:
+ /**
+ * Constructor.
+ *
+ * Constructs a widget with an integer inputline with a little scrollbar
+ * and a slider, with minimal value 0, maximal value 99, step 1, base 10
+ * and initial value 0.
+ */
+ TDEUmaskInput( TQWidget *parent=0, const char *name=0);
+
+ /**
+ * Constructor.
+ *
+ * Constructs a widget with an integer inputline with a little scrollbar
+ * and a slider.
+ *
+ * @param lower The lowest valid value.
+ * @param upper The greatest valid value.
+ * @param step The step size of the scrollbar.
+ * @param value The actual value.
+ * @param base The base of the used number system.
+ * @param parent The parent of the widget.
+ * @param name The Name of the widget.
+ */
+ TDEUmaskInput(int lower, int upper, int step, int value, int base = 10, TQWidget* parent = 0, const char* name = 0);
+
+ /**
+ * Destructor.
+ */
+ virtual ~TDEUmaskInput();
+
+ public:
+ /**
+ * Sets the base in which the numbers in the spin box are represented.
+ */
+ void setBase(int base);
+
+ /**
+ * @return the base in which numbers in the spin box are represented.
+ */
+ int base() const;
+
+ protected:
+ virtual TQString mapValueToText(int);
+
+};
+
+#endif // TDE_UMASKINPUT_H \ No newline at end of file