Note: You are currently viewing documentation for Moodle 3.4. Up-to-date documentation for the latest stable version of Moodle is likely available here: Hacked site recovery.

Hacked site recovery: Difference between revisions

From MoodleDocs
m (added link to spanish translation of page)
 
(4 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Security}}
==Initial steps==
==Initial steps==


* Contact your hosting provider, if you have one.
* Contact your hosting provider, if you have one.
* Immediately put the site into ''Maintenance mode'' or better completely off-line until you know you've fixed everything.
* Immediately put the site into ''Maintenance mode'' or better completely off-line until you know you've fixed everything. You need to cut-off the connection the attacker has to your server.
* Find all available older database and file backups
** You can make a firewall rule to block connections to the server from all ip addresses and then allow only your ip address. Be careful when doing this since your ip address might change from time to time and you can lock yourself out. If that's the case, allow the range that your IP address is in instead.
** If your site is self-hosted or you have physical access to the server, an easier way is to get a small router and plug the server into that. Do not connect it to the rest of the network or the internet. You are now free to access it directly or via another computer on the same router.
* Find all available older databases and file backups
* Backup php files, database and data files (Do not overwrite older backups.)
* Backup php files, database and data files (Do not overwrite older backups.)
* Make a list of all PHP software installed on the same server.
* Make a list of all PHP software and programs/packages installed on the same server.
* Note main Moodle version and the date of last update
* Note main Moodle version and the date of last update and make a list of all contrib modules and custom modifications
* Make a list of all contrib modules and custom modifications
* Check the legal ramifications of possibly exposing users' private data. You are probably required by law to notify your users and at least tell them to change passwords on any accounts with any service that shared the same password with their Moodle account.
* Finally, if you are unfamiliar with the command line or with computers/servers in general, it's best to get someone who is familiar to help you. You are responsible for your users' information that you store, so you want to make sure the recovery is done right.
 
 
Remember, everything on the system should be considered untrusted until you know to what extent the hacker was able to intrude (Does he have root server permissions or just access to modify certain files?) Do some forensic research into how the person (or program) got in and what they did before just restoring a backup or running anti-virus software. For all you know, the backup could have been modified to contain a backdoor program that allows the attacker back in later. You want to close the vulnerability the attacker used so it doesn't happen again.


==Damage assessment==
==Damage assessment==


* Find out when exactly was the site hacked.
* Find out when exactly was the site hacked.
** Check the modification dates on files. You're looking for any application files that were modified around the time of the initial intrusion. These files are suspect.
** Check your server logs for any suspicious activity around that date or few hours before, such as strange page parameters, failed login attempts, command history (especially as root), unknown user accounts, etc.
** Be sure to take into account updates you've downloaded, as that will change the times for modified system files and/or Moodle.
* Look for any modified or uploaded files on your web server - look for oldest file that does not belong in Moodle.
* Look for any modified or uploaded files on your web server - look for oldest file that does not belong in Moodle.
* Check your server logs for any suspicious activity around that date or few hours before, such as strange page parameters, failed login attempts, command history (especially as root), unknown user accounts, etc.


