+ All Categories
Home > Documents > AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content...

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

Date post: 03-Jan-2016
Category:
Upload: samuel-atkins
View: 219 times
Download: 2 times
Share this document with a friend
60
AppSec USA 2014 Denver, Colorado CMS Hacking 101 Hacking and Securing Popular Open Source Content Management Systems
Transcript
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!


Recommended