Skip to content

Instantly share code, notes, and snippets.

@syusui-s
Last active June 10, 2023 16:52
Show Gist options
  • Save syusui-s/9a606fa0ce236cb3ec3ba34677ecccd0 to your computer and use it in GitHub Desktop.
Save syusui-s/9a606fa0ce236cb3ec3ba34677ecccd0 to your computer and use it in GitHub Desktop.
/**
* To the extent possible under law, the person who associated CC0
* with this work has waived all copyright and related or
* neighboring rights to this work.
*
* https://creativecommons.org/publicdomain/zero/1.0/
*/
import fs from 'fs/promises';
import path from 'path';
import util from 'util';
const rootDir = path.resolve();
const pattern = /nsec1[0-9a-zA-Z]+/;
const ignored = [/^node_modules$/, /^\./, /\.tsbuildinfo$/, /^public$/, /^dist$/];
const ignoreNextLine = /@check-secrets-disable-next-line/;
const shouldIgnore = (filename) => ignored.some((pattern) => pattern.test(filename));
const searchFiles = async (folderPath) => {
let didMatch = false;
const files = await fs.readdir(folderPath);
for (const file of files) {
const filePath = path.join(folderPath, file);
const stats = await fs.stat(filePath);
if (shouldIgnore(file)) continue;
if (stats.isDirectory()) {
const match = await searchFiles(filePath);
didMatch ||= match;
} else {
const match = await checkKeyword(filePath);
didMatch ||= match;
}
}
return didMatch;
};
const checkKeyword = async (filePath) => {
const content = await fs.readFile(filePath, 'utf8');
const lines = content.split('\n');
let prevLine = '';
let didMatch = false;
let didShowFilename = false;
for (let i = 0; i < lines.length; i++) {
const line = lines[i];
const match = line.match(pattern);
if (match != null && !ignoreNextLine.test(prevLine.trim())) {
if (!didShowFilename) {
console.error(filePath);
didShowFilename = true;
}
console.error(`${i + 1}: "${match[0]}": ${line}`);
didMatch = true;
}
prevLine = line;
}
return didMatch;
};
const main = async () => {
const result = await searchFiles(rootDir);
if (result) {
process.exit(1);
} else {
process.exit(0);
}
};
export default main;
{
"scripts": {
"checkSecrets": "node -e 'import(\"./checkSecrets.mjs\").then((m) => m.default())'"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment