<SNIP>
> > The problem with telnetd is that you can pass a terminal name that indicates
> > 'use a local file'. Now the ncurses library then goes 'ok leading slash
> > all well and good', Im not suid uid==euid, lets open it as root and read a
> > few bytes. You can't do much with it - you can rewind the machines tape
> > drive for example however. Also if your termcap parser has bugs you can
> > hit those.
>
> This is fixed in the latest (pre-)release of ncurses-5.0.  From the release
> notes posted to bug-ncurses mailing list (as of last night) from da man
> hissef:
>
> 990821  pre-release
>         + updated configure macros CF_MAKEFLAGS, CF_CHECK_ERRNO
>         + minor corrections to beterm terminfo entry.
>         + modify lib_setup.c to reject values of $TERM which have a '/' in them.
>
> So, version 5.0 will no longer accept $TERM that has a slash in it at all,
> much less a leading one.  I haven't looked closely at the source code, but a
> similar change to the 4.2 sources, the version most distributions are using
> now, should address this at least where tgetent() is concerned.

from a COL2.2 system

ldd /usr/sbin/in.telnetd
        libncurses.so.4 => /lib/libncurses.so.4 (0x40018000)
        libc.so.6 => /lib/libc.so.6 (0x4005a000)
        /lib/ld-linux.so.2 => /lib/ld-linux.so.2 (0x40000000)

i think someone should fix the last post on Caldera's homepage regarding
this vulnerability

http://www.calderasystems.com/news/security/CSSA-1999:020.0.txt

.... Olaf? ;)

> > It is a very nice example of why saying "lets ignore XYZ variable" is not
> > security but a quick fix for emergencies. If you don't fix the code it
> > will get you..
>
> Yep...

wise words

Carlo

Reply via email to