Skip to main content

HAWK SOAR Daemon

Project description

Coding guidelines: Doc Strings https://sphinxcontrib-napoleon.readthedocs.io/en/latest/example_google.html

pep8 (enter steps to configure git commit to use style guidelines)

classes should be camel case e.g. class HawkSoarAPI() functions should be snake e.g. def my_func()

_single_leading_underscore: weak "internal use" indicator. E.g. from M import * does not import objects whose name starts with an underscore.

File structure: hawk-soard - HAWK SOAR Application hawkSoar - Main Project app folder lib - Library code: API code for talking to different API's, including logging in. unit - Folder for holding unit test for library code. cache.py - Local helper to set and get cache creds.py - For getting creds from Vault database.py - sets up cache database tables, also query functions eyecon.py - API helper functions for Communicating with standard API calls getting events, agents, etc marketplace.py - API helper functions for Communicating with marketplace API login, getting plugin details, download plugins soar.py - API helper functions for communicating with SOAR API. Get task, Return results from task. common - Common code that can be used anywhere common.py - common functions process.py - common functions for interacting with processes manager - Manager code for different parts of the program cache.py - cacheManager code that manages getting and setting data to cache and syncing with remote cache manager.py - Main manager that starts all the other managers. Manages data between the different managers marketplace.py - Detects new plugins to be installed and installs them and notify the PluginManager of new plugins. Updates Cache plugin.py - For handling registering and deregistering plugins. is responsible for maintaining the state of the registered plugins, broadcasting the registry of those plugins and fielding requests that come in. task.py - taskManager get's task from SOAR API then directs the task to the correct plugin. Returns results to SOAR API. Scheduler marketplace - Where the plugins will be installed in the appropriate folder based on type. contain decision include
ingest investigate network_utilities - Test plugin to build plugin template. code - Where the plugin's code exist html - HTML templete code for plugins view on dashboard. test - Unit test for testing plugin's code. uses investigate_plugin_test_class.py notify record recover utility plugins - Plugin template code investigate - Plugin template for investigate plugins PluginBase.py - Plugin base template code for investigate plugins base.py - Plugin template code for all plugin types test - Unit test unit - Unit test investigate - unit test for investigate plugins investigate_plugin_test_class.py - Plugin unit test code for investigate plugins. Used by code in plugins unit test. errors.py - Custom exceptions logger.py - Logging for program models.py - data models for task objects used by plugins parse_config.py - Parse hawk-soard.cfg file (might be moved to helper_functions.common.py) rpm - Files for building RPM package hawk-soard.spec - Spec file for generating RPM hawk-soard - starts application, daemonize requirements.txt - used for non-rpm install with pip, list all required software to be installed setup.py - install application

Execution Workflow:

Manager starts, needs config

  • soar api needs initializing and login
  • via soar api, a list of playbooks is pulled
    • get playbooks api code
  • load all available plugins?
    • but do not start plugin unless in playbook

    • only 1 instance of plugin runs at a time (for now, can try parallel in future), and answers any questions sent to its queue (incoming/outgoing)

    • run start method if found

    • manager or communication service is responsible for owning the websocket connection, and listening to all outgoing plugin queues and sending the response at the same time, it will be listening to all websocket requests and placing them in the proper plugin incoming queue task broker class

    • initializing the run-time configuration

      • inside manager: for each playbook
        • for each step:
          • initialize each module with given config inside the step to listen for events and pre-process or w/each
          • also pass the given steps playbook data config, so it knows what steps are next and whats previous, or if we're the end.
    • runtime behavior

      • does each step block until other plugins in given step complete? thus providing a total answer? blocks/delays but guarantees message totallity?

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hawk_soard-0.1.1.tar.gz (269.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hawk_soard-0.1.1-py3-none-any.whl (302.9 kB view details)

Uploaded Python 3

File details

Details for the file hawk_soard-0.1.1.tar.gz.

File metadata

  • Download URL: hawk_soard-0.1.1.tar.gz
  • Upload date:
  • Size: 269.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for hawk_soard-0.1.1.tar.gz
Algorithm Hash digest
SHA256 13e2cdde5900e927e3ecf026612a1c15273ea248b1631dc8f4866482e5f478c7
MD5 2e8030a1c76a997d4bfecdf151fe53e0
BLAKE2b-256 842c13ec2931903545526e08ac5b7a4661f80558fa12ee3c29b63e036cff9658

See more details on using hashes here.

File details

Details for the file hawk_soard-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: hawk_soard-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 302.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for hawk_soard-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c9d1579aaf692b18bc0ee5b314bde2c988e3b6c498f354f4bf5d5ab9ab8e0fb9
MD5 92bb1cc82b92768965a26d717c74c678
BLAKE2b-256 a4366ae54769a96399979f6bed75bdd94222a3265b0e54da75061cfd49a85f24

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page