evolve or die

yanf.txt

yanf.txt
Posted Dec 31, 2004
Authored by Ariel Berkman

A buffer overflow vulnerability exists in the Yanf news fetcher utility version 0.4.

tags | advisory, overflow
MD5 | 14bbda8f498430f2e0419965424f8c90

yanf.txt

Change Mirror Download
From djb@cr.yp.to Wed Dec 15 14:20:44 2004
Date: 15 Dec 2004 08:15:34 -0000
From: D. J. Bernstein <djb@cr.yp.to>
To: securesoftware@list.cr.yp.to, yanf@gmx.net, sycrash@users.sourceforge.net
Subject: [remote] [control] Yanf 0.4 get() overflows buf

Ariel Berkman, a student in my Fall 2004 UNIX Security Holes course, has
discovered a remotely exploitable security hole in Yanf. I'm publishing
this notice, but all the discovery credits should be assigned to
Berkman.

You are at risk if you connect to any HTTP servers using Yanf. Anyone
who provides an HTTP response to Yanf (not necessarily the legitimate
server administrator; an attacker can forge HTTP responses) then has
complete control over your account: he can read and modify your files,
watch the programs you're running, etc.

Proof of concept: On an x86 computer running FreeBSD 4.10 with ucspi-tcp
installed, save the file 9.http attached to this message, and, as root,
type

tcpserver 127.0.0.1 80 cat 9.http &

to arrange for 9.http as the response to any connection to IP address
127.0.0.1 port 80. Then, as any user, type

wget http://umn.dl.sourceforge.net/sourceforge/yanf/yanf-0.4.tar.gz
gunzip < yanf-0.4.tar.gz | tar -xf -
cd yanf-0.4
make

to download and compile the yanf program, version 0.4 (current). Then
type

echo '[global]' > my.conf
echo 'start = blah' >> my.conf
echo '' >> my.conf
echo '[Slashdot]' >> my.conf
echo 'url = localhost/test.blah' >> my.conf
echo 'type = slash' >> my.conf
echo 'max = 10' >> my.conf
echo 'output = blah' >> my.conf
bin/yanf my.conf

with the unauthorized result that a file named x is created (and its
previous contents destroyed) in the current directory. (I tested this
with a 534-byte environment, as reported by printenv | wc -c.)

Here's the bug: In src/get.c, get() reads a line of any length into a
2048-byte buf[] array.

---D. J. Bernstein, Associate Professor, Department of Mathematics,
Statistics, and Computer Science, University of Illinois at Chicago

[ Part 2, Text/PLAIN (charset: unknown-8bit) 30 lines. ]
[ Unable to print this part. ]

Comments

RSS Feed Subscribe to this comment feed

No comments yet, be the first!

Login or Register to post a comment

File Archive:

May 2012

  • Su
  • Mo
  • Tu
  • We
  • Th
  • Fr
  • Sa
  • 1
    May 1st
    37 Files
  • 2
    May 2nd
    53 Files
  • 3
    May 3rd
    33 Files
  • 4
    May 4th
    4 Files
  • 5
    May 5th
    10 Files
  • 6
    May 6th
    17 Files
  • 7
    May 7th
    19 Files
  • 8
    May 8th
    36 Files
  • 9
    May 9th
    34 Files
  • 10
    May 10th
    35 Files
  • 11
    May 11th
    20 Files
  • 12
    May 12th
    18 Files
  • 13
    May 13th
    11 Files
  • 14
    May 14th
    27 Files
  • 15
    May 15th
    58 Files
  • 16
    May 16th
    54 Files
  • 17
    May 17th
    25 Files
  • 18
    May 18th
    53 Files
  • 19
    May 19th
    9 Files
  • 20
    May 20th
    15 Files
  • 21
    May 21st
    25 Files
  • 22
    May 22nd
    32 Files
  • 23
    May 23rd
    35 Files
  • 24
    May 24th
    26 Files
  • 25
    May 25th
    25 Files
  • 26
    May 26th
    0 Files
  • 27
    May 27th
    0 Files
  • 28
    May 28th
    0 Files
  • 29
    May 29th
    0 Files
  • 30
    May 30th
    0 Files
  • 31
    May 31st
    0 Files

Top Authors In Last 30 Days

File Tags

Systems

packet storm

© 2012 Packet Storm. All rights reserved.

close