-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathretrieve_pdb.py
66 lines (57 loc) · 2.17 KB
/
retrieve_pdb.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#!/usr/bin/env python3
# File name : __init__.py
# Author : Podalirius (@podalirius_)
# Date created : 7 Feb 2023
from __future__ import annotations
import os
import pefile
import requests
from rich import progress
def download_pdb(download_dir, pdbname, signature):
download_url = "https://msdl.microsoft.com/download/symbols/{}/{}/{}".format(
pdbname, signature.upper(), pdbname
)
print("[>] Downloading %s" % download_url)
r = requests.head(
download_url,
headers={"User-Agent": "Microsoft-Symbol-Server/10.0.10036.206"},
allow_redirects=True,
)
if r.status_code == 200:
target_file = download_dir + os.path.sep + signature
with progress.Progress() as p:
progress_bar, csize = (
p.add_task(
"[cyan]Downloading %s" % pdbname,
total=int(r.headers["Content-Length"]),
),
1024 * 16,
)
pdb = requests.get(
r.url,
headers={"User-Agent": "Microsoft-Symbol-Server/10.0.10036.206"},
stream=True,
)
with open(target_file, "wb") as f:
for chunk in pdb.iter_content(chunk_size=csize):
f.write(chunk)
p.update(progress_bar, advance=len(chunk))
else:
print("[!] (HTTP %d) Could not find %s " % (r.status_code, download_url))
def get_pe_debug_infos(pathtopefile):
p = pefile.PE(pathtopefile, fast_load=False)
pedata = {d.name: d for d in p.OPTIONAL_HEADER.DATA_DIRECTORY}
raw_debug_data = [
e
for e in p.parse_debug_directory(
pedata["IMAGE_DIRECTORY_ENTRY_DEBUG"].VirtualAddress,
pedata["IMAGE_DIRECTORY_ENTRY_DEBUG"].Size,
)
if e.entry is not None
]
raw_debug_data = raw_debug_data[0].entry
pdbname: str = raw_debug_data.PdbFileName.strip(b"\x00").decode("utf-8")
signature: str = p.DIRECTORY_ENTRY_DEBUG[0].entry.Signature_String
# If an absolute path is embedded the server uses just the filename
pdbname = pdbname.split("\\")[-1]
return pdbname, signature