You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
1.4 KiB
64 lines
1.4 KiB
# safe-regex2
|
|
|
|
[![Build Status](https://travis-ci.com/fastify/safe-regex.svg?branch=master)](https://travis-ci.com/fastify/safe-regex)
|
|
|
|
detect potentially
|
|
[catastrophic](http://regular-expressions.mobi/catastrophic.html)
|
|
[exponential-time](http://perlgeek.de/blog-en/perl-tips/in-search-of-an-exponetial-regexp.html)
|
|
regular expressions by limiting the
|
|
[star height](https://en.wikipedia.org/wiki/Star_height) to 1
|
|
|
|
This is a fork of https://github.com/substack/safe-regex at 1.1.0.
|
|
|
|
WARNING: This module has both false positives and false negatives.
|
|
It is not meant as a full checker, but it detect basic cases.
|
|
|
|
# example
|
|
|
|
``` js
|
|
var safe = require('safe-regex2');
|
|
var regex = process.argv.slice(2).join(' ');
|
|
console.log(safe(regex));
|
|
```
|
|
|
|
```
|
|
$ node safe.js '(x+x+)+y'
|
|
false
|
|
$ node safe.js '(beep|boop)*'
|
|
true
|
|
$ node safe.js '(a+){10}'
|
|
false
|
|
$ node safe.js '\blocation\s*:[^:\n]+\b(Oakland|San Francisco)\b'
|
|
true
|
|
```
|
|
|
|
# methods
|
|
|
|
``` js
|
|
var safe = require('safe-regex')
|
|
```
|
|
|
|
## var ok = safe(re, opts={})
|
|
|
|
Return a boolean `ok` whether or not the regex `re` is safe and not possibly
|
|
catastrophic.
|
|
|
|
`re` can be a `RegExp` object or just a string.
|
|
|
|
If the `re` is a string and is an invalid regex, returns `false`.
|
|
|
|
* `opts.limit` - maximum number of allowed repetitions in the entire regex.
|
|
Default: `25`.
|
|
|
|
# install
|
|
|
|
With [npm](https://npmjs.org) do:
|
|
|
|
```
|
|
npm install safe-regex2
|
|
```
|
|
|
|
# license
|
|
|
|
MIT
|