mirror of
git://git.9front.org/plan9front/plan9front
synced 2025-01-12 11:10:06 +00:00
rcpu: show error when we auth but don't connect
When a user isn't allowed to log into a file server, we used to silently dump the user back to the console, reporting that the command succeeded. We should give the user an error when they fail to log in, and we should exit unsuccessfully. This status is communicated by setting up a sentinel env var, and clearning it just before we execute the user command.
This commit is contained in:
parent
dd029bddc8
commit
e92e9cf193
1 changed files with 6 additions and 0 deletions
|
@ -23,6 +23,7 @@ fn server {
|
|||
if(test -d /mnt/term/mnt/cpunote) {
|
||||
rfork e
|
||||
mainproc=$apid
|
||||
rm -f /mnt/term/env/rfailed
|
||||
{cat; echo -n hangup} </mnt/term/mnt/cpunote/data >/proc/$mainproc/notepg &
|
||||
noteproc=$apid
|
||||
wait $mainproc
|
||||
|
@ -33,6 +34,7 @@ fn server {
|
|||
|
||||
fn client {
|
||||
echo -n >/env/rstatus
|
||||
echo -n 'lost connection' > /env/rfailed
|
||||
rfork n
|
||||
bind '#|' /mnt/cpunote || exit
|
||||
</fd/0 exec $exportfs -r / &
|
||||
|
@ -45,6 +47,10 @@ fn client {
|
|||
echo -n interrupt
|
||||
wait
|
||||
}
|
||||
if(test -e /env/rfailed){
|
||||
>[1=2] echo lost connection
|
||||
exit 'disconnected'
|
||||
}
|
||||
status=`{cat /env/rstatus}
|
||||
exit $"status
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue