From owner-doc-jp@jp.FreeBSD.org Fri Dec 21 08:55:30 2001
Received: (from daemon@localhost)
	by castle.jp.FreeBSD.org (8.11.6+3.4W/8.11.3) id fBKNtUH39747;
	Fri, 21 Dec 2001 08:55:30 +0900 (JST)
	(envelope-from owner-doc-jp@jp.FreeBSD.org)
Received: from eos.ocn.ne.jp (eos.ocn.ne.jp [210.190.142.171])
	by castle.jp.FreeBSD.org (8.11.6+3.4W/8.11.3) with ESMTP/inet id fBKNtTH39742
	for <doc-jp@jp.FreeBSD.org>; Fri, 21 Dec 2001 08:55:30 +0900 (JST)
	(envelope-from hrs@eos.ocn.ne.jp)
Received: from mail.hrslab.yi.org (p5126-ip02funabasi.chiba.ocn.ne.jp [61.214.4.126])
	by eos.ocn.ne.jp (OCN) with ESMTP id IAA10046
	for <doc-jp@jp.FreeBSD.org>; Fri, 21 Dec 2001 08:55:27 +0900 (JST)
Received: from localhost (alph.hrslab.yi.org [192.168.0.10])
	by mail.hrslab.yi.org (8.9.3/3.7W/DomainMaster) with ESMTP id IAA53660
	for <doc-jp@jp.FreeBSD.org>; Fri, 21 Dec 2001 08:54:18 +0900 (JST)
	(envelope-from hrs@eos.ocn.ne.jp)
Date: Fri, 21 Dec 2001 08:53:35 +0900 (JST)
Message-Id: <20011221.085335.74752194.hrs@eos.ocn.ne.jp>
To: doc-jp@jp.FreeBSD.org
From: Hiroki Sato <hrs@eos.ocn.ne.jp>
In-Reply-To: <200112171819.fBHIJEw62768@freefall.freebsd.org>
References: <200112171819.fBHIJEw62768@freefall.freebsd.org>
X-Mailer: Mew version 2.0 on Emacs 20.7 / Mule 4.0 (HANANOEN)
Mime-Version: 1.0
Content-Type: Multipart/Mixed;
 boundary="--Next_Part(Fri_Dec_21_08:53:35_2001_364)--"
Content-Transfer-Encoding: 7bit
Reply-To: doc-jp@jp.FreeBSD.org
Precedence: list
X-Distribute: distribute version 2.1 (Alpha) patchlevel 24e+011218
X-Sequence: doc-jp 8577
Subject: [doc-jp 8577] Re: ANNOUNCE: FreeBSD Ports Security Advisory
 FreeBSD-SA-01:67.htdig
Errors-To: owner-doc-jp@jp.FreeBSD.org
Sender: owner-doc-jp@jp.FreeBSD.org
X-Originator: hrs@eos.ocn.ne.jp

----Next_Part(Fri_Dec_21_08:53:35_2001_364)--
Content-Type: Text/Plain; charset=iso-2022-jp
Content-Transfer-Encoding: 7bit

$B:4F#!wEl5~M}2JBg3X$G$9!#(B

 01:67 $B$G$9!#(B

--
| $B:4F#(B $B9-@8!wEl5~M}2JBg3X(B <hrs@eos.ocn.ne.jp>
|                         <hrs@FreeBSD.org> (FreeBSD Project)

----Next_Part(Fri_Dec_21_08:53:35_2001_364)--
Content-Type: Text/Plain; charset=iso-2022-jp
Content-Disposition: inline; filename="01:67"
Content-Transfer-Encoding: 7bit


FreeBSD $B%;%-%e%j%F%#4+9p(B $BF|K\8lHG(B
=============================================================================
FreeBSD-SA-01:67 (2001-12-17)
 * htdig configuration file vulnerability
