/usr/include/KF5/KDESu/kdesu/suprocess.h is in libkf5su-dev 5.18.0-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 | /*
* This file is part of the KDE project, module kdesu.
* 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 KDESUSU_H
#define KDESUSU_H
#include <kdesu/kdesu_export.h>
#include "stubprocess.h"
namespace KDESu
{
/** \class SuProcess kdesu/suprocess.h
* Executes a command under elevated privileges, using su.
*/
class KDESU_EXPORT SuProcess : public StubProcess
{
public:
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
};
explicit SuProcess(const QByteArray &user = 0, const QByteArray &command = 0);
~SuProcess();
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();
/**
* Checks what the default super user command is, e.g. sudo, su, etc
* @return the default super user command
*/
QString superUserCommand();
/**
* Checks whether or not the user's password is being asked for or another
* user's password. Due to usage of systems such as sudo, even when attempting
* to switch to another user one may need to enter their own password.
*/
bool useUsersOwnPassword();
protected:
void virtual_hook(int id, void *data) Q_DECL_OVERRIDE;
private:
enum SuErrors {
error = -1,
ok = 0,
killme = 1,
notauthorized = 2
};
int converseSU(const char *password);
class SuProcessPrivate;
SuProcessPrivate *const d;
};
}
#endif //KDESUSU_H
|