#ifndef __LDAP_H__ #define __LDAP_H__ #include <tqstring.h> #include <tqvaluelist.h> #include <tdeio/slavebase.h> #include <tdeio/authinfo.h> #define LDAP_DEPRECATED 1 /* Needed for ldap_simple_bind_s with openldap >= 2.3.x */ #include <lber.h> #include <ldap.h> #include <tdeabc/ldapurl.h> class LDAPProtocol : public TDEIO::SlaveBase { public: LDAPProtocol( const TQCString &protocol, const TQCString &pool, const TQCString &app ); virtual ~LDAPProtocol(); virtual void setHost( const TQString& host, int port, const TQString& user, const TQString& pass ); virtual void openConnection(); virtual void closeConnection(); virtual void get( const KURL& url ); virtual void stat( const KURL& url ); virtual void listDir( const KURL& url ); virtual void del( const KURL& url, bool isfile ); virtual void put( const KURL& url, int permissions, bool overwrite, bool resume ); int saslInteract( void *in ); private: TQString mHost; int mPort; TQString mUser; TQString mPassword; LDAP *mLDAP; int mVer, mSizeLimit, mTimeLimit; bool mTLS; bool mAuthSASL; TQString mMech,mRealm,mBindName; bool mCancel, mFirstAuth; void controlsFromMetaData( LDAPControl ***serverctrls, LDAPControl ***clientctrls ); void addControlOp( LDAPControl ***pctrls, const TQString &oid, const TQByteArray &value, bool critical ); void addModOp( LDAPMod ***pmods, int mod_type, const TQString &attr, const TQByteArray &value ); void LDAPEntry2UDSEntry( const TQString &dn, TDEIO::UDSEntry &entry, const TDEABC::LDAPUrl &usrc, bool dir=false ); int asyncSearch( TDEABC::LDAPUrl &usrc ); TQCString LDAPEntryAsLDIF( LDAPMessage *msg ); void LDAPErr( const KURL &url, int err = LDAP_SUCCESS ); void changeCheck( TDEABC::LDAPUrl &url ); void fillAuthInfo( TDEIO::AuthInfo &info ); }; #endif