Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release 2.0.0 #299

Draft
wants to merge 148 commits into
base: develop
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
148 commits
Select commit Hold shift + click to select a range
dae3d7a
Restructure directories
pablosnt Jul 8, 2023
598c5c5
Fix broken references to requirements.txt
pablosnt Jul 8, 2023
6a92c04
Fix broken references to backend directory
pablosnt Jul 8, 2023
545bc9f
Merge pull request #232 from pablosnt/feature/restructuration
pablosnt Jul 9, 2023
e54ce4c
Update Python version used by MyPy job
pablosnt Jul 9, 2023
56653fa
Debug generated EXE
pablosnt Jul 9, 2023
8fed1d9
Debug generated EXE
pablosnt Jul 9, 2023
92f528a
Fix generation of Desktop UI in Windows
pablosnt Jul 9, 2023
71a6afb
Merge pull request #238 from pablosnt/bugfix/pipelines
pablosnt Jul 9, 2023
6236b40
Initial refactoring and code optimization
pablosnt Aug 8, 2023
2d6714e
Improve input validation, add target blacklist configuration, and add…
pablosnt Aug 16, 2023
1cb640c
Add user model, authentication, authorization, security middleware an…
pablosnt Sep 6, 2023
e563783
Validate expiration for API tokens
pablosnt Sep 6, 2023
3e8437e
Add tool and configuration models
pablosnt Sep 11, 2023
7ec559b
Add process and step models
pablosnt Sep 11, 2023
c811148
Remove commented code
pablosnt Sep 11, 2023
80a20bf
Add tasks, executions and tasks modules
pablosnt Sep 21, 2023
281c842
Save tool version and installation status in database
pablosnt Sep 22, 2023
87f39f5
Migration of tool parsers, executors and queues
pablosnt Oct 8, 2023
9ae444b
Fix drf-spectacular warnings related to the Enums naming
pablosnt Oct 8, 2023
6bf5a6f
Add new integrations schema, Defect-Dojo and NVD NIST integration
pablosnt Oct 16, 2023
728976c
Add new notifications schema, Mail and Telegram
pablosnt Oct 19, 2023
7cb7eae
Improve filter fields
pablosnt Oct 20, 2023
b5b43da
Improve notifications of executions via mail
pablosnt Oct 20, 2023
f523809
Update Defect-Dojo scan types for supported tools
pablosnt Oct 20, 2023
1d056ea
Invalidate tokens before login, after logout and password changes, as…
pablosnt Oct 20, 2023
b21abd9
Fix fixtures loading after migrations
pablosnt Nov 12, 2023
a1c4728
Optimization and adaption of Telegram bot to the version 20.6
pablosnt Nov 13, 2023
34b54f9
Some Python syntax improvement
pablosnt Nov 14, 2023
2d3191a
Fix unexpected behavior on migrations management
pablosnt Nov 14, 2023
70fcb85
Send mail messages in a thread to don't stop the main execution
pablosnt Nov 14, 2023
0a69748
Remove old and useless code
pablosnt Nov 14, 2023
7c6c7b0
Some improvements: encrypt credentials stored on database, fix queues…
pablosnt Nov 16, 2023
35ce848
Initial unit tests for API operations and fixes for all the problems …
pablosnt Nov 29, 2023
59b44a2
Add config.yaml to the .gitignore to prevent the encryption key exposure
pablosnt Nov 29, 2023
76aefef
Unit tests for tool parsers and fixes for all the problems found
pablosnt Dec 1, 2023
7f4d455
Unit tests for task and executions and fixes for all the problems found
pablosnt Dec 2, 2023
68c860e
Update gitignore
pablosnt Dec 2, 2023
1171c85
Unit tests for findings and fixes for all the problems found
pablosnt Dec 4, 2023
79f5058
Fix unique findings creation
pablosnt Dec 4, 2023
49b87cd
Unit tests for NVD NIST integration
pablosnt Dec 4, 2023
438d158
Unit tests for SMTP settings API
pablosnt Dec 4, 2023
ea980aa
Setup a timeout for the SMTP connection
pablosnt Dec 4, 2023
0b98119
Unit tests for Telegram settings API
pablosnt Dec 5, 2023
657b342
Unit tests for Telegram chats API
pablosnt Dec 5, 2023
f62e504
Improve Telegram chats coverage
pablosnt Dec 5, 2023
5d0cee2
Unit tests for Defect-Dojo settings API
pablosnt Dec 5, 2023
fa0013d
Unit tests for Defect-Dojo entities creation API
pablosnt Dec 5, 2023
aac0c7f
Prevent errors in unit tests
pablosnt Dec 5, 2023
48e17a3
Fix some errors in unit tests
pablosnt Dec 5, 2023
3c0852a
Check Defect-Dojo availability without retries when connection fails
pablosnt Dec 6, 2023
d06d51b
Remove debug input
pablosnt Dec 6, 2023
241a084
Prevent errors introduced by the framework
pablosnt Dec 6, 2023
9480c20
Split Telegram and Defect-Dojo tests in different files
pablosnt Dec 6, 2023
98edf16
Unit tests for Defect-Dojo synchronization API
pablosnt Dec 6, 2023
07d5516
Tests files restructuring, shared findings for testing and unit tests…
pablosnt Dec 6, 2023
367a24f
Fix some errors in unit tests
pablosnt Dec 6, 2023
5703aad
Initial unit tests for BaseExecutor
pablosnt Dec 6, 2023
b047d89
More test cases for BaseExecutor
pablosnt Dec 6, 2023
e02d249
Move Wordlist model reference from fallback to model field in the rel…
pablosnt Dec 6, 2023
1015cec
Unit tests for GobusterExecutor
pablosnt Dec 7, 2023
a577286
Mock _get_url method to avoid connectivity errors from GitHub Actions
pablosnt Dec 7, 2023
c8fbb35
Unit tests for executions generation from tool and process task
pablosnt Dec 7, 2023
046d2ab
Fix some errors and improve some unit tests
pablosnt Dec 7, 2023
c283842
Optimize tests structure
pablosnt Dec 7, 2023
a7d56ec
Unit tests for executions generation from findings and user-provided …
pablosnt Dec 8, 2023
ea084b9
Fix errors after restructuring
pablosnt Dec 8, 2023
c80e786
Improve __str__ methods in models
pablosnt Dec 8, 2023
3e21f20
Adapt unit tests to latest __str__ changes
pablosnt Dec 8, 2023
1450b38
Only encrypt and decrypt database fields when the encryption key is c…
pablosnt Dec 8, 2023
ecdded4
New management commands to handle encryption key in the config file a…
pablosnt Dec 8, 2023
5f4f2b2
Configure encryption key for the unit tests execution
pablosnt Dec 8, 2023
f2445a0
Store hashed OTPs in database instead of plain text ones
pablosnt Dec 8, 2023
e37a467
Override permission_classes in those views with different permissions…
pablosnt Dec 8, 2023
fbc24b4
Skip Telegram bot and notifications code from the unit tests coverage…
pablosnt Dec 8, 2023
0dfa33f
Try to execute unit tests without Redis
pablosnt Dec 8, 2023
5dee8b3
Install Redis before unit tests execution, improve authentication par…
pablosnt Dec 8, 2023
4a125d8
Improve unit tests coverage
pablosnt Dec 8, 2023
c78bd87
Fix filters by multiple database fields at once
pablosnt Dec 8, 2023
fe7473d
Fix Project.__str__ test
pablosnt Dec 8, 2023
e8b210e
Improve unit tests coverage
pablosnt Dec 8, 2023
a23ff5a
Improve unit tests coverage
pablosnt Dec 8, 2023
99e43cd
Improve unit tests coverage
pablosnt Dec 8, 2023
e32c2d7
Improve unit tests coverage and fix some errors
pablosnt Dec 8, 2023
6d57efa
Raise controlled exception when an invalid intensity value is provided
pablosnt Dec 8, 2023
96544c7
Fix unit test error
pablosnt Dec 8, 2023
bd2a55b
Test OPTIONS request and ignore some lines in the coverage check
pablosnt Dec 8, 2023
b91d784
Improve coverage in input validation tests
pablosnt Dec 8, 2023
4798a57
Improve unit tests coverage for notifications scope
pablosnt Dec 8, 2023
412eb61
Remove debugging inputs
pablosnt Dec 8, 2023
1df3e54
Remove debugging prints
pablosnt Dec 8, 2023
85441b4
Fix error in target validator
pablosnt Dec 8, 2023
3d6bc24
Disable some tests for debugging
pablosnt Dec 8, 2023
26787d6
Improve unit tests coverage
pablosnt Dec 9, 2023
f19766a
Get target blacklist dynamically for each validation
pablosnt Dec 9, 2023
3483dc7
Improve unit tests coverage for PasswordValidator and TargetBlacklist
pablosnt Dec 9, 2023
d460013
Fix error in TargetBlacklist test
pablosnt Dec 9, 2023
76dcebb
Fix error in TargetBlacklist test
pablosnt Dec 9, 2023
b34ac96
Improve unit tests coverage in findings models
pablosnt Dec 9, 2023
82c8514
Improve unit tests coverage in findings models
pablosnt Dec 9, 2023
a1cac74
Notify Telegram users when their session is closed automatically due …
pablosnt Dec 9, 2023
1e3371e
Apply TargetPort path filter as filter instead of within the Path parser
pablosnt Dec 9, 2023
a0ce00f
Fix Telegram notifications
pablosnt Dec 9, 2023
755f2ba
Fix Telegram notifications
pablosnt Dec 9, 2023
17ed68d
Fix Telegram notifications
pablosnt Dec 9, 2023
c49519a
Fix Telegram notifications
pablosnt Dec 9, 2023
8924dc8
Improve error and invalid tokens handling by the Telegram bot
pablosnt Dec 10, 2023
99a49f9
Fix background email sending
pablosnt Dec 10, 2023
12762b3
Fix Redis queues, Defect-Dojo integration, Telegram notifications and…
pablosnt Dec 26, 2023
fbeb4ca
Upgrade all dependencies except Django
pablosnt Dec 26, 2023
196054c
Upgrade Django to 5.0 version
pablosnt Dec 26, 2023
688e75b
Keep support for old Dirsearch report format and fix Nikto and findin…
pablosnt Dec 26, 2023
7f22357
Fix Dirsearch parser
pablosnt Dec 26, 2023
d7b6a95
Fix config path in Dockerfiles
pablosnt Dec 26, 2023
e5eb108
Decrease required coverage
pablosnt Dec 26, 2023
d45a125
Update hashes for third party GitHub actions
pablosnt Dec 26, 2023
3433ef4
Fix config path in Dockerfile
pablosnt Dec 26, 2023
3bede31
Fix tests path in Dockerfile
pablosnt Dec 26, 2023
00d039a
Fix config directory in Dockerfile
pablosnt Dec 26, 2023
dab3d2b
Update CHANGELOG with the release preview
pablosnt Dec 27, 2023
2d8033f
Add Bandit scans to SAST workflow
pablosnt Dec 27, 2023
0848c46
Fix artifact upload
pablosnt Dec 27, 2023
b28dad2
Merge pull request #261 from pablosnt/cicd/bandit
pablosnt Dec 27, 2023
c1b4ccd
Union of backend and frontend scans in the same workflow and addition…
pablosnt Dec 27, 2023
8732db4
Improve legitify scans
pablosnt Dec 27, 2023
3a0012b
Merge branch 'feature/backend-optimization' into cicd/code-style
pablosnt Dec 27, 2023
4c9e564
Merge pull request #262 from pablosnt/cicd/code-style
pablosnt Dec 27, 2023
4adc500
Merge pull request #250 from pablosnt/feature/backend-optimization
pablosnt Dec 27, 2023
dd395f5
Fix issues detected by CI/CD tools (#263)
pablosnt Dec 30, 2023
070fffa
Download original reports generated by tools (#264)
pablosnt Dec 30, 2023
1db438a
Custom proxy configuration for executions (#265)
pablosnt Dec 30, 2023
5638f1e
New endpoint to get RQ status and stats (#266)
pablosnt Dec 30, 2023
d6fdd86
Pentesting notes feature (#268)
pablosnt Jan 3, 2024
8381e9f
Integrations API to handle all integrations supported (#270)
pablosnt Jan 3, 2024
5c4e54a
Integration with HackTricks to link findings to wiki resources (#272)
pablosnt Jan 4, 2024
690cfcd
Reporting feature to generate JSON, XML and PDF reports (#274)
pablosnt Mar 21, 2024
8094764
Rename queues without the "-queue" value (#278)
pablosnt Mar 21, 2024
645a1f7
Add new security scans to CI/CD (#280)
pablosnt Mar 21, 2024
dedaa42
Findings management (#285)
pablosnt Mar 24, 2024
dd1ad55
Update NVD NIST API calls to use the API version 2.0 (#291)
pablosnt Mar 27, 2024
054c3d7
Hide authentication details in execution output, error and reports (#…
pablosnt Mar 27, 2024
6b0d6d1
Customization of HTTP headers (#296)
pablosnt Mar 29, 2024
f1edbfa
Update CHANGELOG
pablosnt Mar 29, 2024
d61ea47
Merge remote-tracking branch 'origin/migration/2.0.0' into migration/…
pablosnt Mar 29, 2024
1bb62b0
Improve input validation
pablosnt Mar 30, 2024
2d13322
Remove scheduled_in and scheduled_time_unit from tasks (#305)
pablosnt Mar 31, 2024
970b88d
Multi Factor Authentication (#306)
pablosnt Apr 4, 2024
2a1bb7c
Alert System (#307)
pablosnt Apr 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Initial unit tests for BaseExecutor
  • Loading branch information
pablosnt committed Dec 6, 2023
commit 5703aad5c42641735b4587be266eda9d1fb18c70
17 changes: 9 additions & 8 deletions src/backend/findings/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -112,13 +112,13 @@ def parse(
) -> Dict[str, Any]:
ports = (
[self.port]
if not accumulated or InputKeyword.PORTS.name.lower() not in accumulated
else [self.port] + accumulated[InputKeyword.PORTS.name.lower()]
if not accumulated
else accumulated.get(InputKeyword.PORTS.name.lower(), []) + [self.port]
)
output = {
InputKeyword.PORT.name.lower(): self.port,
InputKeyword.PORTS.name.lower(): ports,
InputKeyword.PORTS_COMMAS.name.lower(): [str(p) for p in ports],
InputKeyword.PORTS_COMMAS.name.lower(): ",".join([str(p) for p in ports]),
}
if self.host:
output.update(
Expand Down Expand Up @@ -170,10 +170,11 @@ class Path(Finding):
]

def _clean_path_value(self, value: str) -> str:
if value[0] != "/":
value = f"/{value}"
if value[-1] != "/":
value += "/"
if len(value) > 1:
if value[0] != "/":
value = f"/{value}"
if value[-1] != "/":
value += "/"
return value

def parse(
Expand All @@ -184,7 +185,7 @@ def parse(
include_path_data = True
if target_port.exists():
include_path_data = self._clean_path_value(self.path).startswith(
self._clean_path_value(target_port.first().path)
self._clean_path_value(target_port.first().path or self.path)
)
if include_path_data:
output[InputKeyword.ENDPOINT.name.lower()] = self.path
Expand Down
6 changes: 5 additions & 1 deletion src/backend/framework/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,10 @@ def _get_url(
schema = "{protocol}://{host}/{endpoint}"
if port:
schema = "{protocol}://{host}:{port}/{endpoint}" # Include port schema if port exists
if port == 80:
protocols = ["http"]
elif port == 443:
protocols = ["https"]
for protocol in protocols: # For each protocol
url_to_test = schema.format(
protocol=protocol, host=host, port=port, endpoint=endpoint
Expand All @@ -120,7 +124,7 @@ def _get_url(
# nosemgrep: python.requests.security.disabled-cert-validation.disabled-cert-validation
requests.get(url_to_test, timeout=5, verify=False)
return url_to_test
except Exception:
except:
continue
return None

Expand Down
4 changes: 2 additions & 2 deletions src/backend/input_types/fixtures/1_input_types.json
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
"fields": {
"name": "Port",
"model": "findings.port",
"fallback_model": "targets.targetport",
"fallback_model": "target_ports.targetport",
"relationships": true
}
},
Expand All @@ -35,7 +35,7 @@
"fields": {
"name": "Path",
"model": "findings.path",
"fallback_model": null,
"fallback_model": "target_ports.targetport",
"relationships": true
}
},
Expand Down
1 change: 1 addition & 0 deletions src/backend/target_ports/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ def parse(
InputKeyword.HOST.name.lower(): self.target.target,
InputKeyword.PORT.name.lower(): self.port,
InputKeyword.PORTS.name.lower(): ports,
InputKeyword.ENDPOINT.name.lower(): self.path,
InputKeyword.PORTS_COMMAS.name.lower(): ",".join(
[str(p) for p in ports]
),
Expand Down
16 changes: 8 additions & 8 deletions src/backend/tasks/queues.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,10 @@ def _consume_tool_task(self, task: Task) -> None:
executions = self._calculate_executions(
task.configuration.tool,
[],
task.target.target_ports,
task.target.input_vulnerabilities,
task.target.input_technologies,
task.wordlists,
task.target.target_ports.all(),
task.target.input_vulnerabilities.all(),
task.target.input_technologies.all(),
task.wordlists.all(),
)
for parameters in executions or [{}]:
execution = Execution.objects.create(
Expand Down Expand Up @@ -135,10 +135,10 @@ def _consume_process_task(self, task: Task) -> None:
executions = self._calculate_executions_from_task_parameters(
step.configuration.tool,
[],
task.target.target_ports,
task.target.input_vulnerabilities,
task.target.input_technologies,
task.wordlists,
task.target.target_ports.all(),
task.target.input_vulnerabilities.all(),
task.target.input_technologies.all(),
task.wordlists.all(),
)
for parameters in executions or [{}]:
execution = Execution.objects.create(
Expand Down
2 changes: 1 addition & 1 deletion src/backend/tests/framework.py
Original file line number Diff line number Diff line change
Expand Up @@ -183,7 +183,7 @@ def _setup_findings(self, execution: Execution) -> None:
},
Exploit: {
"vulnerability": 1,
"title": "Reverse Shell",
"title": "ReverseShell",
"edb_id": 1,
"reference": "https://www.exploit-db.com/exploits/1",
},
Expand Down
165 changes: 165 additions & 0 deletions src/backend/tests/test_executors.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,165 @@
from typing import List

from executions.enums import Status
from executions.models import Execution
from findings.enums import OSINTDataType
from findings.framework.models import Finding
from findings.models import Port
from input_types.enums import InputTypeName
from input_types.models import InputType
from parameters.models import InputTechnology, InputVulnerability
from target_ports.models import TargetPort
from tasks.models import Task
from tests.framework import RekonoTest
from tools.enums import Intensity as IntensityEnum
from tools.enums import Stage
from tools.models import Argument, Configuration, Input, Intensity, Tool
from wordlists.models import Wordlist


class ToolExecutorTest(RekonoTest):
def setUp(self) -> None:
super().setUp()
self._setup_target()
self.fake_tool = Tool.objects.create(
name="fake",
command="fake",
is_installed=True,
version="1.0.0",
version_argument="--version",
)
for index, value in enumerate(IntensityEnum):
Intensity.objects.create(
tool=self.fake_tool, argument=f"-i {index}", value=value
)
self.fake_configuration = Configuration.objects.create(
name="fake",
tool=self.fake_tool,
arguments="{host} {url} {ports_commas} {endpoint} {technology} {secret} {cve} {exploit}",
stage=Stage.ENUMERATION,
default=True,
)
for value, required, multiple, input_type_names in [
("host", True, False, [InputTypeName.OSINT]),
(
"url",
True,
False,
[InputTypeName.PATH, InputTypeName.PORT, InputTypeName.HOST],
),
("ports_commas", True, True, [InputTypeName.PORT]),
("endpoint", False, False, [InputTypeName.PATH]),
("technology", True, False, [InputTypeName.TECHNOLOGY]),
("secret", False, False, [InputTypeName.CREDENTIAL]),
("cve", True, False, [InputTypeName.VULNERABILITY]),
("exploit", False, False, [InputTypeName.EXPLOIT]),
]:
new_argument = Argument.objects.create(
tool=self.fake_tool,
name=value,
argument="-p {" + value + "}",
required=required,
multiple=multiple,
)
for index, input_type_name in enumerate(input_type_names):
Input.objects.create(
argument=new_argument,
type=InputType.objects.get(name=input_type_name),
order=index + 1,
)
self.task = Task.objects.create(
target=self.target,
configuration=self.fake_configuration,
executor=self.auditor1,
)
self.execution = Execution.objects.create(
task=self.task,
configuration=self.fake_configuration,
status=Status.REQUESTED,
)
self._setup_findings(self.execution)
# scanme.nmap.org: connectivity is needed to build a valid URL from host, port and path
self.host.address = "45.33.32.156"
self.host.save(update_fields=["address"])
self.path.path = "/images"
self.path.save(update_fields=["path"])
self.osint.data = "10.10.10.11"
self.osint.data_type = OSINTDataType.IP
self.osint.save(update_fields=["data", "data_type"])
self.executor = self.fake_tool.get_executor_class()(self.execution)

def test_get_environment(self) -> None:
expected_env = [("KEY1", "value1"), ("KEY2", "value2")]
self.executor.arguments = [f"{k}={v}" for k, v in expected_env] + [
self.fake_tool.command,
"--foo=bar",
]
environment = self.executor._get_environment()
for key, value in expected_env:
self.assertIsNotNone(environment.get(key))
self.assertEqual(value, environment.get(key))

def _success_get_arguments(
self,
expected: str,
findings: List[Finding],
target_ports: List[TargetPort] = [],
input_vulnerabilities: List[InputVulnerability] = [],
input_technologies: List[InputTechnology] = [],
wordlists: List[Wordlist] = [],
) -> None:
arguments = self.executor._get_arguments(
findings, target_ports, input_vulnerabilities, input_technologies, wordlists
)
self.assertEqual(expected, " ".join(arguments))
self.assertTrue(
self.executor.check_arguments(
findings,
target_ports,
input_vulnerabilities,
input_technologies,
wordlists,
)
)

def test_get_arguments_only_findings(self) -> None:
self._success_get_arguments(
"-p 10.10.10.11 -p http://45.33.32.156:80/images -p 80 -p /images -p WordPress -p admin -p CVE-2023-1111 -p ReverseShell",
self.findings,
)

def test_get_arguments_only_required_findings(self) -> None:
self._success_get_arguments(
"-p 10.10.10.11 -p http://45.33.32.156:80/ -p 80 -p WordPress -p CVE-2023-1111",
[self.osint, self.host, self.port, self.technology, self.vulnerability],
)

def test_get_arguments_multiple_ports(self) -> None:
self._success_get_arguments(
"-p 10.10.10.11 -p http://45.33.32.156:80/ -p 80,443 -p WordPress -p CVE-2023-1111",
[
self.osint,
self.host,
self.port,
self._create_finding(
Port, {**self.raw_findings[Port], "port": 443}, self.execution
),
self.technology,
self.vulnerability,
],
)

# TODO: test with target ports, user-provided parameters, wordlists and authentication

def test_get_arguments_no_findings(self) -> None:
self.assertFalse(self.executor.check_arguments([], [], [], [], []))

def test_get_arguments_missing_one_required_finding(self) -> None:
self.assertFalse(
self.executor.check_arguments(
[self.osint, self.host, self.port, self.technology], [], [], [], []
)
)


# TODO: Test Gobuster executor
7 changes: 3 additions & 4 deletions src/backend/tests/test_findings.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
from findings.enums import (
HostOS,
OSINTDataType,
PathType,
PortStatus,
Protocol,
Severity,
Expand Down Expand Up @@ -92,11 +91,11 @@
Exploit: (
{
"title": "Exploit 1 found",
"description": "Reverse Shell",
"description": "ReverseShell",
"severity": Severity.CRITICAL,
"references": "https://www.exploit-db.com/exploits/1",
},
"10.10.10.10 - 80 - WordPress - Test - CVE-2023-1111 - Reverse Shell",
"10.10.10.10 - 80 - WordPress - Test - CVE-2023-1111 - ReverseShell",
"/api/exploits/",
),
}
Expand Down Expand Up @@ -230,7 +229,7 @@ def test_str(self) -> None:
Exploit,
{"technology": 1},
"vulnerability",
"10.10.10.10 - 80 - WordPress - Reverse Shell",
"10.10.10.10 - 80 - WordPress - ReverseShell",
),
]:
data = {**self.raw_findings[finding_model], **new_data}
Expand Down
Loading
Loading