Le 10/01/2013 19:19, JC PAROLA a écrit :
Solution simpliste qui n'est pas adaptée au final à votre cas car ne permettant pas de laisser l'accès "complet" à un shell à l'utilisateur mais pratique si l'on veut restreindre à l'usage de rsync (ou de scripts/commandes données) là où rssh par exemple limitera l'accès au seul SFTP (rsync impossible) et où lshell sera bien plus complexe :[...]
Mettre dans le .ssh/authorized_keys2 :
command="/root/.ssh/validate-ssh.sh",no-pty,no-agent-forwarding,no-port-forwarding ssh-rsa LA_CLE_SSH_ICIPuis dans le validate-ssh.sh (si commande contient des caractères permettant d'échapper tels que ;`&| elle est rejetée et doit ensuite correspondre à l'un des cas autorisés) :
(possibilité aussi de limiter à certaines IP en rajoutant from="IP"
#!/bin/mksh
case "$SSH_ORIGINAL_COMMAND" {
(*\&*|*\(*|*\{*|*\;*|*\<*|*\`*|*\|*)
print "Rejected"
;;
("rsync --server"*)
ionice -c3 nice $SSH_ORIGINAL_COMMAND
;;
("/root/unscript.sh"|"/root/autrescript.sh")
"$SSH_ORIGINAL_COMMAND"
;;
(*)
print "Rejected"
;;
}
_______________________________________________
Liste de diffusion du FRsAG
http://www.frsag.org/