| # scmp | 
| [![travis][travis-image]][travis-url] | 
| [![npm][npm-image]][npm-url] | 
| [![downloads][downloads-image]][downloads-url] | 
|   | 
| [travis-image]: https://travis-ci.org/freewil/scmp.svg?branch=master | 
| [travis-url]: https://travis-ci.org/freewil/scmp | 
|   | 
| [npm-image]: https://img.shields.io/npm/v/scmp.svg?style=flat | 
| [npm-url]: https://npmjs.org/package/scmp | 
|   | 
| [downloads-image]: https://img.shields.io/npm/dm/scmp.svg?style=flat | 
| [downloads-url]: https://npmjs.org/package/scmp | 
|   | 
| Safe, constant-time comparison of Buffers. | 
|   | 
| ## Changes in v2.x | 
| Since scmp 2.x, Buffers are now required to be passed as arguments. In 1.x, | 
| the arguments were assumed to be strings, and were always run through `String()`. | 
|   | 
| Also, there is a new `crypto.timingSafeEqual()` since Node v6.6.0. If this function | 
| is available, then that will be used, otherwise a scmp-internal implementation | 
| will be used. | 
|   | 
| ## Install | 
|   | 
| ``` | 
| npm install scmp | 
| ``` | 
|   | 
| ## Why? | 
|   | 
| To minimize vulnerability against [timing attacks](http://codahale.com/a-lesson-in-timing-attacks/). | 
|   | 
| ## Example | 
|   | 
| ```js | 
| const scmp = require('scmp'); | 
| const Buffer = require('safe-buffer').Buffer; | 
|   | 
| const hash      = Buffer.from('e727d1464ae12436e899a726da5b2f11d8381b26', 'hex'); | 
| const givenHash = Buffer.from('e727e1b80e448a213b392049888111e1779a52db', 'hex'); | 
|   | 
| if (scmp(hash, givenHash)) { | 
|   console.log('good hash'); | 
| } else { | 
|   console.log('bad hash'); | 
| } | 
|   | 
| ``` |