6.3 Medium
AI Score
Confidence
Low
10 High
CVSS2
Access Vector
NETWORK
Access Complexity
LOW
Authentication
NONE
Confidentiality Impact
COMPLETE
Integrity Impact
COMPLETE
Availability Impact
COMPLETE
AV:N/AC:L/Au:N/C:C/I:C/A:C
0.97 High
EPSS
Percentile
99.7%
This host is missing a critical security update according to
Microsoft Bulletin MS09-037.
# Copyright (C) 2009 Greenbone Networks GmbH
# Some text descriptions might be excerpted from (a) referenced
# source(s), and are Copyright (C) by the respective right holder(s).
#
# SPDX-License-Identifier: GPL-2.0-or-later
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
if(description)
{
script_oid("1.3.6.1.4.1.25623.1.0.101100");
script_version("2022-05-25T07:40:23+0000");
script_tag(name:"last_modification", value:"2022-05-25 07:40:23 +0000 (Wed, 25 May 2022)");
script_tag(name:"creation_date", value:"2009-08-14 07:53:52 +0200 (Fri, 14 Aug 2009)");
script_tag(name:"cvss_base", value:"10.0");
script_tag(name:"cvss_base_vector", value:"AV:N/AC:L/Au:N/C:C/I:C/A:C");
script_cve_id("CVE-2008-0015", "CVE-2008-0020", "CVE-2009-0901",
"CVE-2009-2493", "CVE-2009-2494");
script_name("Vulnerabilities in Microsoft ATL Could Allow Remote Code Execution (973908)");
script_xref(name:"URL", value:"http://secunia.com/advisories/36187");
script_xref(name:"URL", value:"http://www.securityfocus.com/bid/35558");
script_xref(name:"URL", value:"http://www.securityfocus.com/bid/35585");
script_xref(name:"URL", value:"http://www.securityfocus.com/bid/35828");
script_xref(name:"URL", value:"http://www.securityfocus.com/bid/35832");
script_xref(name:"URL", value:"http://www.securityfocus.com/bid/35982");
script_xref(name:"URL", value:"http://support.microsoft.com/kb/973908");
script_xref(name:"URL", value:"http://www.vupen.com/english/advisories/2009/2232");
script_xref(name:"URL", value:"https://docs.microsoft.com/en-us/security-updates/securitybulletins/2009/ms09-037");
script_category(ACT_GATHER_INFO);
script_copyright("Copyright (C) 2009 Greenbone Networks GmbH");
script_family("Windows : Microsoft Bulletins");
script_dependencies("smb_reg_service_pack.nasl");
script_require_ports(139, 445);
script_mandatory_keys("SMB/WindowsVersion");
script_tag(name:"impact", value:"Successful exploitation could allow remote attacker execute arbitrary code on
the vulnerable system.");
script_tag(name:"affected", value:"- Microsoft Windows Media Player 9/10/11
- Microsoft Outlook Express 6 Service Pack 1
- Microsoft Outlook Express 5.5 Service Pack 2
- Microsoft Windows 2K Service Pack 4 and prior
- Microsoft Windows XP Service Pack 3 and prior
- Microsoft Windows 2003 Service Pack 2 and prior
- Microsoft Windows Vista Service Pack 1/2 and prior
- Microsoft Windows Server 2008 Service Pack 1/2 and prior");
script_tag(name:"insight", value:"Multiple flaws exist due to:
- Bug in the ATL header that could allow reading a variant from a stream and
leaving the variant type read with an invalid variant. When deleting the
variant, it is possible to free unintended areas in memory that could be
controlled by an attacker.
- Error in 'CComVariant::ReadFromStream()' function used in the ATL header.
This function does not properly restrict untrusted data read from a stream.
- An bug in the ATL headers that could allow an attacker to force VariantClear
to be called on a VARIANT that has not been correctly initialized.
- Bugs in the ATL headers that handle instantiation of an object from data
streams.");
script_tag(name:"solution", value:"The vendor has released updates. Please see the references for more information.");
script_tag(name:"summary", value:"This host is missing a critical security update according to
Microsoft Bulletin MS09-037.");
script_tag(name:"qod_type", value:"executable_version");
script_tag(name:"solution_type", value:"VendorFix");
exit(0);
}
include("smb_nt.inc");
include("secpod_reg.inc");
include("version_func.inc");
include("secpod_smb_func.inc");
if(hotfix_check_sp(win2k:5, xp:4, win2003:3, winVista:3, win2008:3) <= 0){
exit(0);
}
sysPath = smb_get_systemroot();
if(sysPath)
{
# For Windows ATL Component
sysVer = fetch_file_version(sysPath:sysPath, file_name:"system32\atl.dll");
if(sysVer != NULL)
{
if(hotfix_check_sp(win2k:5) > 0)
{
if(version_is_less(version:sysVer, test_version:"3.0.9794.0"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if(hotfix_check_sp(xp:4) > 0)
{
SP = get_kb_item("SMB/WinXP/ServicePack");
if(("Service Pack 2" >< SP) || ("Service Pack 3" >< SP))
{
if(version_is_less(version:sysVer, test_version:"3.5.2284.2"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
if(hotfix_check_sp(win2003:3) > 0)
{
SP = get_kb_item("SMB/Win2003/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_is_less(version:sysVer, test_version:"3.5.2284.2"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
if(hotfix_check_sp(winVista:3, win2008:3) > 0)
{
if(version_is_less(version:sysVer, test_version:"3.5.2284.2"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
mpVer = fetch_file_version(sysPath:sysPath, file_name:"system32\wmp.dll");
if(mpVer != NULL)
{
if(hotfix_check_sp(win2k:5) > 0)
{
if(version_is_less(version:mpVer, test_version:"9.0.0.3364"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if(hotfix_check_sp(xp:4) > 0)
{
SP = get_kb_item("SMB/WinXP/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_in_range(version:mpVer, test_version:"9.0", test_version2:"9.0.0.3363")||
version_in_range(version:mpVer, test_version:"10.0", test_version2:"10.0.0.4073")||
version_in_range(version:mpVer, test_version:"11.0", test_version2:"11.0.5721.5267"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if("Service Pack 3" >< SP)
{
if(version_in_range(version:mpVer, test_version:"9.0", test_version2:"9.0.0.4506")||
version_in_range(version:mpVer, test_version:"10.0", test_version2:"10.0.0.4073")||
version_in_range(version:mpVer, test_version:"11.0", test_version2:"11.0.5721.5267"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
if(hotfix_check_sp(win2003:3) > 0)
{
SP = get_kb_item("SMB/Win2003/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_in_range(version:mpVer, test_version:"10.0", test_version2:"10.0.0.4005"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
}
if(hotfix_check_sp(winVista:3, win2008:3) > 0)
{
if(version_in_range(version:mpVer, test_version:"11.0", test_version2:"11.0.6000.6351") ||
version_in_range(version:mpVer, test_version:"11.0.6000.6500", test_version2:"11.0.6000.6510"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
SP = get_kb_item("SMB/WinVista/ServicePack");
if(!SP) {
SP = get_kb_item("SMB/Win2008/ServicePack");
}
if("Service Pack 1" >< SP)
{
if(version_in_range(version:mpVer, test_version:"11.0.6001.7000", test_version2:"11.0.6001.7006") ||
version_in_range(version:mpVer, test_version:"11.0.6001.7100", test_version2:"11.0.6001.7113"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if("Service Pack 2" >< SP)
{
if(version_in_range(version:mpVer, test_version:"11.0.6002.18000", test_version2:"11.0.6002.18064") ||
version_in_range(version:mpVer, test_version:"11.0.6002.22000", test_version2:"11.0.6002.22171"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
# For Microsoft MSWebDVD ActiveX Control
msVer = fetch_file_version(sysPath:sysPath, file_name:"system32\Mswebdvd.dll");
if(msVer)
{
if(hotfix_check_sp(xp:4) > 0)
{
SP = get_kb_item("SMB/WinXP/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_is_less(version:msVer, test_version:"6.5.2600.3610"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if("Service Pack 3" >< SP)
{
if(version_is_less(version:msVer, test_version:"6.5.2600.5857"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
if(hotfix_check_sp(win2003:3) > 0)
{
SP = get_kb_item("SMB/Win2003/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_is_less(version:msVer, test_version:"6.5.3790.4565"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
}
# For Microsoft HtmlInput Object ActiveX Control
webVer = fetch_file_version(sysPath:sysPath, file_name:"ehome\Ehkeyctl.dll");
if(webVer)
{
if(hotfix_check_sp(winVista:3) > 0)
{
SP = get_kb_item("SMB/WinVista/ServicePack");
if(!SP) {
SP = get_kb_item("SMB/Win2008/ServicePack");
}
if("Service Pack 1" >< SP)
{
if(version_in_range(version:webVer, test_version:"6.0.6001.18000", test_version2:"6.0.6001.18294")||
version_in_range(version:webVer, test_version:"6.0.6001.22000", test_version2:"6.0.6001.22475"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if("Service Pack 2" >< SP)
{
if(version_in_range(version:webVer, test_version:"6.0.6002.18000", test_version2:"6.0.6002.18071") ||
version_in_range(version:webVer, test_version:"6.0.6002.22000", test_version2:"6.0.6002.22180"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
}
}
# Microsoft Outlook Express 5.5 Service Pack 2 or 6 Service Pack 1
sysPath = registry_get_sz(key:"SOFTWARE\Microsoft\Windows\CurrentVersion",
item:"ProgramFilesDir");
if(sysPath != NULL)
{
dllVer = fetch_file_version(sysPath:sysPath, file_name:"Outlook Express\msoe.dll");
if(dllVer != NULL)
{
if(hotfix_check_sp(win2k:5) > 0)
{
if(version_in_range(version:dllVer, test_version:"5.5", test_version2:"5.50.5003.999")||
version_in_range(version:dllVer, test_version:"6.0", test_version2:"6.0.2800.1982"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if(hotfix_check_sp(xp:4) > 0)
{
SP = get_kb_item("SMB/WinXP/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_in_range(version:dllVer, test_version:"6.0", test_version2:"6.0.2900.3597"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if("Service Pack 3" >< SP)
{
if(version_in_range(version:dllVer, test_version:"6.0", test_version2:"6.0.2900.5842"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
if(hotfix_check_sp(win2003:3) > 0)
{
SP = get_kb_item("SMB/Win2003/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_in_range(version:dllVer, test_version:"6.0", test_version2:"6.0.3790.4547"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
}
}
# For DHTML Editing Component ActiveX Control
sysPath = registry_get_sz(key:"SOFTWARE\Microsoft\Windows\CurrentVersion",
item:"ProgramFilesDir");
if(sysPath != NULL)
{
ocxVer = fetch_file_version(sysPath:sysPath, file_name:"Common Files\Microsoft Shared\Triedit\Dhtmled.ocx");
if(ocxVer != NULL)
{
if(hotfix_check_sp(win2k:5) > 0)
{
if(version_is_less(version:ocxVer, test_version:"6.1.0.9234"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
if(hotfix_check_sp(xp:4) > 0)
{
SP = get_kb_item("SMB/WinXP/ServicePack");
if(("Service Pack 2" >< SP) || ("Service Pack 3" >< SP))
{
if(version_is_less(version:ocxVer, test_version:"6.1.0.9247"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
if(hotfix_check_sp(win2003:3) > 0)
{
SP = get_kb_item("SMB/Win2003/ServicePack");
if("Service Pack 2" >< SP)
{
if(version_is_less(version:ocxVer, test_version:"6.1.0.9247"))
{
security_message( port: 0, data: "The target host was found to be vulnerable" );
exit(0);
}
}
}
}
}
secunia.com/advisories/36187
support.microsoft.com/kb/973908
www.securityfocus.com/bid/35558
www.securityfocus.com/bid/35585
www.securityfocus.com/bid/35828
www.securityfocus.com/bid/35832
www.securityfocus.com/bid/35982
www.vupen.com/english/advisories/2009/2232
docs.microsoft.com/en-us/security-updates/securitybulletins/2009/ms09-037