=============================================================================

 $B$3$N%a!<%k$O(B, announce-jp $B$KN.$l$?(B

  Subject: ANNOUNCE: FreeBSD Ports Security Advisory FreeBSD-SA-01:67.htdig
  From: FreeBSD Security Advisories <security-advisories@FreeBSD.org>
  Date: Mon, 17 Dec 2001 10:19:14 -0800 (PST)
  Message-Id: <200112171819.fBHIJEw62768@freefall.freebsd.org>
  X-Sequence: announce-jp 872

 $B$rF|K\8lLu$7$?$b$N$G$9(B. 

 $B86J8$O(B PGP $B=pL>$5$l$F$$$^$9$,(B, $B$3$NF|K\8lLu$O(B PGP $B=pL>$5$l$F$$$^$;$s(B. 
 $B=$@5%Q%C%AEy$NFbMF$,2~$6$s$5$l$F$$$J$$$3$H$r3NG'$9$k$?$a$K(B PGP $B=pL>$N(B
 $B%A%'%C%/$r9T$J$&$K$O(B, $B86J8$r;2>H$7$F$/$@$5$$(B. 

 $BF|K\8lLu$*$h$S(B, $B%_%i!<%5%$%HMxMQ$N>\:Y$K$D$$$F$O(B, $BJ8Kv$N!V(BA. FreeBSD
 $B%;%-%e%j%F%#4+9p(B $BF|K\8lHG$K$D$$$F!W$r$4Mw$/$@$5$$(B.


                                     [$BK]Lu<T(B: $B:4F#(B $B9-@8(B <hrs@jp.FreeBSD.org>]
--($B$3$3$+$i(B)

=============================================================================
FreeBSD-SA-01:67                                            Security Advisory
                                                                FreeBSD, Inc.

$B%H%T%C%/(B:	htdig configuration file vulnerability
                htdig $B$N@_Dj%U%!%$%k$K$*$1$k%;%-%e%j%F%#>e$N<eE@(B

$BJ,N`(B:		ports
$B%b%8%e!<%k(B:	htdig
$B9pCNF|(B:		2001-12-17
$B%/%l%8%C%H(B:	Rafal Wojtczuk <nergal@7bulls.com>
$B1F6AHO0O(B:	$B=$@5F|0JA0$N(B Ports Collection
$B=$@5F|(B:		2001-09-25 07:08:47 2001 UTC
FreeBSD $B$K8GM-$+(B:	NO


I.   $BGX7J(B - Background

htsearch is a part of htdig. The htdig system is a complete World Wide
Web indexing and searching system.

htdig $B$O(B WWW $B$N:w0z:n@.$H8!:w$r9T$J$&E}9g%7%9%F%`$N0l$D$G$"$j(B,
$B$3$l$K4^$^$l$F$$$k%W%m%0%i%`$K(B htsearch $B$H$$$&$b$N$,$"$j$^$9(B.


II.  $BLdBj$N>\:Y(B - Problem Description

htsearch can be run either remotely as a CGI or from the command line.
htsearch supports several options for use from the command line, such
as an option specifying a configuration file that it should use.
However, these options are not limited to use via the command line.
When run as a CGI script, htsearch still honors these options, which
may be passed as part of the URL.  As a result, a remote attacker can
request that htsearch use any file that the webserver has sufficient
privilege to read as a configuration file.

htsearch $B$O(B CGI $B7PM3$G%j%b!<%H$+$i(B, $B$b$7$/$O%3%^%s%I%i%$%s$+$i(B
$B<B9T$9$k$3$H$,$G$-$^$9(B.  htsearch $B$K$O@_Dj%U%!%$%k$r;XDj$9$k$?$a$N(B
$B%*%W%7%g%s$J$I(B, $B$$$/$D$+$N%3%^%s%I%i%$%s%*%W%7%g%s$,$"$k$N$G$9$,(B,
$B$3$l$i$N%*%W%7%g%s$O%3%^%s%I%i%$%s7PM3$G$J$/$H$bMxMQ$G$-$k$h$&$K(B
$B$J$C$F$$$^$9(B.  $B$D$^$j(B htsearch $B$O(B CGI $B%9%/%j%W%H$H$7$F<B9T$5$l$?(B
$B>l9g$K$b(B, URL $B$N0lIt$H$7$FEO$5$l$k%*%W%7%g%s$r<u$1$H$j$^$9(B.
$B$=$N$?$a%j%b!<%H$N967b<T$O(B, $B%&%'%V%5!<%P$+$iFI$_9~$`$3$H$N$G$-$k(B
$BG$0U$N%U%!%$%k$r(B, htsearch $B$N@_Dj%U%!%$%k$H$7$F;HMQ$9$k$3$H$,2DG=$G$9(B.

The htsearch port is not installed by default, nor is it "part of
FreeBSD" as such: it is part of the FreeBSD ports collection, which
contains over 6000 third-party applications in a ready-to-install
format. The ports collection shipped with FreeBSD 4.4 contains this
problem since it was discovered after the release.

FreeBSD makes no claim about the security of these third-party
applications, although an effort is underway to provide a security
audit of the most security-critical ports.

htdig $B$N(B port $B$O%G%U%)%k%H$G%$%s%9%H!<%k$5$l$k$b$N$G$O$J$/(B,
$B!V(BFreeBSD $B%7%9%F%`$N0lIt!W$r9=@.$9$k$b$N$G$b$"$j$^$;$s(B.
$B$=$l$i$O(B 6000 $B$r1[$($k%5!<%I%Q!<%F%#@=%"%W%j%1!<%7%g%s$,$9$0$K(B
$B%$%s%9%H!<%k$G$-$k7A$G<}$a$i$l$F$$$k(B FreeBSD Ports Collection $B$N0lIt$G$9(B.
$B$3$NLdBj$O(B FreeBSD 4.4 $B$N%j%j!<%98e$KH/8+!&=$@5$5$l$?$?$a(B,
FreeBSD 4.4 $B$K$O$3$NLdBj$K$h$k%;%-%e%j%F%#>e$N<eE@$,4^$^$l$F$$$^$9(B.

FreeBSD $B$G$O(B, $B$3$N$h$&$J%5!<%I%Q!<%F%#@=%"%W%j%1!<%7%g%s$N%;%-%e%j%F%#(B
$BLdBj$KBP$7$F(B, $BFC$K2?$+$r<gD%$9$k$3$H$O$"$j$^$;$s(B ($BLuCm(B: Ports Collection $B$K(B
$BF~$C$F$$$k$+$i$H$$$C$F(B, FreeBSD $B$N3+H/<T$?$A$,$=$N%"%W%j%1!<%7%g%s$,(B
$B0BA4$G$"$k$HI>2A$7$?$o$1$G$O$"$j$^$;$s(B).  $B$?$@$7(B, $B%;%-%e%j%F%#LdBj$KBP$7$F(B
$BBg$-$J1F6A$r;}$D$h$&$J(B ports $B$KBP$9$k%;%-%e%j%F%#4F::$rDs6!$9$Y$/(B,
$B8=:_EXNOCf$G$9(B.

III. $B1F6AHO0O(B - Impact

A remote attacker may use htsearch as a kind of denial-of-service
attack by causing it to read a never-ending special file such as
`/dev/null'.

$B%j%b!<%H$N967b<T$O(B htsearch $B$KBP$7(B, $B@_Dj%U%!%$%k$H$7$F(B
`/dev/null' $B$N$h$&$J=*C<$N$J$$FC<l$J%U%!%$%k$rFI$_9~$^$;$k$3$H$G(B,
$B0l<o$N%5!<%S%9K832967b(B (denial-of-service attack) $B$r<B8=$G$-$k(B
$B2DG=@-$,$"$j$^$9(B.

More seriously, if the attacker has a local account or can otherwise
create a file on the target system (such as via anonymous FTP upload
or Samba), then he can remotely read any file on the target system for
which the webserver has sufficient privilege.

$B967b<T$,%m!<%+%k%"%+%&%s%H$r;}$C$F$$$k(B, $B$b$7$/$O967bBP>]$N%7%9%F%`$K(B
(anonymous FTP $B$K$h$k%"%C%W%m!<%I$d(B Samba $B7PM3$G(B) $B%U%!%$%k$r(B
$B:n@.$G$-$k$h$&$J%1!<%9$G$O(B, $B;vBV$O$5$i$K?<9o$G$9(B.  $B967b<T$O$=$N>l9g(B,
$B%&%'%V%5!<%P$+$iFI$`$3$H$,$G$-$k(B, $B967bBP>]%7%9%F%`>e$N$9$Y$F$N%U%!%$%k$r(B
$B%j%b!<%H$+$iFI$`$3$H$,$G$-$k$3$H$K$J$j$^$9(B.


IV.  $B2sHrJ}K!(B - Workaround

1) Deinstall the htdig port/package if you have it installed.
1) htdig $B$N(B port/package $B$,%$%s%9%H!<%k$5$l$F$$$k>l9g$O(B,
   $B$=$l$r%7%9%F%`$+$i:o=|$7$^$9(B.


V.   $B2r7h:v(B - Solution

1) Upgrade your entire ports collection and rebuild the htdig port.
1) Ports Collection $BA4BN$r%"%C%W%0%l!<%I$7(B htdig $B$N(B port $B$r:F9=C[$9$k(B.

2) Deinstall the old package and install a new package dated after the
correction date, obtained from the following directories:
2) $B8E$$(B ($BLuCm(B: htdig $B$N(B) package $B$r%7%9%F%`$+$i:o=|$7(B,
   $B=$@5F|0J9_$K:n@.$5$l$??7$7$$(B package $B$r0J2<$N>l=j$+$i(B
   $B<hF@$7$F%$%s%9%H!<%k$9$k(B.

[i386]
ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/i386/packages-4-stable/textproc/htdig-3.1.5_1.tgz
ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/i386/packages-5-current/textproc/htdig-3.1.5_1.tgz

[alpha]
Packages are not automatically generated for the alpha architecture at
this time due to lack of build resources.
$B8=;~E@$G$O(B alpha $B%"!<%-%F%/%A%cMQ$N(B package $B$O<+F0@8@.$5$l$F$$$^$;$s(B.
$B$3$l$O(B, $B9=C[$N$?$a$N%^%7%s%j%=!<%9$,ITB-$7$F$$$k$?$a$G$9(B.

3) Download a new port skeleton for the htdig port from:
3) htdig $B$N?7$7$$(B port $B%9%1%k%H%s$r0J2<$N>l=j$+$i%@%&%s%m!<%I$7(B,
   $B$=$l$r;H$C$F(B port $B$r:F9=C[$9$k(B.

http://www.freebsd.org/ports/

and use it to rebuild the port.

4) Use the portcheckout utility to automate option (3) above. The
portcheckout port is available in /usr/ports/devel/portcheckout or the
package can be obtained from:
4) $B>e5-(B (3) $B$NA`:n$r<+F0E*$K9T$J$&(B portcheckout $B%f!<%F%#%j%F%#$r;H$&(B.
   portcheckout $B$N(B port $B$O(B /usr/ports/devel/portcheckout $B$K$"$j$^$9(B.
   $B$^$?(B, portcheckout $B$N(B package $B$,0J2<$N>l=j$+$iF~<j2DG=$G$9(B.

ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/i386/packages-4-stable/devel/portcheckout-2.0.tgz
ftp://ftp.FreeBSD.org/pub/FreeBSD/ports/i386/packages-5-current/devel/portcheckout-2.0.tgz


VI.  $B=$@5$N>\:Y(B - Correction details

The following list contains the revision numbers of each file that was
corrected in the FreeBSD ports collection.

$B<!$NI=$O(B, FreeBSD Ports Collection $B$K4^$^$l$F$$$k(B,
$B=$@5$5$l$?%U%!%$%k$=$l$>$l$N%j%S%8%g%sHV9f$G$9(B.

Path                                                             Revision
$B%Q%9L>(B                                                       $B%j%S%8%g%sHV9f(B
- -------------------------------------------------------------------------
ports/textproc/htdig/Makefile                                        1.20
ports/textproc/htdig/file/patch-htsearch_cc                           1.1
- -------------------------------------------------------------------------


VII. $B;29M;qNA(B - References

<URL:http://sourceforge.net/tracker/?func=detail&atid=104593&aid=458013&group_id=4593>
<URL:http://www.geocrawler.com/archives/3/8822/2001/9/100/6685429/>


A.   FreeBSD $B%;%-%e%j%F%#4+9p(B $BF|K\8lHG$K$D$$$F(B

$BF|K\8lLu$O(B FreeBSD $BF|K\8l%I%-%e%a%s%F!<%7%g%s%W%m%8%'%/%H(B (doc-jp) $B$,(B
$B;29M$N$?$a$KDs6!$9$k$b$N$G$9(B.  $B2a5n$NF|K\8lHG%;%-%e%j%F%#4+9p$O(B

 http://www.FreeBSD.org/ja/security/

$B$K$^$H$a$i$l$F$$$^$9(B.  

$B$?$@$7(B, $BK]Lu<T$*$h$S(B doc-jp $B$O(B, $B$=$NFbMF$K$D$$$F$$$+$J$kJ]>Z$b(B
$B$$$?$7$^$;$s$N$G$4Cm0U$/$@$5$$(B.  $BF|K\8lLu$K$D$$$F$N$40U8+(B, $B$4MWK>(B,
$B$*Ld$$9g$o$;Ey$O(B doc-jp@jp.FreeBSD.org $B$^$G$*4j$$$7$^$9(B.

$B$3$N4+9p$NCf$G>R2p$5$l$F$$$k(B WWW $B%5%$%H(B http://www.FreeBSD.org/ $B$*$h$S(B
FTP $B%5%$%H(B ftp://ftp.FreeBSD.org/ $B$K$O(B, $BF|K\$N%_%i!<%5%$%H$,B8:_$7$^$9(B.
$B%M%C%H%o!<%/$N:.;($r4KOB$9$k$?$a(B, $B$^$:$O%_%i!<%5%$%H$NMxMQ$r(B
$B9MN8$9$k$h$&$*4j$$$7$^$9(B.

$BF|K\$N%_%i!<%5%$%H$rMxMQ$9$k$K$O(B,
http://www.FreeBSD.org/ $B$r(B http://www.jp.FreeBSD.org/www.freebsd.org/ $B$K(B,
ftp://ftp.FreeBSD.org/ $B$r(B ftp://ftp.jp.FreeBSD.org/ $B$K(B,
$B$=$l$>$lCV$-49$($F$/$@$5$$(B.

$BB>$NCO0h$r4^$`(B, $B%_%i!<%5%$%H$K4X$9$k>\:Y$O(B,

 http://www.FreeBSD.org/handbook/mirror.html ($B1QJ8(B)
 http://www.FreeBSD.org/ja/handbook/mirror.html ($BF|K\8lLu(B)

$B$K$^$H$a$i$l$F$$$^$9(B.

$hrs: announce-jp/FreeBSD-SA/01:67,v 1.1 2001/12/20 23:53:00 hrs Exp $

----Next_Part(Fri_Dec_21_08:53:35_2001_364)----
