KDESu::SuProcess

Search for usage in LXR

#include <KDESu/SuProcess>

Inheritance diagram for KDESu::SuProcess:

Public Types

enum  checkMode { NoCheck = 0 , Install = 1 , NeedPassword = 2 }
 
enum  Errors { SuNotFound = 1 , SuNotAllowed , SuIncorrectPassword }
 
- Public Types inherited from KDESu::StubProcess
enum  Scheduler { SchedNormal , SchedRealtime }
 
- Public Types inherited from KDESu::PtyProcess
enum  checkPidStatus { Error = -1 , NotExited = -2 , Killed = -3 }
 

Public Member Functions

 SuProcess (const QByteArray &user=nullptr, const QByteArray &command=nullptr)
 
int checkInstall (const char *password)
 
int checkNeedPassword ()
 
int exec (const char *password, int check=NoCheck)
 
QString superUserCommand ()
 
bool useUsersOwnPassword ()
 
- Public Member Functions inherited from KDESu::StubProcess
void setCommand (const QByteArray &command)
 
void setPriority (int prio)
 
void setScheduler (int sched)
 
void setUser (const QByteArray &user)
 
void setXOnly (bool xonly)
 
- Public Member Functions inherited from KDESu::PtyProcess
int enableLocalEcho (bool enable=true)
 
int exec (const QByteArray &command, const QList< QByteArray > &args)
 
int fd () const
 
int pid () const
 
QByteArray readAll (bool block=true)
 
QByteArray readLine (bool block=true)
 
void setEnvironment (const QList< QByteArray > &env)
 
void setErase (bool erase)
 
void setExitString (const QByteArray &exit)
 
void setTerminal (bool terminal)
 
void unreadLine (const QByteArray &line, bool addNewline=true)
 
int waitForChild ()
 
int waitSlave ()
 
void writeLine (const QByteArray &line, bool addNewline=true)
 

Protected Member Functions

void virtual_hook (int id, void *data) override
 
- Protected Member Functions inherited from KDESu::StubProcess
KDESU_NO_EXPORT StubProcess (StubProcessPrivate &dd)
 
int converseStub (int check)
 
virtual QByteArray display ()
 
virtual QByteArray displayAuth ()
 
- Protected Member Functions inherited from KDESu::PtyProcess
KDESU_NO_EXPORT PtyProcess (PtyProcessPrivate &dd)
 
QList< QByteArrayenvironment () const
 

Additional Inherited Members

- Static Public Member Functions inherited from KDESu::PtyProcess
static bool checkPid (pid_t pid)
 
static int checkPidExited (pid_t pid)
 
static int waitMS (int fd, int ms)
 
- Protected Attributes inherited from KDESu::StubProcess
QByteArray m_command
 
KDESuPrivate::KCookie * m_cookie
 
int m_priority
 
int m_scheduler
 
QByteArray m_user
 
bool m_XOnly
 
- Protected Attributes inherited from KDESu::PtyProcess
std::unique_ptr< PtyProcessPrivate > const d_ptr
 
QByteArray m_command
 
bool m_erase
 
QByteArray m_exitString
 
int m_pid
 
bool m_terminal
 

Detailed Description

Executes a command under elevated privileges, using su.

Definition at line 23 of file suprocess.h.

Member Enumeration Documentation

◆ checkMode

Executes the command.

This will wait for the command to finish.

Definition at line 35 of file suprocess.h.

◆ Errors

enum KDESu::SuProcess::Errors

Definition at line 26 of file suprocess.h.

Constructor & Destructor Documentation

◆ SuProcess()

KDESu::SuProcess::SuProcess ( const QByteArray & user = nullptr,
const QByteArray & command = nullptr )
explicit

Definition at line 52 of file suprocess.cpp.

Member Function Documentation

◆ checkInstall()

int KDESu::SuProcess::checkInstall ( const char * password)

Checks if the stub is installed and the password is correct.

Returns
Zero if everything is correct, nonzero otherwise.

Definition at line 91 of file suprocess.cpp.

◆ checkNeedPassword()

int KDESu::SuProcess::checkNeedPassword ( )

Checks if a password is needed.

Definition at line 96 of file suprocess.cpp.

◆ exec()

int KDESu::SuProcess::exec ( const char * password,
int check = NoCheck )

Definition at line 104 of file suprocess.cpp.

◆ superUserCommand()

QString KDESu::SuProcess::superUserCommand ( )

Checks what the default super user command is, e.g.

sudo, su, etc

Returns
the default super user command

Definition at line 72 of file suprocess.cpp.

◆ useUsersOwnPassword()

bool KDESu::SuProcess::useUsersOwnPassword ( )

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.

Definition at line 79 of file suprocess.cpp.

◆ virtual_hook()

void KDESu::SuProcess::virtual_hook ( int id,
void * data )
overrideprotectedvirtual

Standard hack to add virtual methods in a BC way.

Unused.

Reimplemented from KDESu::StubProcess.

Definition at line 306 of file suprocess.cpp.


The documentation for this class was generated from the following files:
This file is part of the KDE documentation.
Documentation copyright © 1996-2025 The KDE developers.
Generated on Fri Jan 3 2025 11:50:34 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.