Move the long option name enum from cl.h into main.c, because it is
[svn.git] / www / svn-sscanf-advisory.txt
blobcad900938d12ef104efaa3708612b4920c51cad2
1 Subversion versions up to and including 1.0.2 have a buffer overflow in
2 the date parsing code.
4 Both client and server are vulnerable.  The server is vulnerable over
5 both httpd/DAV and svnserve (that is, over http://, https://, svn://,
6 svn+ssh:// and other tunneled svn+*:// methods).
8 Additionally, clients with shared working copies, or permissions that
9 allow files in the administrative area of the working copy to be
10 written by other users, are potentially exploitable.
12 Severity:
13 =========
15 Severity ranges from "Denial of Service" to, potentially, "Arbitrary
16 Code Execution", depending upon how skilled the attacker is and the
17 ABI specifics of your platform.
19 The server vulnerabilities can be triggered without write/commit access
20 to the repository.  So repositories with anonymous/public read access
21 are vulnerable.
23 Workarounds:
24 ============
26 There are no workarounds except to disallow public access.  Even then
27 you'd still be vulnerable to attack by someone who still has access
28 (perhaps you trust those people, though).
30 Recommendations:
31 ================
33 We recommend all users upgrade to 1.0.3.
35 References:
36 ===========
38 CAN-2004-0397: subversion sscanf stack overflow via revision date
39                in REPORT query
41 Note:
42 =====
44 There was a similar vulnerability in the Neon HTTP library up to and including
45 version 0.24.5.  Because Subversion ships with Neon, we have included (in
46 Subversion 1.0.3) Neon 0.24.6, which is being released simultaneously.
47 Subversion does not actually invoke the vulnerable code in Neon; we are
48 updating our copy of Neon simply as a reassuring gesture, so people don't
49 worry.  See CAN-2004-0398 for details.