|
|
|
@ -1,131 +1,166 @@
|
|
|
|
|
#!/usr/bin/env python
|
|
|
|
|
import sys, string, types, hashlib, base64, re, urllib
|
|
|
|
|
import sys, string, types, hashlib, base64, re, urllib, binascii
|
|
|
|
|
import operator
|
|
|
|
|
from collections import Counter
|
|
|
|
|
|
|
|
|
|
LOWER_LETTERS = [chr(x) for x in range(97, 123)]
|
|
|
|
|
UPPER_LETTERS = [chr(x) for x in range(65, 91)]
|
|
|
|
|
COMMON_LETTERS = 'ETAOIN SHRDLU'
|
|
|
|
|
|
|
|
|
|
def xorSingleBrute(encoded='', keybytes=1):
|
|
|
|
|
resultList = dict()
|
|
|
|
|
if(encoded == ''):
|
|
|
|
|
encoded = raw_input('Input your Hex String:')
|
|
|
|
|
for xor_key in range(0, 2**(keybytes*8)):
|
|
|
|
|
decoded = '';
|
|
|
|
|
for i, j in zip(encoded[::2], encoded[1::2]):
|
|
|
|
|
decoded += ''.join(chr(int(i+j, 16) ^ xor_key))
|
|
|
|
|
#if (all(c in string.printable for c in decoded)):
|
|
|
|
|
#if isHumanReadable(decoded):
|
|
|
|
|
#print(xor_key, decoded)
|
|
|
|
|
resultList[decoded] = commonCounter(decoded)
|
|
|
|
|
sortedResults = sorted(resultList.items(), key=operator.itemgetter(1))
|
|
|
|
|
|
|
|
|
|
for result, key in sortedResults[-20:]:
|
|
|
|
|
#if (all(c in string.printable for c in result)):
|
|
|
|
|
print(result)
|
|
|
|
|
|
|
|
|
|
def commonCounter(inputString, limit=7):
|
|
|
|
|
countObj = Counter(inputString.upper())
|
|
|
|
|
common = countObj & Counter(COMMON_LETTERS)
|
|
|
|
|
return sum(common.values())
|
|
|
|
|
|
|
|
|
|
def fixedxor(string1 = '', string2 = ''):
|
|
|
|
|
if(string1 == ''):
|
|
|
|
|
string1 = raw_input("Please input your first hex string: ")
|
|
|
|
|
string2 = raw_input("Please input your second hex string: ")
|
|
|
|
|
hex1 = int(string1, 16)
|
|
|
|
|
hex2 = int(string2, 16)
|
|
|
|
|
result = hex1 ^ hex2
|
|
|
|
|
print(hex(result))
|
|
|
|
|
|
|
|
|
|
def rot(inputString, amount):
|
|
|
|
|
outputString = ""
|
|
|
|
|
for char in inputString:
|
|
|
|
|
resultChar = ""
|
|
|
|
|
if char.isupper():
|
|
|
|
|
index = UPPER_LETTERS.index(char)
|
|
|
|
|
resultChar = UPPER_LETTERS[(index + amount)%len(UPPER_LETTERS)]
|
|
|
|
|
elif char.islower():
|
|
|
|
|
index = LOWER_LETTERS.index(char)
|
|
|
|
|
resultChar = LOWER_LETTERS[(index + amount) % len(LOWER_LETTERS)]
|
|
|
|
|
else:
|
|
|
|
|
resultChar = char
|
|
|
|
|
outputString += resultChar
|
|
|
|
|
return outputString
|
|
|
|
|
outputString = ""
|
|
|
|
|
for char in inputString:
|
|
|
|
|
resultChar = ""
|
|
|
|
|
if char.isupper():
|
|
|
|
|
index = UPPER_LETTERS.index(char)
|
|
|
|
|
resultChar = UPPER_LETTERS[(index + amount)%len(UPPER_LETTERS)]
|
|
|
|
|
elif char.islower():
|
|
|
|
|
index = LOWER_LETTERS.index(char)
|
|
|
|
|
resultChar = LOWER_LETTERS[(index + amount) % len(LOWER_LETTERS)]
|
|
|
|
|
else:
|
|
|
|
|
resultChar = char
|
|
|
|
|
outputString += resultChar
|
|
|
|
|
return outputString
|
|
|
|
|
|
|
|
|
|
def translate(inputString, inputType, outputType):
|
|
|
|
|
result = ""
|
|
|
|
|
if(inputType == outputType):
|
|
|
|
|
result = inputString
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
if (inputType == 5):
|
|
|
|
|
for char in inputString:
|
|
|
|
|
if(outputType == 1):
|
|
|
|
|
result += str(bin(ord(char))) + " "
|
|
|
|
|
elif(outputType == 2):
|
|
|
|
|
result += str(ord(char)) + " "
|
|
|
|
|
elif(outputType == 3):
|
|
|
|
|
result += str(oct(ord(char))) + " "
|
|
|
|
|
elif(outputType == 4):
|
|
|
|
|
result += str(hex(ord(char))) + " "
|
|
|
|
|
else:
|
|
|
|
|
result = inputString
|
|
|
|
|
break
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
elif(inputType == 1):
|
|
|
|
|
inputString = int(inputString, 2)
|
|
|
|
|
elif(inputType == 2):
|
|
|
|
|
inputString = int(inputString)
|
|
|
|
|
elif(inputType == 3):
|
|
|
|
|
inputString = int(inputString, 8)
|
|
|
|
|
elif(inputType == 4):
|
|
|
|
|
inputString = int(inputString, 16)
|
|
|
|
|
|
|
|
|
|
if(outputType == 1):
|
|
|
|
|
result = bin(inputString)
|
|
|
|
|
elif(outputType == 2):
|
|
|
|
|
result = inputString
|
|
|
|
|
elif(outputType == 3):
|
|
|
|
|
result = oct(inputString)
|
|
|
|
|
elif(outputType == 4):
|
|
|
|
|
result = hex(inputString)
|
|
|
|
|
elif(outputType == 5):
|
|
|
|
|
result = chr(inputString)
|
|
|
|
|
return result
|
|
|
|
|
result = ""
|
|
|
|
|
if(inputType == outputType):
|
|
|
|
|
result = inputString
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
if (inputType == 5):
|
|
|
|
|
for char in inputString:
|
|
|
|
|
if(outputType == 1):
|
|
|
|
|
result += str(bin(ord(char))) + " "
|
|
|
|
|
elif(outputType == 2):
|
|
|
|
|
result += str(ord(char)) + " "
|
|
|
|
|
elif(outputType == 3):
|
|
|
|
|
result += str(oct(ord(char))) + " "
|
|
|
|
|
elif(outputType == 4):
|
|
|
|
|
result += str(hex(ord(char))) + " "
|
|
|
|
|
else:
|
|
|
|
|
result = inputString
|
|
|
|
|
break
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
elif(inputType == 1):
|
|
|
|
|
inputString = int(inputString, 2)
|
|
|
|
|
elif(inputType == 2):
|
|
|
|
|
inputString = int(inputString)
|
|
|
|
|
elif(inputType == 3):
|
|
|
|
|
inputString = int(inputString, 8)
|
|
|
|
|
elif(inputType == 4):
|
|
|
|
|
inputString = int(inputString, 16)
|
|
|
|
|
|
|
|
|
|
if(outputType == 1):
|
|
|
|
|
result = bin(inputString)
|
|
|
|
|
elif(outputType == 2):
|
|
|
|
|
result = inputString
|
|
|
|
|
elif(outputType == 3):
|
|
|
|
|
result = oct(inputString)
|
|
|
|
|
elif(outputType == 4):
|
|
|
|
|
result = hex(inputString)
|
|
|
|
|
elif(outputType == 5):
|
|
|
|
|
result = chr(inputString)
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
def urlEncoder():
|
|
|
|
|
input = raw_input("Pleae input your String: ")
|
|
|
|
|
print(urllib.quote_plus(input))
|
|
|
|
|
input = raw_input("Pleae input your String: ")
|
|
|
|
|
print(urllib.quote_plus(input))
|
|
|
|
|
|
|
|
|
|
def reverser():
|
|
|
|
|
string = raw_input('Please input your string to reverse:')
|
|
|
|
|
print(string[::-1])
|
|
|
|
|
string = raw_input('Please input your string to reverse:')
|
|
|
|
|
print(string[::-1])
|
|
|
|
|
|
|
|
|
|
def base64prompt():
|
|
|
|
|
b64regex = '^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$'
|
|
|
|
|
inputString = raw_input('Please input your string: ')
|
|
|
|
|
if (re.match(b64regex, inputString)):
|
|
|
|
|
print(base64.b64decode(inputString))
|
|
|
|
|
else:
|
|
|
|
|
print(base64.b64encode(inputString))
|
|
|
|
|
b64regex = '^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$'
|
|
|
|
|
inputString = raw_input('Please input your string: ')
|
|
|
|
|
if (re.match(b64regex, inputString)):
|
|
|
|
|
print(base64.b64decode(inputString))
|
|
|
|
|
else:
|
|
|
|
|
print(base64.b64encode(inputString))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def rotPrompt():
|
|
|
|
|
choice = input("What kind of ROT do you want to perform? 1-25, or all: ")
|
|
|
|
|
userInput = raw_input("Please insert a string: ")
|
|
|
|
|
if type(choice) is types.IntType:
|
|
|
|
|
print(rot(userInput, choice))
|
|
|
|
|
else:
|
|
|
|
|
for i in range(0, 26):
|
|
|
|
|
print(rot(userInput, i))
|
|
|
|
|
choice = input("What kind of ROT do you want to perform? 1-25, or all: ")
|
|
|
|
|
userInput = raw_input("Please insert a string: ")
|
|
|
|
|
if type(choice) is types.IntType:
|
|
|
|
|
print(rot(userInput, choice))
|
|
|
|
|
else:
|
|
|
|
|
for i in range(0, 26):
|
|
|
|
|
print(rot(userInput, i))
|
|
|
|
|
|
|
|
|
|
def translatePrompt():
|
|
|
|
|
print("1: Binary")
|
|
|
|
|
print("2: Decimal")
|
|
|
|
|
print("3: Octal")
|
|
|
|
|
print("4: Hexadecimal")
|
|
|
|
|
print("5: ASCII")
|
|
|
|
|
inputType = input("Please specify input type: ")
|
|
|
|
|
outputType = input("Please specify output type: ")
|
|
|
|
|
if (inputType == 5):
|
|
|
|
|
inputString = raw_input("Please input your strings, seperated by semicolon: ")
|
|
|
|
|
else:
|
|
|
|
|
inputString = raw_input("Please input your values, seperated by semicolon: ")
|
|
|
|
|
|
|
|
|
|
inputList = inputString.split(";")
|
|
|
|
|
for entry in inputList:
|
|
|
|
|
print(translate(entry, inputType, outputType))
|
|
|
|
|
print("1: Binary")
|
|
|
|
|
print("2: Decimal")
|
|
|
|
|
print("3: Octal")
|
|
|
|
|
print("4: Hexadecimal")
|
|
|
|
|
print("5: ASCII")
|
|
|
|
|
inputType = input("Please specify input type: ")
|
|
|
|
|
outputType = input("Please specify output type: ")
|
|
|
|
|
if (inputType == 5):
|
|
|
|
|
inputString = raw_input("Please input your strings, seperated by semicolon: ")
|
|
|
|
|
else:
|
|
|
|
|
inputString = raw_input("Please input your values, seperated by semicolon: ")
|
|
|
|
|
|
|
|
|
|
inputList = inputString.split(";")
|
|
|
|
|
for entry in inputList:
|
|
|
|
|
print(translate(entry, inputType, outputType))
|
|
|
|
|
|
|
|
|
|
def hashPrompt():
|
|
|
|
|
typeChoice = raw_input('Would you like to hash a file or a String? f for file, s for string: ')
|
|
|
|
|
algoList = hashlib.algorithms_available
|
|
|
|
|
for word in algoList:
|
|
|
|
|
print(word)
|
|
|
|
|
algoChoice = raw_input('Which hashing algorithm? ')
|
|
|
|
|
if algoChoice in algoList:
|
|
|
|
|
hasher = hashlib.new(algoChoice)
|
|
|
|
|
else:
|
|
|
|
|
print("That's no algorithm!")
|
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
|
|
|
|
if (typeChoice == 'f'):
|
|
|
|
|
filePath = raw_input('Please input a fully qualified path: ')
|
|
|
|
|
filePath = filePath.strip()
|
|
|
|
|
with open(filePath, 'rb') as hashFile:
|
|
|
|
|
content = hashFile.read()
|
|
|
|
|
hasher.update(content)
|
|
|
|
|
else:
|
|
|
|
|
inputString = raw_input('Please input a string: ')
|
|
|
|
|
hasher.update(inputString)
|
|
|
|
|
print(hasher.hexdigest())
|
|
|
|
|
typeChoice = raw_input('Would you like to hash a file or a String? f for file, s for string: ')
|
|
|
|
|
algoList = hashlib.algorithms_available
|
|
|
|
|
for word in algoList:
|
|
|
|
|
print(word)
|
|
|
|
|
algoChoice = raw_input('Which hashing algorithm? ')
|
|
|
|
|
if algoChoice in algoList:
|
|
|
|
|
hasher = hashlib.new(algoChoice)
|
|
|
|
|
else:
|
|
|
|
|
print("That's no algorithm!")
|
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
|
|
|
|
if (typeChoice == 'f'):
|
|
|
|
|
filePath = raw_input('Please input a fully qualified path: ')
|
|
|
|
|
filePath = filePath.strip()
|
|
|
|
|
with open(filePath, 'rb') as hashFile:
|
|
|
|
|
content = hashFile.read()
|
|
|
|
|
hasher.update(content)
|
|
|
|
|
else:
|
|
|
|
|
inputString = raw_input('Please input a string: ')
|
|
|
|
|
hasher.update(inputString)
|
|
|
|
|
print(hasher.hexdigest())
|
|
|
|
|
|
|
|
|
|
print("Welcome aboard PankiCrypt Airlines!")
|
|
|
|
|
print("How may we serve you today?")
|
|
|
|
@ -135,19 +170,29 @@ print("3: Translation")
|
|
|
|
|
print("4: Base64 Encoder/Decoder")
|
|
|
|
|
print("5: String Reverser")
|
|
|
|
|
print("6: URL Encoder")
|
|
|
|
|
choice = input("Please make a selection: ")
|
|
|
|
|
if (choice == 1):
|
|
|
|
|
rotPrompt()
|
|
|
|
|
elif (choice == 2):
|
|
|
|
|
hashPrompt()
|
|
|
|
|
elif (choice == 3):
|
|
|
|
|
translatePrompt()
|
|
|
|
|
elif(choice == 4):
|
|
|
|
|
base64prompt()
|
|
|
|
|
elif(choice == 5):
|
|
|
|
|
reverser()
|
|
|
|
|
elif(choice == 6):
|
|
|
|
|
urlEncoder()
|
|
|
|
|
print("7: Fixed XOR")
|
|
|
|
|
print("8: XOR Bruteforce Single Byte ")
|
|
|
|
|
choice = raw_input("Please make a selection: ")
|
|
|
|
|
if (choice == "1"):
|
|
|
|
|
rotPrompt()
|
|
|
|
|
elif (choice == "2"):
|
|
|
|
|
hashPrompt()
|
|
|
|
|
elif (choice == "3"):
|
|
|
|
|
translatePrompt()
|
|
|
|
|
elif(choice == "4"):
|
|
|
|
|
base64prompt()
|
|
|
|
|
elif(choice == "5"):
|
|
|
|
|
reverser()
|
|
|
|
|
elif(choice == "6"):
|
|
|
|
|
urlEncoder()
|
|
|
|
|
elif(choice[0] == "7"):
|
|
|
|
|
if(len(choice) > 1):
|
|
|
|
|
argList = choice.split(" ")
|
|
|
|
|
fixedxor(argList[1], argList[2])
|
|
|
|
|
else:
|
|
|
|
|
fixedxor()
|
|
|
|
|
elif(choice == "8"):
|
|
|
|
|
xorSingleBrute()
|
|
|
|
|
|
|
|
|
|
print("Thank you for flying with PankiCrypt Airlines!")
|
|
|
|
|
|
|
|
|
|