README.md
# StripJs
StripJs is an Elixir module for stripping executable JavaScript from
blocks of HTML and CSS.
It handles:
* `<script>...</script>` and `<script src="..."></script>` tags
* Event handler attributes such as `onclick="..."`
* `javascript:...` URLs in HTML and CSS
* CSS `expression(...)` directives
* HTML entity attacks (like `<script>`)
## Usage
`clean_html/2` removes all JS vectors from an HTML string:
iex> html = "<button onclick=\"alert('pwnt')\">Hi!</button>"
iex> StripJs.clean_html(html)
"<button>Hi!</button>"
`clean_css/2` removes all JS vectors from a CSS string:
iex> css = "body { background-image: url('javascript:alert()'); }"
iex> StripJs.clean_css(css)
"body { background-image: url('removed_by_strip_js:alert()'); }"
## [Documentation](https://hexdocs.pm/strip_js/StripJs.html)
[Full docs](https://hexdocs.pm/strip_js/StripJs.html) are available at
Hexdocs.pm.
## Authorship and License
Copyright 2017, Appcues, Inc.
StripJs is released under the
[MIT License](https://opensource.org/licenses/MIT).