-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
59 lines (45 loc) · 1.58 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
const core = require('@actions/core');
const github = require('@actions/github');
const simpleGit = require('simple-git');
const git = simpleGit();
// Helper function to fetch commits and check files for secrets
async function checkCommitsForSecrets(commitHash,previousCommitHash, patterns) {
const diff = await git.diff([commitHash, previousCommitHash]);
const regexPatterns = patterns.split(',').map(p => new RegExp(p, 'i'));
let foundSecrets = [];
regexPatterns.forEach(pattern => {
if (diff && pattern.test(diff)) {
foundSecrets.push(pattern.toString());
}
});
return foundSecrets;
}
async function run() {
try {
const repo = core.getInput('repo');
const token = core.getInput('token');
const branch = core.getInput('branch');
const patterns = core.getInput('patterns');
const [owner, repoName] = repo.split('/');
const octokit = github.getOctokit(token);
// Fetch the latest commit from the repository
const commits = await octokit.rest.repos.listCommits({
owner,
repo: repoName,
sha: branch,
per_page: 2,
});
const latestCommitHash = commits.data[0].sha;
const previousCommitHash = commits.data[1].sha;
// Check for secrets in the latest commit
const secretsFound = await checkCommitsForSecrets(latestCommitHash, previousCommitHash, patterns);
if (secretsFound.length > 0) {
core.setFailed(`Found secrets: ${secretsFound.join(', ')}`);
} else {
core.info('No secrets found in the latest commit!');
}
} catch (error) {
core.setFailed(error.message);
}
}
run();