Un étudiant vient de demander quel pourrait être l'inconvénient d'avoir un point ( .
) au nom de l'utilisateur. Par exemple:john.doe
Comment cela affectera-t-il le système ou les applications?
Un étudiant vient de demander quel pourrait être l'inconvénient d'avoir un point ( .
) au nom de l'utilisateur. Par exemple:john.doe
Comment cela affectera-t-il le système ou les applications?
Réponses:
POSIX déclare ceci à propos des noms d'utilisateur:
[...] Pour être portable sur des systèmes conformes à IEEE Std 1003.1-2001, la valeur est composée de caractères du jeu de caractères de nom de fichier portable. Le tiret ne doit pas être utilisé comme premier caractère d'un nom d'utilisateur portable.
... où le jeu de caractères du nom de fichier portable est:
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
a b c d e f g h i j k l m n o p q r s t u v w x y z
0 1 2 3 4 5 6 7 8 9 . _ -
En outre, la page de manuel du /etc/adduser.conf
fichier indique:
VALID NAMES
adduser and addgroup enforce conformity to IEEE Std 1003.1-2001,
which allows only the following characters to appear in group
and user names: letters, digits, underscores, periods, at signs
(@) and dashes. The name may not start with a dash. The "$" sign
is allowed at the end of usernames (to conform to samba).
An additional check can be adjusted via the configuration
parameter NAME_REGEX to enforce a local policy.
Alors que les deux spécifications semblent inclure le point, Ubuntu (sur mon 13.04 au moins) semble le refuser:
⊳ sudo adduser as.df
adduser: Please enter a username matching the regular expression configured
via the NAME_REGEX[_SYSTEM] configuration variable. Use the `--force-badname'
option to relax this check or reconfigure NAME_REGEX.
La valeur NAME_REGEX
par défaut dans Ubuntu est (à partir de la /etc/adduser.conf
page de manuel):
^[a-z][-a-z0-9]*$
_
, @
ou .
.en conclusion, un point .
peut être utilisé pour un nom d'utilisateur Ubuntu, il NAME_REGEX
suffit de le changer /etc/adduser.conf
. Étant donné qu'il est conforme à POSIX, il ne devrait y avoir aucun problème à avoir un .
dans le nom d'utilisateur avec un programme compatible POSIX.
Exécutez cette commande dans un terminal:
sudo nano /etc/adduser.conf
Localisez cette ligne (vers la fin du fichier)
#NAME_REGEX="^[a-z][-a-z0-9]*$"
et remplacez-le par
NAME_REGEX='^[a-z][-.a-z0-9]*$'
Notez que le -
doit rester le premier caractère de l'expression entre crochets [...]
, sinon il est traité comme spécifiant une plage a-z
.
Appuyez sur Ctrl+ X, puis Y, puis Enter.
Les références:
NAME_REGEX="^[a-z][-a-z0-9_.]*\$?$"
à /etc/adduser.conf
fait.
useradd
place: sudo useradd -m my.user
. C'est ce que nous faisons dans Userify et c'est également multiplateforme.
Les applications qui lisent les noms d'utilisateur peuvent utiliser une expression régulière qui suppose que votre nom d'utilisateur suit les règles et ne peut donc pas gérer votre nom d'utilisateur.
Marc Haber explique un inconvénient possible dans le bogue Debian # 604242 (Autoriser les points dans le nom d'utilisateur par défaut):
Le fait d'avoir des points dans le nom d'utilisateur crée certains problèmes avec scipts à l'aide de
chown
, qui accepte toujours les points comme séparateur entre le nom d'utilisateur et le nom de groupe. S'ilchown
accepte toujours des points, il y aura des scripts utilisant cette notation, qui se briseront si un nom d'utilisateur contient un point.Je recommanderais de conserver la valeur par défaut actuelle (qui peut être remplacée par la configuration locale) jusqu'à ce qu'elle
chown
ait cessé d'accepter les points comme séparateur.
Et chown
accepte toujours le point comme séparateur, bien qu'il ne soit plus documenté. Je suis d'accord que la compatibilité POSIX devrait prévaloir et j'emploie en effet des noms d'utilisateur contenant des points sur plusieurs systèmes sans aucun effet négatif.