Man page - runuser(1)

Packages contains this manual

Available languages:

en fr pl uk ro sr de

Manual

RUNUSER

NOM
SYNOPSIS
DESCRIPTION
OPTIONS
FICHIERS DE CONFIGURATION
CODE DE RETOUR
FICHIERS
HISTORIQUE
VOIR AUSSI
SIGNALER DES BOGUES
DISPONIBILITÉ

NOM

runuser - ExĂ©cuter une commande avec des identifiants d’utilisateur et de groupe substituĂ©s

SYNOPSIS

runuser [options] -u user [[--] command [ argument ...]]

runuser [options] [ - ] [ user [ argument ...]]

DESCRIPTION

runuser can be used to run commands with a substitute user and group ID. If the option -u is not given, runuser falls back to su -compatible semantics and a shell is executed. The difference between the commands runuser and su is that runuser does not ask for a password (because it may be executed by the root user only) and it uses a different PAM configuration. The command runuser does not have to be installed with set-user-ID permissions.

Si une session PAM n’est pas indispensable, la solution recommandĂ©e consiste Ă  utiliser la commande setpriv (1).

Si appelée sans argument, runuser exécute par défaut un interpréteur de commandes interactif en tant que superutilisateur .

Pour assurer la rĂ©trocompatibilitĂ©, runuser ne change pas, par dĂ©faut, de rĂ©pertoire actuel et ne dĂ©finit que les variables d’environnement HOME et SHELL (plus USER et LOGNAME si l’ utilisateur cible n’est pas le superutilisateur). Cette version de runuser utilise PAM pour la gestion de session.

Remarquez que runuser utilise dans tous les cas PAM (pam_getenvlist()) pour effectuer une modification sur l’environnement final. Les options de la ligne de commande comme --login ou --preserve-environment touchent l’environnement avant qu’il ne soit modifiĂ© par PAM.

Since version 2.38 runuser resets process resource limits RLIMIT_NICE, RLIMIT_RTPRIO, RLIMIT_FSIZE, RLIMIT_AS and RLIMIT_NOFILE.

OPTIONS

-c , --command = commande

Passer une commande Ă  l’interprĂ©teur de commandes avec l’option -c .

-f , --fast

Passer -f Ă  l’interprĂ©teur de commandes, ce qui pourrait ĂȘtre utile ou non suivant l’interprĂ©teur de commandes.

-g , --group = groupe

Le groupe primaire à utiliser. Cette option n’est permise que pour le superutilisateur.

-G , --supp-group = groupe

SpĂ©cifier un groupe supplĂ©mentaire. Cette option n’est disponible que pour le superutilisateur. Le premier groupe supplĂ©mentaire spĂ©cifiĂ© est Ă©galement utilisĂ© en tant que groupe primaire si l’option --group n’est pas spĂ©cifiĂ©e.

- , -l , --login

DĂ©marrer l’interprĂ©teur de commandes comme un interprĂ©teur de connexion avec un environnement similaire Ă  une connexion rĂ©elle :

‱ effacer toutes les variables d’environnement sauf TERM et les variables spĂ©cifiĂ©es avec --whitelist-environment ;

‱ initialiser les variables d’environnement HOME , SHELL , USER , LOGNAME et PATH

‱ se placer dans le rĂ©pertoire personnel de l’utilisateur cible ;

‱ dĂ©finir argv[0] pour l’interprĂ©teur de commandes Ă  « - » pour faire de l’interprĂ©teur de commandes un interprĂ©teur de connexion.

-m , -p , --preserve-environment

PrĂ©server la totalitĂ© de l’environnement, c’est-Ă -dire ne pas dĂ©finir HOME , SHELL , USER ni LOGNAME . Cette option est ignorĂ©e si l’option --login est indiquĂ©e.

-P , --pty

Create a pseudo-terminal for the session. The independent terminal provides better security as the user does not share a terminal with the original session. This can be used to avoid TIOCSTI ioctl terminal injection and other security attacks against terminal file descriptors. The entire session can also be moved to the background (e.g., runuser --pty -u user -- command & ). If the pseudo-terminal is enabled, then runuser works as a proxy between the sessions (sync stdin and stdout).

This feature is mostly designed for interactive sessions. If the standard input is not a terminal, but for example a pipe (e.g., echo "date" | runuser --pty -u user ), then the ECHO flag for the pseudo-terminal is disabled to avoid messy output.

