Skip to content

Instantly share code, notes, and snippets.

@tillson
Created May 10, 2020 19:22
Show Gist options
  • Save tillson/620e8ef87bc057f25b0a27c423433fda to your computer and use it in GitHub Desktop.
Save tillson/620e8ef87bc057f25b0a27c423433fda to your computer and use it in GitHub Desktop.
Decode Base64 strings in a git repo's commit history
from pydriller import RepositoryMining
import re
import base64
foundSet = set()
for commit in RepositoryMining('./').traverse_commits():
for mod in commit.modifications:
if mod.source_code_before != None:
regex = re.findall(r"<text encoding=\"base64\">[^>]+</text>", mod.source_code_before)
for result in regex:
based = str(base64.b64decode(result[len("<text encoding='base64'>"):-len("</text>")]))
if based not in foundSet:
print(based)
foundSet.add(based + "\n")
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment