Testing Joomla for CVE-2015-8562

Over the last couple of days I've been responding to question about Joomla's 0-day which has been gaining some attention lately. I decided to write a PowerShell script to check a Joomla server if it is running the at least 3.4.6 or 3.4.7. Hope you enjoy it and let me know your thoughts.

###############################################################################################
#
# Script: CheckJoomla.ps1
# By: Tim Muniz
# Date: 20151222
#
###############################################################################################
<#

.SYNOPSIS

This script checks Joomla Version to check if the remote host is vulnerable to CVE-2015-8562.



.DESCRIPTION

This script checks Joomla Version to check if the remote host is vulnerable to CVE-2015-8562.


.PARAMETER target

a host running Joomla to test.



.PARAMETER Https

To test a host running SSL/TLS. 

This is an optional parameter.



.EXAMPLE

Check remote Joomla Host and report if vulnerable.

CheckJoomla.ps1 myjoomla.com 



.EXAMPLE 

Check remote Joomla Host running SSL/TLS and report if vulnerable.

CheckJoomla.ps1 myjoomla.com -Https



.NOTES

Please let me know what you think or if it isn't working. Also, it relies on access to /language/en-GB/en-GB.xml

#>
[CmdletBinding()]
Param(
  
  
    [Parameter(Mandatory=$True,Position=1)]
    [string] $target,
    
    [Switch]$Https = $false    

)
    
if ($Https){
    write-host "Checking host: $target"
    $site = Invoke-WebRequest -Uri https://$target/joomla/language/en-GB/en-GB.xml -UseBasicParsing
$xml = [xml]$site.Content
$version = $xml.metafile.version[1]
    if($version -notlike "3.4.[6-7]"){
        write-host "Your Instance of Joomla is VULNERABLE!"
        write-host "Please Upgrade to 3.4.6."
        write-host "Joomla host is running version " $version
    }
    else { 
        write-host "You are running the updated version of Joomla"
        write-host "Joomla host is running version " $version
    }
}
else {
    write-host "Checking host: $target"
    $site = Invoke-WebRequest -UseBasicParsing -Uri http://$target/joomla/language/en-GB/en-GB.xml
$xml = [xml]$site.Content
$version = $xml.metafile.version[1]
    if($version -notlike "3.4.[6-7]"){
        write-host "Your Instance of Joomla is VULNERABLE!"
        write-host "Please Upgrade to 3.4.6."
        write-host "Joomla host is running version " $version
    }
    else { 
        write-host "You are running the updated version of Joomla"
        write-host "Joomla host is running version " $version
    }
}

Comments

Popular posts from this blog

And now for something completely different...

Been awhile hasn't it.

Well I guess it's time to start this back up.