July 24th, 2018
So many amazing tools have come out since the release of Sleepy Puppy that streamline the original goals of the project. We're currently leaving Sleepy Puppy code online but are not planning on adding any new features or addressing issues/pull requests. If you are interested in maintaining this project, please reach out to me (sbehrens@netflix.com).
-Scott
Sleepy Puppy is a cross-site scripting (XSS) payload management framework which simplifies the ability to capture, manage, and track XSS propagation over long periods of time.
Often when testing for client side injections (HTML/JS/etc.) security engineers are looking for where the injection occurs within the application they are testing only. While this provides ample coverage for the application in scope, there is a possibility that the code engineers are injecting may be reflected back in a completely separate application.
Sleepy Puppy helps facilitate inter-application XSS testing by providing JavaScript payloads that callback to the Sleepy Puppy application. This allows tracking when/where a payload fires even if the execution is triggered by a different user, occurs in a different application, or happens long after the initial test was performed.
These payloads and the "PuppyScripts" (which are often JavaScripts) that define them are completely customizable, allowing you to capture only the information you need depending on your environment.
Sleepy Puppy provides you with a number of payloads, PuppyScripts, and captures/collectors. Payloads are the actual XSS strings that are used to load Sleepy Puppy PuppyScripts. The PuppyScripts provide a way to collect the information on the client and application where the payload was executed. Captures and Collectors allow you to view the data you have returned from your PuppyScripts. Everything is configurable and you can create your own payloads and PuppyScripts as needed.
Testers can leverage the Sleepy Puppy Assessment model, to categorize payloads and subscribe to email notifications when delayed cross-site scripting events are triggered.
The default PuppyScript we use most often generates useful capture metadata including the url, DOM with payload highlighting, user-agent, cookies, referer header, and a screenshot of the application where the payload executed. This provides the tester ample knowledge to quickly identify what the application is so they may mitigate the vulnerability quickly. As payloads propagate throughout a network, the tester can trace what applications the payload executes in throughout the payload’s lifecycle.
Sleepy Puppy also supports email notifications for captures received for specific assessments.
Sleepy Puppy exposes an API for users who may want to develop plugins for scanners such as Burp or Zap.
Sleepy Puppy has a Docker composition which includes Nginx, PostGres, and Sleepy-Puppy. The Docker guide is the fastest way to try out Sleepy Puppy. The setup guide has examples on how to setup Sleepy Puppy for test as well as as more production setup using SSL and Nginx.
V0.3 "Netflix OSS Release" - 8/31/2015
- Support for custom JavaScripts and JavaScript chaining with new PuppyScripts model
- ACE JavaScript editor integration into PuppyScripts models
- Created new model for collecting arbitrary data from PuppyScripts (Generic Collector)
- Created new model for logging anytime a PuppyScript is requested but not necessarily executed (Access Log)
- Added "Snooze" and "Run Once" option for noisy Payloads
- Updated a large number of dependencies to latest releases
- Migrated from Bootstrap2 to Bootstrap3
- Numerous UI fixes/improvements
- Improved Default PuppyScript for collecting captures with better module loading
- Additional error logging has been integrated
- Better exception handling throughout the application
- New API endpoints for all new models (Javascript, Generic Collector, Access Log)
- New setup directive (setup_sleepy_puppy) creates example javascript, payloads, and an assessment.
V0.2 "OWASP Beta Release" - 7/9/2015 (/~https://github.com/sbehrens/sleepy-puppy)
- Updated a number of third party dependencies
- Bug fixes for jQuery and Email Notifications
- Amazon S3 storage configuration is now available for screenshots
- Amazon SES email support is now available
- Allowed domains config directive allows users to whitelist which domains to log captures for
- Callback configuration settings for hostname and protocol now supported
- PEP 8 changes (thanks @monkey_security)
- manage.py now supports a new command 'create_bootstrap_assessment' which adds a number of example payloads and an example assessment
- Added comprehensive Wiki documentation
V0.1 Alpha - 2/26/2014
- Initial release
Documentation is maintained in the Github Wiki