forked from DataDog/security-labs-pocs
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #11 from DataDog/ossl_punycode_malicious_server
Ossl punycode malicious server
- Loading branch information
Showing
5 changed files
with
55 additions
and
14 deletions.
There are no files selected for viewing
41 changes: 41 additions & 0 deletions
41
...f-of-concept-exploits/openssl-punycode-vulnerability/malicious_server/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
Several scripts are available to ease the generation of server certificates so as to running client / server commands for testing purpose with gdb. | ||
|
||
# run.sh | ||
|
||
## run_server | ||
|
||
This command bootstraps the malicious server. | ||
|
||
```run.sh run_server``` | ||
|
||
1. Fetch OpenSSL 3.0.7 source code, statically compile it with debug symbols. It also adds CFLAGS to generate expand files, useful to generate call graph. | ||
2. Build server certificate chains | ||
3. start server with openssl binary compiled at step1. | ||
|
||
## run_vuln_client | ||
|
||
This command bootstraps the vulnerable client. | ||
|
||
```run.sh run_vuln_client``` | ||
|
||
1. Fetch OpenSSL 3.0.6 source code, statically compile it with debug symbols. It also adds CFLAGS to generate expand files, useful to generate call graph. | ||
2. start client gdb session with openssl binary compiled at step1. Gdb commands will: | ||
* set a breakpoint on the vulnerable function | ||
|
||
## compile | ||
|
||
```run.sh compile openssl-3.0.6``` | ||
|
||
Fetches OpenSSL source code based on provided version, statically compiles it with debug symbols. It also adds CFLAGS to generate expand files, useful to generate call graph. | ||
|
||
## build_server | ||
|
||
```run.sh build_server``` | ||
|
||
Rebuilds the server certificate chains. Useful if you updated the server configuration and just want to use the new certs. | ||
|
||
## clean | ||
|
||
```run.sh clean clean_server``` | ||
|
||
These commands will delete all files created at build step. You can clean globally by calling clean, or just for server with clean_server. |
2 changes: 1 addition & 1 deletion
2
...-of-concept-exploits/openssl-punycode-vulnerability/malicious_server/client/gdb_client.sh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
gdb ../openssl/apps/openssl -command=client.gdb | ||
gdb ../openssl-3.0.6/apps/openssl -command=client.gdb |
2 changes: 1 addition & 1 deletion
2
...-of-concept-exploits/openssl-punycode-vulnerability/malicious_server/client/run_client.sh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
../openssl/apps/openssl s_client -connect 127.0.0.1:3000 -state | ||
../openssl-3.0.6/apps/openssl s_client -connect 127.0.0.1:3000 -state |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2 changes: 1 addition & 1 deletion
2
...-of-concept-exploits/openssl-punycode-vulnerability/malicious_server/server/run_server.sh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
../openssl/apps/openssl s_server -accept 127.0.0.1:3000 -CAfile certs/cacert.pem -cert certs/trusted.pem -key certs/server.key.pem -state | ||
../openssl-3.0.7/apps/openssl s_server -accept 127.0.0.1:3000 -CAfile certs/cacert.pem -cert certs/trusted.pem -key certs/server.key.pem -state |