|
26 | 26 | """
|
27 | 27 | from __future__ import absolute_import
|
28 | 28 |
|
29 |
| -from .base import BasePlugin |
30 |
| -from detect_secrets.core.potential_secret import PotentialSecret |
| 29 | +import re |
31 | 30 |
|
| 31 | +from .base import RegexBasedDetector |
32 | 32 |
|
33 |
| -BLACKLIST = ( |
34 |
| - 'BEGIN RSA PRIVATE KEY', |
35 |
| - 'BEGIN DSA PRIVATE KEY', |
36 |
| - 'BEGIN EC PRIVATE KEY', |
37 |
| - 'BEGIN OPENSSH PRIVATE KEY', |
38 |
| - 'BEGIN PRIVATE KEY', |
39 |
| - 'PuTTY-User-Key-File-2', |
40 |
| - 'BEGIN SSH2 ENCRYPTED PRIVATE KEY', |
41 |
| -) |
42 | 33 |
|
43 |
| - |
44 |
| -class PrivateKeyDetector(BasePlugin): |
| 34 | +class PrivateKeyDetector(RegexBasedDetector): |
45 | 35 | """This checks for private keys by determining whether the blacklisted
|
46 | 36 | lines are present in the analyzed string.
|
47 | 37 | """
|
48 | 38 |
|
49 | 39 | secret_type = 'Private Key'
|
50 |
| - |
51 |
| - def analyze_string(self, string, line_num, filename): |
52 |
| - output = {} |
53 |
| - |
54 |
| - for identifier in self.secret_generator(string): |
55 |
| - secret = PotentialSecret( |
56 |
| - self.secret_type, |
57 |
| - filename, |
58 |
| - identifier, |
59 |
| - line_num, |
60 |
| - ) |
61 |
| - output[secret] = secret |
62 |
| - |
63 |
| - return output |
64 |
| - |
65 |
| - def secret_generator(self, string): |
66 |
| - for line in BLACKLIST: |
67 |
| - if line in string: |
68 |
| - yield line |
| 40 | + blacklist = [ |
| 41 | + re.compile(regexp) |
| 42 | + for regexp in ( |
| 43 | + r'BEGIN RSA PRIVATE KEY', |
| 44 | + r'BEGIN DSA PRIVATE KEY', |
| 45 | + r'BEGIN EC PRIVATE KEY', |
| 46 | + r'BEGIN OPENSSH PRIVATE KEY', |
| 47 | + r'BEGIN PRIVATE KEY', |
| 48 | + r'PuTTY-User-Key-File-2', |
| 49 | + r'BEGIN SSH2 ENCRYPTED PRIVATE KEY', |
| 50 | + ) |
| 51 | + ] |
0 commit comments