Où sont stockées les insultes de sudo?

224

Pour ceux qui aiment l'humour, sudo peut être configuré pour imprimer une phrase aléatoire plus ou moins insultante ou amusante au lieu de Sorry, try again. neutre en ajoutant la ligne ci-dessous à /etc/sudoers (en utilisant la commande sudo visudo , ne pas éditer manuellement!):

Defaults insults

Voici quelques exemples:

[sudo] password for bytecommander: 
The more you drive -- the dumber you get.
[sudo] password for bytecommander: 
I've seen penguins that can type better than that.
[sudo] password for bytecommander: 
This mission is too important for me to allow you to jeopardize it.
[sudo] password for bytecommander: 
He has fallen in the water!
[sudo] password for bytecommander: 
Hold it up to the light --- not a brain in sight!

Maintenant, juste pour le plaisir, je voudrais les lire tous, mais la mauvaise méthode de saisie de mots de passe incorrects toute la journée (délai après chaque tentative, seulement 2 messages par 3 tentatives, abandon après 3 tentatives, .. .).

Alors ... où sont stockées ces insultes? Tout fichier texte que je peux lire directement? Ou des chaînes codées en dur dans le code source?

Comment puis-je obtenir une liste de tous les messages d'insulte sudo disponibles?

    
posée Byte Commander 15.10.2016 - 20:25
la source

5 réponses

172

Ils sont dans le fichier binaire

/usr/lib/sudo/sudoers.so

(trouvé par: find /usr/lib/sudo -type f | xargs grep "fallen in the water" )

Si vous activez les téléchargements de sources et faites

apt source sudo

Vous pouvez trouver les fichiers d'insultes dans le répertoire source sous

plugins/sudoers

Les fichiers sont

ins_2001.h
ins_classic.h
ins_csops.h
ins_goons.h
insults.h

Exemple de ce à quoi ces fichiers ressemblent:

#ifndef SUDOERS_INS_GOONS_H
#define SUDOERS_INS_GOONS_H

/*
 * Insults from the "Goon Show."
 */

    "You silly, twisted boy you.",
    "He has fallen in the water!",
    "We'll all be murdered in our beds!",
    "You can't come in. Our tiger has got flu",

et ainsi de suite ... ils sont assez lisibles.

    
réponse donnée Zanna 15.10.2016 - 20:34
la source
75

Avec

dpkg -L sudo | xargs grep dumber

nous pouvons rechercher quels fichiers du paquet sudo contiennent le mot dumber .

La seule correspondance est dans le fichier /usr/lib/sudo/sudoers.so . Ceci est un fichier binaire, nous utilisons donc la commande strings pour obtenir uniquement des choses qui semblent être lisibles par l'homme. Comme il y a beaucoup de choses, nous concentrons le résultat dans less :

strings /usr/lib/sudo/sudoers.so | less

Dans less nous pouvons utiliser

/dumber

rechercher à nouveau le mot "dumber". Cela nous amène directement dans les insultes. Faites défiler vers le haut et le bas avec les touches du curseur et quittez avec q

    
réponse donnée Florian Diesch 15.10.2016 - 20:55
la source
72

Liste de toutes les insultes

Lorsque nous regardons toutes les insultes, nous découvrons une nouveauté intéressante: dire que le brocoli est politiquement correct, mais dire que ce n’est pas le cas. Toutes les insultes sont énumérées ci-dessous.

