/*************************************************************************** * Copyright (C) 2012 by Timothy Pearson * * kb9vqf@pearsoncomputing.net * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * * This program 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 General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ #ifndef _LDAP_H_ #define _LDAP_H_ #include #include #include #include #include #include #include #include #include #include "ldapconfigbase.h" #ifdef HAVE_CONFIG_H #include #endif // PRIVATE class LDAPRealmConfig { public: TQString name; bool bonded; long uid_offset; long gid_offset; TQStringList domain_mappings; TQString kdc; int kdc_port; TQString admin_server; int admin_server_port; bool pkinit_require_eku; bool pkinit_require_krbtgt_otherName; bool win2k_pkinit; bool win2k_pkinit_require_binding; }; typedef TQMap LDAPRealmConfigList; class LDAPConfig: public KCModule { Q_OBJECT public: LDAPConfig( TQWidget *parent=0, const char *name=0, const TQStringList& = TQStringList() ); ~LDAPConfig(); virtual void load(); virtual void load( bool useDefaults); virtual void save(); virtual void defaults(); virtual int buttons(); virtual TQString quickHelp() const; virtual const KAboutData *aboutData() const { return myAboutData; }; int bondRealm(LDAPRealmConfig realmcfg, TQString adminUserName, const char * adminPassword, TQString adminRealm, TQString *errstr=0); int unbondRealm(LDAPRealmConfig realmcfg, TQString adminUserName, const char * adminPassword, TQString adminRealm, TQString *errstr=0); // FIXME // This should be moved to a TDE core library TQString getMachineFQDN(); private slots: void processLockouts(); void bondToNewRealm(); void reBondToRealm(); void removeRealm(); void deactivateRealm(); void realmProperties(); private: void updateRealmList(); void writeKrb5ConfFile(); void writeLDAPConfFile(); void writeNSSwitchFile(); private: KAboutData *myAboutData; KGlobalSettings *kgs; LDAPConfigBase *base; LDAPRealmConfigList m_realms; TQString m_fqdn; TQString m_defaultRealm; int m_ticketLifetime; int m_ldapVersion; int m_ldapTimeout; TQString m_bindPolicy; int m_ldapBindTimeout; TQString m_passwordHash; TQString m_ignoredUsers; }; #endif