60
AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Embed Size (px)

Citation preview

Page 1: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

AppSec USA 2014

Denver, Colorado

CMS Hacking 101

Hacking and Securing Popular Open Source Content Management Systems

Page 2: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Greg Foss• Senior Security Research Engineer

• Web Developer => Penetration Tester => Researcher

Introduction

Page 3: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Content Management Systems

Page 4: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Image: http://www.emerce.nl/content/uploads/2012/10/Monkey-Barcode-Scanner-88205.jpg

Page 5: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Drupal - [domain.com] inurl:changelog.txt

Page 6: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Joomla - [domain.com] inurl:htaccess.txt

Page 7: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

WordPress - [domain.com] inurl:readme.html

Page 8: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Targeted Scanning - Joomla

http://sourceforge.net/projects/joomscan/

Page 9: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Targeted Scanning - WordPress

http://wpscan.org/

Page 10: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• https://code.google.com/p/cms-explorer/ # perl cms-explorer.pl --url http://some.cms.org/ --type [CMS] --osvdb

• http://blindelephant.sourceforge.net/ # python BlindElephant.py http://some.cms.org/ [CMS]

Intelligent Fingerprinting

Page 11: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Image: http://is1103.com/2013/10-October/source.png

Page 12: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

GitHub Advanced Queries

Page 13: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

http://blog.conviso.com.br/2013/06/github-hacking-for-fun-and-sensitive.html

Page 14: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Scrape Internal GitHub Deployment

Page 15: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Joomla – [docroot]/configuration.php

Page 16: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

WordPress – [docroot]/wp-config.php

Page 17: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• MySQL Creds

• Drupal Hash Salt

Drupal [docroot]/sites/default/settings.php

Page 18: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Remediation

Page 19: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Already have server access?• Drush available?• Create a one-time link to log in as an admin…

• $ cd [drupal directory]

• $ drush uli

Gaining Admin Access to Drupal…

Page 20: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems
Page 21: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Joomla – Password Reset Abuse

Page 22: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

WordPress – Password Reset Abuse

Page 23: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Drupal – Password Reset Abuse

Page 24: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Not seen as a vuln by the Drupal Security Team

• Iterate through accounts

• View comments, posts, etc.

• Social features, forums, etc.

Drupal User Enumeration

Page 25: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Automation

Page 26: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Image: http://security-is-just-an-illusion.blogspot.com/2013/11/wordlistpasword

list-for-dictionary.html

Page 27: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Drupal - Single Account…

Page 28: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

All the Accounts!

Page 29: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Brute Forcing w/ Burp works against WordPress too!

• Will not work against Joomla…– Joomla integrates a unique form token per login

request, which is actually verified at the server (unlike Drupal’s form token)

– Brute forcing can be scripted but will be slow…

Joomla & WordPress

Page 30: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• New Security Controls in Drupal 7…• Even better in Drupal 8!

Uh Oh…

Page 31: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Change it up!

Page 32: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Just Be Careful…

Page 33: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

‘Mitigation’

Page 34: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Configure Appropriately

Page 35: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Image: http://blog.codinghorror.com/content/images/uploads/2012/02/6a0120

a85dcdae970b016301e98de2970d-800wi.png

Session Handling

Page 36: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Missing Updates?

• Drupal

• WordPress

• Joomla

Page 38: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Watchdog – Drupal’s built in logging, captures data within the ‘Watchdog’ database table.

• Syslog – Export Drupal’s logs to the Linux syslog. Creates a flat file that is easy to monitor.

Drupal Application Logging

Page 39: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Nothing built in… Need to use a plugin which stores logs to a database tablehttps://wordpress.org/plugins/wp-security-audit-log/

WordPress Application Logging

Page 40: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Must be configured manually within Joomla’s configuration and is not enabled by default.

• Flat file logging can be set up using Jlog

• http://developer.joomla.org/manual/ch02s05s03.html

Joomla Application Logging

Page 41: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Authorization

Image: http://blog.codinghorror.com/content/images/uploads/2012/02/6a0120a85dcdae970b016301e98de2970d-800wi.png

Page 42: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Persistent XSS

Page 43: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Reflected XSS

Page 44: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Unrestricted File Uploads

Page 45: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems
Page 46: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Uploading and executing PHP code has been ‘fixed’ in recent versions of Drupal as of November 2013

• https://drupal.org/SA-CORE-2013-003 • Code execution prevention (Files

directory .htaccess for Apache - Drupal 6 and 7)

• Not exactly… <evil> :-) </evil>

Drupal File Upload Vuln Fixed?

Page 47: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Modules that assist with the active development of a Drupal application.

• Excellent for Development• Remove prior to Test / Staging– Never leave installed on Production applications

• Picking on…– Devel — https://drupal.org/project/devel

Development Modules

Page 48: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Module used for development• Should never be installed on production,

ever…• Allows users to view debugging information,

including full database details of application content.

• Also allows for PHP code execution!

Devel

Page 49: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Password Hash Disclosure

Page 50: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Automated Hash Extraction

Page 51: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems
Page 52: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• WordPress# hashcat -m 400 -a 0 -o wp.txt wphash.txt rock.dict

• Joomla# hashcat -m 11 -a 0 -o joomla.txt jhash.txt rock.dict

Cracking WordPress & Joomla Hashes

Page 53: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Drupal 7# john dhash.txt --wordlist=“rockyou.txt” --salt=“ ” --format=“drupal7”

• Drupal 6# john dhash.txt --wordlist=“rockyou.txt”

OR# hashcat –m 0 -a 0 -o drupal.txt dhash.txt rock.dict

Cracking Drupal Hashes

Page 54: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems
Page 55: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

PHP Code Execution

Page 56: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

I <3 Shells…

Page 57: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Demonstration

Image: http://fc01.deviantart.net/fs71/i/2014/040/2/3/_outdated__move_to_eqj__pony_avatar_creator_demo_by_lexuzieel-d4vx715.png

Page 58: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Pen Test your applications, don’t just scan…• Update early and often!• Leverage assistance from external entities• Embed security with development from the

beginning.• Download scripts to augment the penetration

testing process of Drupal applications:– https://github.com/gfoss/attacking-drupal/

Closing Thoughts

Page 59: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

• Target: XXX.XXX.XXX.XXX

Hands On Exercise Time!

Page 60: AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems

Questions?https://github.com/gfoss/attacking-drupal/ Greg Foss | OSCP, GPEN, GWAPT, GCIH, CEH

Senior Security Research Engineergreg.foss[at]LogRhythm.com

@heinzarelli

Thank You!