wget git.io/mwscan.txt
grep -Erlf mwscan.txt /var/www
For faster scanning and more features, you can install the scanner from this repository.
# Install prerequisites on Debian/Ubuntu flavoured server
sudo apt install -qy python-pip gcc python-dev
sudo pip install --no-cache-dir --upgrade mwscan
# If you don't have EPEL yet, for CentOS 6:
wget https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
sudo rpm -ivh epel-release-latest-6.noarch.rpm
sudo yum -y install python-pip python-devel gcc
sudo pip install --no-cache-dir --upgrade mwscan
# Install prerequisites on a Mac OSX environemnt
brew install yara python
sudo pip install --no-cache-dir --upgrade mwscan
If you have installed through pip, you can now run this and any hits will appear
mwscan /Users/frosit/Werk/Security/mage17
# this will for example show:
eval_post /Users/frosit/Werk/Security/mage17/media/dhl/info.php
obfuscated_eval /Users/frosit/Werk/Security/mage17/skin/backdoor1.php
It is recommended to run nightly from cron. This will download the latest rules every night, run a scan on your Magento store and mail you if anything was found.
cat <<'EOM' | sudo tee /etc/cron.d/mwscan
MAILTO=youremail@etc
RULESURL=https://raw.githubusercontent.com/gwillem/magento-malware-scanner/master/build/all-confirmed.yar
RULEFILE=/var/cache/rules.yar
MAGENTO=/var/www/magento
MWSCAN=/usr/bin/mwscan
10 2 * * * root /usr/bin/curl -s $RULESURL -o $RULEFILE && $MWSCAN --quiet --newonly --rules $RULEFILE $MAGENTO
EOM
This cron will ensure only a single concurrent scan, will log timestamped new finds to /var/log/mwscan.log and mail them to the supplied address. Requires util-linux
, moreutils
and mailutils
on Ubuntu/Debian for flock
, ifne
, ts
, and mail
.
MAILTO=your@address
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
0 2 * * * root flock -n ~/.mwscan.lock mwscan --newonly --quiet /data/web | ts | tee -a /var/log/mwscan.log | ifne mail -s "Malware found at $(hostname)" -a 'From: Malware Scanner <[email protected]>' $MAILTO
You can run an external scan by using wget
to download a page and then running the result through magento-malware-scanner
.
For example, to process a page with all page requisites.
d=`date +%y%m%d%H%M%S` wget -p -q -H -P scan-$d https://www.example.com/ && grep -Erlf mwscan.txt scan-%d
When you receive the error pkg_resources.DistributionNotFound: requests
try to upgrade the request
package as follows:
easy_install --upgrade requests
When you receive the error ImportError: No module named argparse
, try to run the following:
easy_install argparse