diff options
author | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2011-11-06 15:56:40 -0600 |
---|---|---|
committer | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2011-11-06 15:56:40 -0600 |
commit | e16866e072f94410321d70daedbcb855ea878cac (patch) | |
tree | ee3f52eabde7da1a0e6ca845fb9c2813cf1558cf /tdesu/su.h | |
parent | a58c20c1a7593631a1b50213c805507ebc16adaf (diff) | |
download | tdelibs-e16866e072f94410321d70daedbcb855ea878cac.tar.gz tdelibs-e16866e072f94410321d70daedbcb855ea878cac.zip |
Actually move the kde files that were renamed in the last commit
Diffstat (limited to 'tdesu/su.h')
-rw-r--r-- | tdesu/su.h | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/tdesu/su.h b/tdesu/su.h new file mode 100644 index 000000000..dcb67a14c --- /dev/null +++ b/tdesu/su.h @@ -0,0 +1,63 @@ +/* vi: ts=8 sts=4 sw=4 + * + * $Id$ + * + * This file is part of the KDE project, module tdesu. + * Copyright (C) 1999,2000 Geert Jansen <jansen@kde.org> + * + * This is free software; you can use this library under the GNU Library + * General Public License, version 2. See the file "COPYING.LIB" for the + * exact licensing terms. + */ + +#ifndef __SU_h_Included__ +#define __SU_h_Included__ + +#include <tqcstring.h> + +#include <kdelibs_export.h> + +#include "stub.h" + +/** + * Executes a command under elevated privileges, using su. + */ + +class KDESU_EXPORT SuProcess: public StubProcess +{ +public: + SuProcess(const TQCString &user=0, const TQCString &command=0); + ~SuProcess(); + + enum Errors { SuNotFound=1, SuNotAllowed, SuIncorrectPassword }; + + /** + * Executes the command. This will wait for the command to finish. + */ + enum checkMode { NoCheck=0, Install=1, NeedPassword=2 } ; + int exec(const char *password, int check=NoCheck); + + /** + * Checks if the stub is installed and the password is correct. + * @return Zero if everything is correct, nonzero otherwise. + */ + int checkInstall(const char *password); + + /** + * Checks if a password is needed. + */ + int checkNeedPassword(); + +private: + enum SuErrors { error=-1, ok=0, killme=1, notauthorized=2 } ; + int ConverseSU(const char *password); + +protected: + virtual void virtual_hook( int id, void* data ); +private: + class SuProcessPrivate; + SuProcessPrivate *d; + TQString superUserCommand; +}; + +#endif |