From 74a663bdea8d7ffc07f581e7575b673e24800d5c Mon Sep 17 00:00:00 2001 From: naisanzaa Date: Mon, 2 Sep 2024 16:03:45 -0700 Subject: [PATCH] keepass_to_pass: add integration --- README.md | 2 +- .../integrations/keepass_to_pass/__init__.py | 4 +++ .../integrations/keepass_to_pass/client.py | 33 +++++++++++++++++++ .../keepass_to_pass/tests/__init__.py | 0 .../keepass_to_pass/tests/test_keepass.py | 23 +++++++++++++ 5 files changed, 61 insertions(+), 1 deletion(-) create mode 100644 automon/integrations/keepass_to_pass/__init__.py create mode 100644 automon/integrations/keepass_to_pass/client.py create mode 100644 automon/integrations/keepass_to_pass/tests/__init__.py create mode 100644 automon/integrations/keepass_to_pass/tests/test_keepass.py diff --git a/README.md b/README.md index 48e7bd73..eb437dde 100644 --- a/README.md +++ b/README.md @@ -41,7 +41,7 @@ Github issues and feature requests welcomed. | API | flask | | Chat | slack | | Data Scraping | beautifulsoup
facebook groups
instagram
scrapy | -| Databases | elasticsearch
neo4j
splunk | +| Databases | elasticsearch
neo4j
splunk
pass | | Data Store | minio
swift | | Devices | snmp | | Google Cloud | google auth api
google people api
google sheets api | diff --git a/automon/integrations/keepass_to_pass/__init__.py b/automon/integrations/keepass_to_pass/__init__.py new file mode 100644 index 00000000..373397f0 --- /dev/null +++ b/automon/integrations/keepass_to_pass/__init__.py @@ -0,0 +1,4 @@ +from .client import ( + KeepassClient, + PassClient +) diff --git a/automon/integrations/keepass_to_pass/client.py b/automon/integrations/keepass_to_pass/client.py new file mode 100644 index 00000000..ad466aef --- /dev/null +++ b/automon/integrations/keepass_to_pass/client.py @@ -0,0 +1,33 @@ +import os + +from automon import log + +logger = log.logging.getLogger(__name__) +logger.setLevel(level=log.DEBUG) + + +class KeepassClient(object): + + def __init__(self): + self.database_csv_path = None + + def set_database_csv_path(self, database_csv_path: str) -> bool: + if os.path.exists(database_csv_path): + self.database_csv_path = database_csv_path + logger.debug( + f'KeepassClient :: set_database_csv_path :: {database_csv_path} :: {os.stat(database_csv_path)}') + return True + + raise FileNotFoundError(f'KeepassClient :: set_database_csv_path :: ERROR :: {database_csv_path}') + + def read_database_csv(self, database_csv_path: str) -> open: + if self.set_database_csv_path(database_csv_path=database_csv_path): + logger.debug(f'KeepassClient :: read_database_csv :: open') + return open(self.database_csv_path, 'r').read() + + raise OSError(f'KeepassClient :: read_database_csv :: ERROR :: {database_csv_path}') + + + +class PassClient(object): + pass diff --git a/automon/integrations/keepass_to_pass/tests/__init__.py b/automon/integrations/keepass_to_pass/tests/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/automon/integrations/keepass_to_pass/tests/test_keepass.py b/automon/integrations/keepass_to_pass/tests/test_keepass.py new file mode 100644 index 00000000..fb10cb91 --- /dev/null +++ b/automon/integrations/keepass_to_pass/tests/test_keepass.py @@ -0,0 +1,23 @@ +import unittest + +from automon.integrations.keepass_to_pass import KeepassClient + + +class TestKeepassClient(unittest.TestCase): + def test_set_database_csv_path(self): + test = KeepassClient() + with self.assertRaises(FileNotFoundError): + test.set_database_csv_path('AAAA.XXXCSV') + + open('BBBB.XXXCSV', 'w').close() + + self.assertTrue(test.set_database_csv_path('BBBB.XXXCSV')) + + def test_read_database_csv(self): + test = KeepassClient() + with self.assertRaises(OSError): + test.read_database_csv('AAAA.XXXCSV') + + +if __name__ == '__main__': + unittest.main()