/*************************************************************************** * 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 _LDAPCONTROLLER_H_ #define _LDAPCONTROLLER_H_ #include #include #include #include #include #include #include #include #include "ldapcontrollerconfigbase.h" enum sc_command { SC_START, SC_STOP, SC_RESTART, SC_PURGE, SC_SETDBPERMS }; // 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; }; class LDAPController: public KCModule { Q_OBJECT public: LDAPController( TQWidget *parent=0, const char *name=0, const TQStringList& = TQStringList() ); ~LDAPController(); virtual void load(); virtual void save(); virtual void defaults(); virtual int buttons(); virtual TQString quickHelp() const; virtual const KAboutData *aboutData() const { return myAboutData; }; public: int createNewLDAPRealm(TQWidget* dialogparent, LDAPRealmConfig realmconfig, TQString adminUserName, TQString adminGroupName, const char * adminPassword, TQString rootUserName, const char * rootPassword, TQString adminRealm, TQString *errstr); // FIXME // This should be moved to a TDE core library TQString getMachineFQDN(); private slots: void systemRoleChanged(); void processLockouts(); private: int controlHeimdalServer(sc_command command); int controlLDAPServer(sc_command command, uid_t userid=-1, gid_t groupid=-1); private: KAboutData *myAboutData; LDAPControllerConfigBase *m_base; KSimpleConfig *m_systemconfig; TQString m_fqdn; int m_prevRole; }; #endif // _LDAPCONTROLLER_H_