Skip to content

Commit

Permalink
Create system-requirements.md
Browse files Browse the repository at this point in the history
  • Loading branch information
austinsonger authored Jun 18, 2024
1 parent 086dfac commit dce20a6
Showing 1 changed file with 63 additions and 0 deletions.
63 changes: 63 additions & 0 deletions docs/system-requirements.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
# AuditBuddy

This GitHub Action automates evidence collection for compliance frameworks like SOC 2, ISO 27001, FedRAMP, and PCI DSS. It integrates with various cloud providers (AWS, Azure, GCP) and security tools (Okta, Tenable, etc.) to extract relevant data based on the chosen framework and control. The collected evidence is then formatted and committed to a designated location within the user's GitHub repository, simplifying compliance audits.

### Framework Requirements:

* Framework Specificity:
* Each framework has control objectives and corresponding controls with evidence types (e.g., policies, procedures, logs).
* Mapping Framework Controls to Evidence:
* Create a mapping between specific framework controls and the type of evidence they require (e.g., Population for user access controls, Configurations for security settings).

### Language and Configuration Files
- Python
- `YAML`
- `json`

### Integration with Cloud Providers and Security Tools

* SDKs and APIs:
* Utilize the official SDKs or APIs provided by each cloud provider (AWS, Azure, GCP) and security tool (Okta, OneLogin, Tenable, Elastic, Splunk, CrowdStrike) to interact with them. This will allow you to pull relevant evidence based on the framework and control being assessed.
* https://aws.amazon.com/sdk-for-python/
* https://github.com/Azure/azure-sdk-for-python
* https://github.com/googleapis/google-cloud-python
* https://github.com/okta/okta-sdk-python
* https://pypi.org/project/elasticsearch/
* https://github.com/CrowdStrike/falconpy
* https://github.com/splunk/splunk-sdk-python
* https://github.com/TheJumpCloud/jcapi-python
* https://github.com/onelogin/onelogin-python-sdk
* https://github.com/tenable/pyTenable
* https://github.com/onelogin/onelogin-python-sdk
* Authentication:
* Implement secure authentication methods (e.g., OAuth, API keys) to connect with each platform. Store these credentials securely within the Github Action workflow using secrets.

### Evidence Collection Logic

* Framework Selection:
* Allow users to specify the framework they're targeting within the Github Action workflow.
* Control Mapping:
* Based on the chosen framework and control being assessed, use the mapping created earlier to identify the type of evidence needed.
* Data Extraction:
* Leverage the SDKs/APIs to extract relevant data from each cloud provider and security tool based on the control objective.
* Data Formatting:
* Format the extracted data according to your defined structure (Populations, Configurations, Rules, Samples).

### Commit and Push Evidence
* Version Control:
* Use Git commands within the Github Action workflow to commit the collected evidence files to a dedicated branch.
* Push Automation:
* Configure the workflow to automatically push the committed evidence to the desired location in the repository.

### Additional Considerations:

* Error Handling:
* Implement robust error handling mechanisms to address potential issues during data extraction or API calls.
* Security:
* Prioritize security throughout the development process. Use secure methods to store credentials and ensure proper access controls.
* Testing:
* Develop a comprehensive testing strategy to ensure the Github Action collects accurate evidence for various frameworks and controls.


Can you give me recommendations of different programming setups that will work best for this project.

0 comments on commit dce20a6

Please sign in to comment.