-s , --shell = shell

ExĂ©cuter l’interprĂ©teur de commandes shell indiquĂ© au lieu de celui par dĂ©faut. L’interprĂ©teur de commandes Ă  exĂ©cuter est sĂ©lectionnĂ© d’aprĂšs les rĂšgles suivantes dans cet ordre :

‱ l’interprĂ©teur de commandes indiquĂ© avec --shell ;

‱ l’interprĂ©teur de commandes indiquĂ© dans la variable d’environnement SHELL si l’option --preserve-environment est utilisĂ©e ;

‱ l’interprĂ©teur de commandes indiquĂ© dans l’entrĂ©e passwd de l’utilisateur cible ;

‱ /bin/sh

Si l’utilisateur cible a un interprĂ©teur de commandes restreint (c’est-Ă -dire ne faisant pas partie de /etc/shells ), l’option --shell et la variable d’environnement SHELL sont ignorĂ©es sauf si l’utilisateur appelant est le superutilisateur.

--session-command= commande

Comme -c , mais sans créer de nouvelle session (à éviter).

-T , --no-pty

Do not create a pseudo-terminal, opposite of --pty and -P . Note that running without a pseudo-terminal opens the security risk of privilege escalation through TIOCSTI/TIOCLINUX ioctl command injection.

-u , --user = user

Run command with the effective user ID and group ID of the user name user .

-w , --whitelist-environment = liste

Ne pas rĂ©initialiser les variables d’environnement spĂ©cifiĂ©es dans une liste sĂ©parĂ©e par des virgules au moment de vider l’environnement pour --login (une connexion). La liste blanche est ignorĂ©e s’agissant des variables d’environnement HOME , SHELL , USER , LOGNAME et PATH .

-h , --help

Afficher l’aide-mĂ©moire puis quitter.

-V , --version

Afficher la version et quitter.

FICHIERS DE CONFIGURATION

runuser reads the /etc/default/runuser and /etc/login.defs configuration files. The following configuration items are relevant for runuser :

ENV_PATH (chaĂźne)

DĂ©finit la variable d’environnement pour un utilisateur ordinaire. La valeur par dĂ©faut est /usr/local/bin:/bin:/usr/bin .

ENV_ROOTPATH (chaĂźne), ENV_SUPATH (chaĂźne)

Defines the PATH environment variable for root. ENV_SUPATH takes precedence. The default value is /usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin .

ALWAYS_SET_PATH (booléen)

If set to yes and --login and --preserve-environment were not specified runuser initializes PATH .

La variable d’environnement PATH peut ĂȘtre diffĂ©rente sur des systĂšmes oĂč /bin et /sbin sont fusionnĂ©s dans /usr , cette variable est aussi concernĂ©e par l’option --login de la ligne de commande et le paramĂ©trage du systĂšme PAM (comme pam_env (8)).

CODE DE RETOUR

runuser normally returns the exit status of the command it executed. If the command was killed by a signal, runuser returns the number of the signal plus 128.

Le code de retour gĂ©nĂ©rĂ© par runuser elle-mĂȘme est un des suivants.

1

Erreur gĂ©nĂ©rale avant d’exĂ©cuter la commande demandĂ©e.

126

La commande demandĂ©e n’a pas pu ĂȘtre exĂ©cutĂ©e.

127

La commande demandĂ©e n’a pas Ă©tĂ© trouvĂ©e.

FICHIERS

/etc/pam.d/runuser

fichier de configuration de PAM par défaut

/etc/pam.d/runuser-l

fichier de configuration de PAM si --login est indiqué

/etc/default/runuser

fichier de configuration logindef spécifique à runuser

/etc/login.defs

fichier de configuration logindef général

HISTORIQUE

Cette commande runuser est dérivée de su de coreutils, qui était basée sur une implémentation de David MacKenzie, et de la commande runuser de Fedora par Dan Walsh.

VOIR AUSSI

setpriv (1), su (1), login.defs (5), shells (5), pam (8)

SIGNALER DES BOGUES

Pour signaler un bogue, utilisez le gestionnaire de bogues <https://github.com/util-linux/util-linux/issues>.

DISPONIBILITÉ

La commande runuser fait partie du paquet util-linux, elle est disponible sur l’archive du noyau Linux <https://www.kernel.org/pub/linux/utils/util-linux/>.