6739615 2001-07-12 12:41 +0400 /110 rader/ 3APA3A <3APA3A@SECURITY.NNOV.RU> Sänt av: joel@lysator.liu.se Importerad: 2001-07-12 21:16 av Brevbäraren Extern mottagare: bugtraq@securityfocus.com Externa svar till: 3APA3A@SECURITY.NNOV.RU Mottagare: Bugtraq (import) <17938> Ärende: SECURITY.NNOV: directory traversal and path globing in multiple archivers ------------------------------------------------------------ Hello, Topic: Directory traversal and path globing in multiple archivers Author: 3APA3A <3APA3A@security.nnov.ru> Affected Software: GNU tar <= 1.13.19, Info-Zip UnZip <= 5.42, RARSoft rar <= 2.02, PKWare pkzipc <= 4.00 Not affected: rar 2.80, WinZIP 8.0 Risk: average Released: July, 2, 2001 SECURITY.NNOV advisories: http://www.security.nnov.ru/advisories Background: Archive extraction is usually treated by users as a safe operation. There are few problems with files extraction though. Problem(s): Among them: huge files with high compression ratio are able to fill memory/disk (see "Antivirus scanner DoS with zip archives" thread on Vuln-Dev), special device names and special characters in file names, directory traversal (dot-dot bug). Probably, directory traversal is most dangerous among this bugs, because it allows to craft archive which will trojan system on extraction. This problem is known for software developers, and newer archivers usually have some kind of protection. But in some cases this protection is weak and can be bypassed. I did very quick (approx. 30 minutes, so may be I've missed something) researches on few popular archivers. Results are below. Detailed info: GNU tar (all platforms): tar below 1.13.19 including latest releases has no any ".." or absolute path protection. Tar development team was contacted. They replied they're aware of problem and current development version 1.13.19 implements some kind of protection but it doesn't work for most cases due to bug in coding. Exploitation scenario was passed back to development team. I hope it will work then 1.13.19 will be finally released. See attached patch (tar-1.13.19.patch). 1.13.19 sources can be obtained from ftp://alpha.gnu.org/gnu/tar/ Info-Zip's UnZip (all platforms): all versions have neither .. nor absolute path protection. No reply from vendor. See attached patch (unzip-5.42.patch). PKWare's PKZip (Windows): console version was tested. It's vulnerable, if archive is extracted with -rec (recursive) option. If this option is not given archive is extracted without directory structure. All versions up to latest 4.00 are vulnerable. Program is shareware, no sources available. Vendor contacted but status of patch unknown. RARsoft (Eugene Roshal's) RAR (all platforms): Directory traversal protection was implemented in rar 2.02. This protection can be bypassed. Eugene Roshal was contacted and replied latest version of rar (2.80) is absolutely safe. It's true, but 2.02 is latest available version in most Unix ports (2.80 is available for Windows and Linux, you can use Linux version if your system supports Linux emulation). Program is shareware, no sources available. WinZip (Windows): Behavior is close to ideal. Console version doesn't extract files with ".." until special switch is not selected, windowed version warns user on ".." about possible impacts of such extraction. Exploitation: Exploitation of path globing and directory traversal under Windows exploitation is trivial. On most unix system to exploit directory traversal you should guess level of directory file will be extracted to. tar and rar are able to create files with permission different from umask, it makes it possible to create executables. Only tar overwrites target files without prompt by default. Demo archives can be found on http://www.security.nnov.ru/advisories/archdt.asp Workaround: List content of archive before extraction if archive was obtained from untrusted source (but have in mind that name of the file can be with something like ../^H^H^H - do not trust your eyes, use some program). Never automate archive extraction, or use jail if you need automation. Be sure never run extraction from user with elevated privileges. Solution: Wait for vendor patch or use checked archivers or apply attached patches on your own risk. -- http://www.security.nnov.ru /\_/\ { . . } |\ +--oQQo->{ ^ }<-----+ \ | 3APA3A U 3APA3A } +-------------o66o--+ / |/ You know my name - look up my number (The Beatles) (6739615) /3APA3A <3APA3A@SECURITY.NNOV.RU>/-------- Bilaga (application/octet-stream) i text 6739616 Bilaga (application/octet-stream) i text 6739617 6739616 2001-07-12 12:41 +0400 /41 rader/ 3APA3A <3APA3A@SECURITY.NNOV.RU> Bilagans filnamn: "tar-1.13.19.patch" Importerad: 2001-07-12 21:16 av Brevbäraren Extern mottagare: bugtraq@securityfocus.com Externa svar till: 3APA3A@SECURITY.NNOV.RU Mottagare: Bugtraq (import) <17939> Bilaga (text/plain) till text 6739615 Ärende: Bilaga (tar-1.13.19.patch) till: SECURITY.NNOV: directory traversal and path globing in multiple archivers ------------------------------------------------------------ *** misc.c.orig Sat Jan 13 08:59:29 2001 --- misc.c Mon Jul 9 15:45:09 2001 *************** *** 201,217 **** { char const *p = name + FILESYSTEM_PREFIX_LEN (name); for (;;) { ! if (p[0] == '.' && p[1] == '.' && (ISSLASH (p[2]) || !p[2])) return 1; do { ! if (! *p++) return 0; } ! while (! ISSLASH (*p)); } } --- 201,218 ---- { char const *p = name + FILESYSTEM_PREFIX_LEN (name); + if(ISSLASH (*p) ) return 1; for (;;) { ! if (p[0] == '.' && p[1] == '.' && (!p[2] || ISSLASH (p[2]))) return 1; do { ! if (! *p) return 0; } ! while (! ISSLASH (*p++)); } } (6739616) /3APA3A <3APA3A@SECURITY.NNOV.RU>/-------- 6739617 2001-07-12 12:41 +0400 /32 rader/ 3APA3A <3APA3A@SECURITY.NNOV.RU> Bilagans filnamn: "unzip-5.42.patch" Importerad: 2001-07-12 21:16 av Brevbäraren Extern mottagare: bugtraq@securityfocus.com Externa svar till: 3APA3A@SECURITY.NNOV.RU Mottagare: Bugtraq (import) <17940> Bilaga (text/plain) till text 6739615 Ärende: Bilaga (unzip-5.42.patch) till: SECURITY.NNOV: directory traversal and path globing in multiple archivers ------------------------------------------------------------ *** extract.orig Sun Jan 14 00:40:20 2001 --- extract.c Mon Jul 9 14:45:42 2001 *************** *** 154,159 **** --- 154,161 ---- #ifndef WINDLL static ZCONST char Far ReplaceQuery[] = "replace %s? [y]es, [n]o, [A]ll, [N]one, [r]ename: "; + static ZCONST char Far TraversalWarning[] = + "%s skipped because of directory traversal\n"; static ZCONST char Far AssumeNone[] = " NULL\n(assuming [N]one)\n"; static ZCONST char Far NewNameQuery[] = "new name: "; static ZCONST char Far InvalidResponse[] = "error: invalid response [%c]\n"; *************** *** 877,882 **** --- 879,893 ---- } /* end switch (*answerbuf) */ #endif /* ?WINDLL */ } /* end if (query) */ + if(*__G__ G.filename=='/' || !strncmp(__G__ G.filename, "../", 3) + || strstr(__G__ G.filename,"/../")){ + skip_entry = SKIP_Y_EXISTING; + #ifndef WINDLL + Info(slide, 0x81, ((char *)slide, + LoadFarString(TraversalWarning), + FnFilter1(G.filename))); + #endif + } if (skip_entry != SKIP_NO) { #ifdef WINDLL if (skip_entry == SKIP_Y_EXISTING) { (6739617) /3APA3A <3APA3A@SECURITY.NNOV.RU>/(Ombruten)