hashcat

0.4.1 • Public • Published

hashcat Build Status

A commandline utility to concatenate, minify and cache-bust your Javascript and CSS references in HTML.

It works by parsing the HTML file for special markup. It then concatenates, minifies, hashes and replaces references to those files. It is ideal for use with a build tool as part of your CI pipeline.

Install

npm install hashcat

Usage

Prepare your references by surrounding them with special comment blocks.

<!-- #cat app-min.js -->
<script src="1.js" />
<script type="text/javascript" src="other-folder/3.js"></script>
<!-- endcat -->

 <!-- #cat min.css -->
 <link rel="stylesheet" type="text/css" href="first.css"/>
 <link rel="stylesheet" href="second.css" />
 <!-- endcat -->

Pass the HTML file to hashcat

$(npm bin)/hashcat app/index.html

After processing, the above reference should be replaced with something like this:

<link rel="stylesheet" href="ec784ace.min.css" />
<script src="d41d8cd9.app-min.js"></script>

You can have hashcat output to another file as well

$(npm bin)/hashcat app/index.html app/outputFile.html

How

Hashcat parses the HTML files, looks for the #cat blocks and gathers the files up. The Javascript/CSS files are concatenated and minified into a single file. A hash of the resulting file's contents is then taken and the first 8 characters are prepended to the file's name. Finally, the reference blocks in the HTML are replaced with this new file.

The concatenation and minification allow for multiple files during development but a smaller, simpler asset in production.

The hash rename provides cache busting by changing the file name on each deployment if the contents have changed.

About

This tool is similar to the grunt-usemin task.

In our case, using grunt as part of a CI pipeline meant having to run npm install hundreds of times a day which was not desirable. This standalone tool solves this specific problem by reducing the external dependencies and does not leave the build agent in a transient state.

Local development

You can work with this repo directly.

Use the VSCode task included

npm:tryMe

Or invoke the node script directly,

node bin/hashcat.js example/tryMe.html

And watch for the changes that occur in tryMe.html as well as the new files that appear.

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 0.4.1
    20
    • latest

Version History

Package Sidebar

Install

npm i hashcat

Weekly Downloads

43

Version

0.4.1

License

MIT

Unpacked Size

19.7 kB

Total Files

9

Last publish

Collaborators

  • mendhak