==Recovery==
==Recovery==
Line 19: Line 28:
* [http://download.moodle.org/ Download the latest stable version] and [[Upgrade|upgrade]] your site.
* [http://download.moodle.org/ Download the latest stable version] and [[Upgrade|upgrade]] your site.
* Change your passwords.
* Change your passwords.
* Depending on the extent of the attack, a complete format and reinstall of the operating system might be in order.
* Be sure to implement any fixes you found during your investigation and double-check existing security on the server to see if it can't be improved.
** This also means you should review any customizations/add-ons you made for Moodle. Are you sure you properly escaped all user inputs? What about the permissions on your web server directories and database?


==Dealing with spam==
==Dealing with spam==
* Spam in profiles or forum posts does not mean your site was actually hacked.
* Spam in profiles or forum posts does not mean your site was actually hacked.
* Use the [[Spam cleaner]] tool (''Administration > Reports > Spam cleaner'') regularly to find spam (Moodle 1.8.9 and 1.9.5 onwards).
* Use the [[Spam cleaner]] tool (''Settings > Site administration > Reports > Spam cleaner'') regularly to find spam.


==Prevention==
==Prevention==


* ''Always keep your site up-to-date and use the [http://download.moodle.org/ latest stable version].'' It is very safe to go from 1.9.3 to 1.9.4+ weekly build, for example, at any time. [[CVS for Administrators|CVS]] is an easy way to do this.
* ''Always keep your site up-to-date and use the [http://download.moodle.org/ latest stable version].'' [[Git for Administrators|Git]] is an easy way to do this.
* Regularly run the [[Security overview]] report (''Administration > Reports > Security overview'') (Moodle 1.8.9 and 1.9.4 onwards).
* Regularly run the [[Security overview]] report (''Settings > Site administration > Reports > Security overview'').
* Understand how to properly set permissions and file ownership to maximise security. If this is a mystery, you mustn't ignore it - read about it or ask in the forums!
* Make sure you have a properly configured firewall/packet filter on your server.
* When making customizations to Moodle or other web applications on your server, be sure to review your code and make sure it doesn't add any new vulnerabilities.
* You might also consider running a anti-rootkit program such as rkhunter that will help you see if rootkits or other strange happenings are occurring on your server. RootkitRevealer is a comparable Windows program.
* SELinux or AppArmor are very good at mitigating several forms of attacks on the server itself. Windows has something similar called EMET.


== See also ==
== See also ==
Line 33: Line 50:
* [[Security FAQ]]
* [[Security FAQ]]
* [[Reducing spam in Moodle]]
* [[Reducing spam in Moodle]]
== External Links ==
* [http://rkhunter.sourceforge.net/]: rkhunter official site
* [http://technet.microsoft.com/en-us/sysinternals/bb795534]: Windows Sysinternals site, where you will find RootkitRevealer among other useful programs.
* [https://secure.wikimedia.org/wikipedia/en/wiki/SELinux]: SELinux wikipedia article. Check the References and See Also section.
* [http://technet.microsoft.com/es-mx/library/cc512587%28en-us%29.aspx]: A great article on Microsoft Technet detailing some very important security concepts. A good read no matter what OS you use.
* [http://technet.microsoft.com/en-us/library/cc512595.aspx]: Part 2 of the Microsoft Technet article above.
* [http://serverfault.com/questions/218005/my-servers-been-hacked-emergency]: A thread from ServerFault which has yet more good information on recovery from an intrusion. Robert Moir's comment provide lots of good information.
* [http://www.cert.org/tech_tips/win-UNIX-system_compromise.html]: An article on cert.org which details the steps one should take after a server compromise. It was written in 2000, so program specific information may be out-dated.


Using Moodle forum discussions:
Using Moodle forum discussions:
Line 43: Line 70:
* [http://moodle.org/mod/forum/discuss.php?d=124063 Trojan:JS Type Obfuscation Exploits]
* [http://moodle.org/mod/forum/discuss.php?d=124063 Trojan:JS Type Obfuscation Exploits]


[[Category:Security]]
[[de:Wiederherstellung einer komprimittierten Moodle-Installation]]
[[de:Wiederherstellung einer komprimittierten Moodle-Installation]]
[[es:Recuperación de un sitio hackeado]]

Latest revision as of 15:23, 26 February 2013

Initial steps

  • Contact your hosting provider, if you have one.
  • Immediately put the site into Maintenance mode or better completely off-line until you know you've fixed everything. You need to cut-off the connection the attacker has to your server.
    • You can make a firewall rule to block connections to the server from all ip addresses and then allow only your ip address. Be careful when doing this since your ip address might change from time to time and you can lock yourself out. If that's the case, allow the range that your IP address is in instead.
    • If your site is self-hosted or you have physical access to the server, an easier way is to get a small router and plug the server into that. Do not connect it to the rest of the network or the internet. You are now free to access it directly or via another computer on the same router.
  • Find all available older databases and file backups
  • Backup php files, database and data files (Do not overwrite older backups.)
  • Make a list of all PHP software and programs/packages installed on the same server.
  • Note main Moodle version and the date of last update and make a list of all contrib modules and custom modifications
  • Check the legal ramifications of possibly exposing users' private data. You are probably required by law to notify your users and at least tell them to change passwords on any accounts with any service that shared the same password with their Moodle account.
  • Finally, if you are unfamiliar with the command line or with computers/servers in general, it's best to get someone who is familiar to help you. You are responsible for your users' information that you store, so you want to make sure the recovery is done right.


Remember, everything on the system should be considered untrusted until you know to what extent the hacker was able to intrude (Does he have root server permissions or just access to modify certain files?) Do some forensic research into how the person (or program) got in and what they did before just restoring a backup or running anti-virus software. For all you know, the backup could have been modified to contain a backdoor program that allows the attacker back in later. You want to close the vulnerability the attacker used so it doesn't happen again.

Damage assessment

  • Find out when exactly was the site hacked.
    • Check the modification dates on files. You're looking for any application files that were modified around the time of the initial intrusion. These files are suspect.
    • Check your server logs for any suspicious activity around that date or few hours before, such as strange page parameters, failed login attempts, command history (especially as root), unknown user accounts, etc.
    • Be sure to take into account updates you've downloaded, as that will change the times for modified system files and/or Moodle.
  • Look for any modified or uploaded files on your web server - look for oldest file that does not belong in Moodle.

Recovery

  • Restore last backup right before the incident.
  • Download the latest stable version and upgrade your site.
  • Change your passwords.
  • Depending on the extent of the attack, a complete format and reinstall of the operating system might be in order.
  • Be sure to implement any fixes you found during your investigation and double-check existing security on the server to see if it can't be improved.
    • This also means you should review any customizations/add-ons you made for Moodle. Are you sure you properly escaped all user inputs? What about the permissions on your web server directories and database?

Dealing with spam

  • Spam in profiles or forum posts does not mean your site was actually hacked.
  • Use the Spam cleaner tool (Settings > Site administration > Reports > Spam cleaner) regularly to find spam.

Prevention

  • Always keep your site up-to-date and use the latest stable version. Git is an easy way to do this.
  • Regularly run the Security overview report (Settings > Site administration > Reports > Security overview).
  • Understand how to properly set permissions and file ownership to maximise security. If this is a mystery, you mustn't ignore it - read about it or ask in the forums!
  • Make sure you have a properly configured firewall/packet filter on your server.
  • When making customizations to Moodle or other web applications on your server, be sure to review your code and make sure it doesn't add any new vulnerabilities.
  • You might also consider running a anti-rootkit program such as rkhunter that will help you see if rootkits or other strange happenings are occurring on your server. RootkitRevealer is a comparable Windows program.
  • SELinux or AppArmor are very good at mitigating several forms of attacks on the server itself. Windows has something similar called EMET.

See also

External Links

  • [1]: rkhunter official site
  • [2]: Windows Sysinternals site, where you will find RootkitRevealer among other useful programs.
  • [3]: SELinux wikipedia article. Check the References and See Also section.
  • [4]: A great article on Microsoft Technet detailing some very important security concepts. A good read no matter what OS you use.
  • [5]: Part 2 of the Microsoft Technet article above.
  • [6]: A thread from ServerFault which has yet more good information on recovery from an intrusion. Robert Moir's comment provide lots of good information.
  • [7]: An article on cert.org which details the steps one should take after a server compromise. It was written in 2000, so program specific information may be out-dated.

Using Moodle forum discussions: