Skip to content

Commit

Permalink
Merge pull request #74 from michalpirchala/master
Browse files Browse the repository at this point in the history
#69 Private key analyzer added.
  • Loading branch information
d-Rickyy-b committed Oct 3, 2019
2 parents 1d9b82e + a8746f1 commit 0555d02
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 1 deletion.
4 changes: 3 additions & 1 deletion pastepwn/analyzers/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
from .urlanalyzer import URLAnalyzer
from .wordanalyzer import WordAnalyzer
from .ibananalyzer import IBANAnalyzer
from .privatekeyanalyzer import PrivateKeyAnalyzer

__all__ = (
'AlwaysTrueAnalyzer',
Expand All @@ -26,5 +27,6 @@
'RegexAnalyzer',
'URLAnalyzer',
'WordAnalyzer',
'IBANAnalyzer'
'IBANAnalyzer',
'PrivateKeyAnalyzer'
)
11 changes: 11 additions & 0 deletions pastepwn/analyzers/privatekeyanalyzer.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# -*- coding: utf-8 -*-
from .regexanalyzer import RegexAnalyzer


class PrivateKeyAnalyzer(RegexAnalyzer):
"""Analyzer to match private keys beginnigs via regex"""
name = "PrivateKeyAnalyzer"

def __init__(self, actions):
regex = r"\-\-\-\-\-BEGIN( [A-Z]+)? PRIVATE KEY( BLOCK)?\-\-\-\-\-"
super().__init__(actions, regex)
38 changes: 38 additions & 0 deletions pastepwn/analyzers/tests/privatekeyanalyzer_test.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
# -*- coding: utf-8 -*-
import unittest
from unittest import mock

from pastepwn.analyzers.privatekeyanalyzer import PrivateKeyAnalyzer


class TestMailAnalyzer(unittest.TestCase):
def setUp(self):
self.analyzer = PrivateKeyAnalyzer(None)
self.paste = mock.Mock()

def test_match_positive(self):
"""Test if positives are recognized"""
self.paste.body = "-----BEGIN PRIVATE KEY-----"
self.assertTrue(self.analyzer.match(self.paste))
self.paste.body = "-----BEGIN PGP PRIVATE KEY BLOCK-----"
self.assertTrue(self.analyzer.match(self.paste))
self.paste.body = "-----BEGIN RSA PRIVATE KEY-----"
self.assertTrue(self.analyzer.match(self.paste))
self.paste.body = "-----BEGIN ENCRYPTED PRIVATE KEY-----"
self.assertTrue(self.analyzer.match(self.paste))
self.paste.body = "-----BEGIN OPENSSH PRIVATE KEY-----"
self.assertTrue(self.analyzer.match(self.paste))


def test_match_negative(self):
"""Test if negatives are not recognized"""
self.paste.body = ""
self.assertFalse(self.analyzer.match(self.paste))
self.paste.body = None
self.assertFalse(self.analyzer.match(self.paste))
self.paste.body = "-----BEGIN PUBLIC KEY-----"
self.assertFalse(self.analyzer.match(self.paste))


if __name__ == '__main__':
unittest.main()

0 comments on commit 0555d02

Please sign in to comment.