ins_2001.h (insultes de 2001 Odyssée de l'espace):

.
    /*
     * HAL insults (paraphrased) from 2001.
     */

    "Just what do you think you're doing Dave?",
    "It can only be attributed to human error.",
    "That's something I cannot allow to happen.",
    "My mind is going. I can feel it.",
    "Sorry about this, I know it's a bit silly.",
    "Take a stress pill and think things over.",
    "This mission is too important for me to allow you to jeopardize it.",
    "I feel much better now.",

ins_classic.h (Insultes Original Sudo 8):

    /*
     * Insults from the original sudo(8).
     */

    "Wrong!  You cheating scum!",
#ifdef PC_INSULTS
    "And you call yourself a Rocket Scientist!",
#else
    "No soap, honkie-lips.",
#endif
    "Where did you learn to type?",
    "Are you on drugs?",
    "My pet ferret can type better than you!",
    "You type like i drive.",
    "Do you think like you type?",
    "Your mind just hasn't been the same since the electro-shock, has it?",

ins_csops.h (insultes CSOps):

    /*
     * CSOps insults (may be site dependent).
     */

    "Maybe if you used more than just two fingers...",
    "BOB says:  You seem to have forgotten your passwd, enter another!",
    "stty: unknown mode: doofus",
    "I can't hear you -- I'm using the scrambler.",
    "The more you drive -- the dumber you get.",
#ifdef PC_INSULTS
    "Listen, broccoli brains, I don't have time to listen to this trash.",
#else
    "Listen, burrito brains, I don't have time to listen to this trash.",
#endif
    "I've seen penguins that can type better than that.",
    "Have you considered trying to match wits with a rutabaga?",
    "You speak an infinite deal of nothing",

ins_goons.h (insultes de Goon Show):

.
    /*
     * Insults from the "Goon Show."
     */

    "You silly, twisted boy you.",
    "He has fallen in the water!",
    "We'll all be murdered in our beds!",
    "You can't come in. Our tiger has got flu",
    "I don't wish to know that.",
    "What, what, what, what, what, what, what, what, what, what?",
    "You can't get the wood, you know.",
    "You'll starve!",
    "... and it used to be so popular...",
    "Pauses for audience applause, not a sausage",
    "Hold it up to the light --- not a brain in sight!",
    "Have a gorilla...",
    "There must be cure for it!",
    "There's a lot of it about, you know.",
    "You do that again and see what happens...",
    "Ying Tong Iddle I Po",
    "Harm can come to a young lad like that!",
    "And with that remarks folks, the case of the Crown vs yourself was proven.",
    "Speak English you fool --- there are no subtitles in this scene.",
    "You gotta go owwwww!",
    "I have been called worse.",
    "It's only your word against mine.",
    "I think ... err ... I think ... I think I'll go home",

Le fichier insults.h contient les instructions du compilateur sur les insultes ci-dessus à inclure dans le noyau compilé. En effet, vous pouvez créer votre propre fichier d'insultes, ajouter le nom à insults.h et le recompiler pour avoir des messages comme "Quoi, êtes-vous un utilisateur ArchLinux?" ou "Ce n'est pas Windows où les erreurs sont monnaie courante!", etc.

Notez le #ifdef PC_INSULTS dans certains fichiers insultes. Cela ne signifie pas "si vous avez un ordinateur personnel", cela signifie "si vous voulez être politiquement correct".

    
réponse donnée WinEunuuchs2Unix 15.10.2016 - 22:22
la source
11

Les réponses ci-dessus sont idéales pour la recherche hors ligne. Mais nous sommes en ligne. Ouvrez donc la recherche de code Debian et essayez l'une des insultes here . Il vous indique instantanément que c'est en sudo_1.8.12-1/plugins/sudoers/ins_csops.h . Cela a l'avantage de le trouver partout que ce soit un fichier de configuration à déployer dans /etc ou autre. Et comme il s’agit d’un fichier .h, il est visible dans la source et non pas modifiable.

    
réponse donnée chx 19.10.2016 - 01:49
la source
7

Pour ajouter aux autres réponses, les insultes semblent se trouver dans la section .rodata de sudoers.so. Vous pouvez utiliser objcopy pour restreindre quelque peu la sortie, même s'il y aura toujours beaucoup de faux positifs:

$ objcopy /usr/lib/sudo/sudoers.so /dev/null --dump-section .rodata=/dev/stdout | strings | head
/build/sudo-g3ghsu/sudo-1.8.16/plugins/sudoers/auth/sudo_auth.c
invalid authentication methods
Invalid authentication methods compiled into sudo!  You may not mix standalone and non-standalone authentication.
There are no authentication methods compiled into sudo!  If you want to turn off authentication, use the --disable-authentication configure option.
Unable to initialize authentication methods.
Just what do you think you're doing Dave?
It can only be attributed to human error.
That's something I cannot allow to happen.
My mind is going. I can feel it.
Sorry about this, I know it's a bit silly.
$ 
    
réponse donnée Digital Trauma 18.10.2016 - 01:48
la source

Lire d'autres questions sur les étiquettes