marked/test/vuln-regex.js
Ben McCann 4afb228d95
fix: Convert to ESM (#2227)
BREAKING CHANGE:

- Default export removed. Use `import { marked } from 'marked'` or `const { marked } = require('marked')` instead.
- `/lib/marked.js` removed. Use `/marked.min.js` in script tag instead.
- When using marked in a script tag use `marked.parse(...)` instead of `marked(...)`
2021-11-02 09:32:17 -05:00

43 lines
1.1 KiB
JavaScript
Vendored

import regexp from '../src/rules.js';
import { test, responses } from 'vuln-regex-detector';
const promises = [];
function findRegexps(name, obj) {
if (typeof obj === 'string') {
promises.push(testRegexp(name, obj));
} if (obj instanceof RegExp || obj.exec) {
if (obj.source) {
promises.push(testRegexp(name, obj.source));
}
} else if (typeof obj === 'object') {
for (const prop in obj) {
findRegexps(name + (name ? '.' : '') + prop, obj[prop]);
}
}
}
async function testRegexp(name, source) {
try {
const result = await test(source);
if (result === responses.safe) {
console.log(`${name} is safe`);
return true;
} else if (result === responses.vulnerable) {
console.error(`${name} is vulnerable`);
} else {
console.error(`${name} might be vulnerable: ` + result.toString());
}
} catch (ex) {
console.error(`${name} failed with error: ` + ex.toString());
}
return false;
}
findRegexps('', regexp);
// promises.push(testRegexp('a', /(a+)+$/.source));
Promise.allSettled(promises).then(results => {
const code = results.every(r => r.value) ? 0 : 1;
process.exit(code);
});