forked from karma9874/CTF-CryptoTool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdecoder.py
180 lines (152 loc) · 7.35 KB
/
decoder.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
import re
from Utils.functions import *
from pycipher import *
from colorama import Fore, Style,init
banner="""
_____ ___________ _____ _ _____ _
/ __ \_ _| ___| / __ \ | | |_ _| | |
| / \/ | | | |_ ______| / \/_ __ _ _ _ __ | |_ ___ | | ___ ___ | |
| | | | | _|______| | | '__| | | | '_ \| __/ _ \| |/ _ \ / _ \| |
| \__/\ | | | | | \__/\ | | |_| | |_) | || (_) | | (_) | (_) | |
\____/ \_/ \_| \____/_| \__, | .__/ \__\___/\_/\___/ \___/|_|
__/ | |
|___/|_|
"""
print(Style.BRIGHT+Fore.GREEN+banner+Fore.RESET)
string = input("Enter the text : ")
key = input("Enter Key (if none press enter): ")
flag = input("Enter flag (if none press enter): ")
if flag==None:
flag=""
ic=getIC(string)
print('ic',ic)
result=""
if not key:
if set(string).issubset({'0', '1',' '}):
res=bin(string)
if res:
pretty_print("Possible Binary",res)
#print(Fore.YELLOW+"\nPossible Binary : ",Style.BRIGHT+Fore.GREEN+bin(string)+Fore.RESET)
if len(string)%8==0 or string[-1]=="=" and any(x not in string for x in b_32):
res=b32(string)
if res:
pretty_print("Possible Base32",res)
#print(Fore.YELLOW+"\nPossible Base32 : ",Fore.GREEN+b32(string)+Fore.RESET)
if len(string)%4==0 or string[-1]== '=' and len(set(string))<=65:
res = b64(string)
if res:
pretty_print("Possible Base64",res)
if ('I' not in string) and ('O' not in string) and ('l' not in string) and (len(set(string)) < 58) and ('0' not in string):
res = b58(string)
if res:
pretty_print("Possible Base58", res)
if set(string).issubset({'-', '.','/'," "}):
res = morse(string,flag)
pretty_print("Possible Morse",res)
if re.search(r'[0-9a-fA-F]+',string):
res = hex(string)
if res:
pretty_print("Possible Hex",res)
if b85Checker(string):
res = b85(string)
if res:
pretty_print("Possible Base85",res)
if b91check(string):
res = b91(string)
if res:
pretty_print("Possible Base91",res)
s = string.split(' ')
if s[0] == s[4]:
res = unary_decode(s)
if res:
pretty_print("Possible Chuck Norris Unary Code",res)
if re.search(r'^[1-9]+$',string):
print(Fore.YELLOW+"\nPossible Morbit ")
morbit(string,flag)
if re.search(r"^[0-7\s]+$",string):
res = octal(string)
if res:
pretty_print("Possible Octal",res)
if set(string).issubset({">","<","+","-",".","[","]"," "}):
pretty_print("Possible brainfuck","https://www.dcode.fr/brainfuck-language")
if set(string).issubset({"Ook.","Ook?","Ook!"}):
pretty_print("Possible ook","https://www.dcode.fr/ook-language")
if set(string).issubset({"(","!","[","]","+",")"}):
pretty_print("Possible Jsfuck","https://enkhee-osiris.github.io/Decoder-JSFuck/")
if ic != None and ic[0] > 0.02:
print(Fore.YELLOW+"\nPossible Keyboard Shift Cipher"+Fore.RESET)
# a,b,c,d = keyboard_cipher(string)
# print("Right Shift :",Fore.GREEN+''.join(a)+Fore.RESET)
# print("Left Shift :",Fore.GREEN+''.join(b)+Fore.RESET)
# print("Up Shift :",Fore.GREEN+''.join(c)+Fore.RESET)
# print("Down Shift :",Fore.GREEN+''.join(d)+Fore.RESET)
max_key = break_caesar(string)
if flag.lower() in Caesar(max_key[1]).decipher(string).lower():
print(Fore.YELLOW+"\nPossible Caesar Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Caesar(max_key[1]).decipher(string)+Fore.RESET,"Key:",Fore.BLUE+str(max_key[1]))
if flag.lower() in atbash(string).lower():
print(Fore.YELLOW+"\nPossible Atbash Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,atbash(string))
print(Fore.YELLOW+"\nPossible Vigenere Cipher")
break_3(string,"v",flag)
print(Fore.YELLOW+"\nPossible Beaufort Cipher")
break_3(string,"b",flag)
print(Fore.YELLOW+"\nPossible Gronsfeld Cipher")
break_gronsfeld(string,flag)
max_key = break_caesar(string)
max_key = break_affine(string)
if flag.lower() in Affine(max_key[1][0],max_key[1][1]).decipher(string).lower():
print(Fore.YELLOW+"\nPossible Affine Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Affine(max_key[1][0],max_key[1][1]).decipher(string)+Fore.RESET,"Key:",Fore.BLUE+str(max_key))
print(Fore.YELLOW+"\nPossible ROT Cipher\nBreaking ROT")
for i in range(2,30):
if flag.lower() in rotN(string,i).lower():
print(Fore.YELLOW+"Decoded String:",Fore.GREEN+rotN(string,i)+Fore.RESET,Fore.BLUE+"Rot"+str(i))
max_key = break_railfence(string)
if flag.lower() in Railfence(max_key[1]).decipher(string).lower():
print(Fore.YELLOW+"\nPossible Railfence Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Railfence(max_key[1]).decipher(string)+Fore.RESET,"Key:",Fore.BLUE+str(max_key[1]))
print(Fore.YELLOW+"\nPossible Autokey Cipher")
break_3(string,"a",flag)
print(Fore.YELLOW+"\nPossible Substitution Cipher","use quipquip")
else:
string=string.lower().replace(" ","")
print(string)
if len(key)==1 and key.isdigit():
print(Fore.YELLOW+"\nPossible Caesar Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Caesar(key).decipher(string))
print(Fore.YELLOW+"\nPossible Railfence Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Railfence(key).decipher(string))
if key.isalpha():
print(Fore.YELLOW+"\nPossible Vigenere Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Vigenere(key).decipher(string))
print(Fore.YELLOW+"\nPossible Beaufort Cipher"+Fore.RESET,"Decoded String:"+Fore.GREEN,Beaufort(key).decipher(string))
if all(isinstance(item, int) for item in key):
print(Fore.YELLOW+"\nPossible Gronsfeld Cipher"+Fore.RESET,"Decoded String:",Gronsfeld(list(key)).decipher(string))
if " " in key:
key_set - key.split(" ")
print(Fore.YELLOW+"\nPossible Affine Cipher"+Fore.RESET,"Decoded String:",Affine(key_set[0],key_set[1]).decipher(string))
print(Fore.YELLOW+"\nPossible Autokey Cipher"+Fore.RESET,"Decoded String:",Autokey(key).decipher(string))
if len(key)==26:
print(Fore.YELLOW+"\nPossible Substitution Cipher"+Fore.RESET,"Decoded String:",SimpleSubstitution(key).decipher(string))
if len(key)==25:
print(Fore.YELLOW+"\nPossible playfair Cipher"+Fore.RESET,"Decoded String:",Playfair(key).decipher(string))
#print("\nPossible Polybius Cipher","Decoded String:",Polybius(key).decipher(string))
#nGmni Tskcxipo esdskkxgmejvc
# if ic[0] < 0.055 and ic[0] >= 0.035 :
# max_key = break_caesar(string)
# if flag in Caesar(max_key[1]).decipher(string):
# print("Possible Caesar Cipher","Decoded String:",Caesar(max_key[1]).decipher(string),"Key:",max_key[1])
# # else:
# # if mode:
# # print("Possible Caesar Cipher","Decoded String:",Caesar(max_key[1]).decipher(string),"Key:",max_key[1])
# print("Possible Vigenere Cipher")
# break_3(string,"v",flag)
# print("Possible Beaufort Cipher")
# break_3(string,"b",flag)
# print("Possible Gronsfeld Cipher")
# break_gronsfeld(string,flag)
# elif ic[0]>=0.06:
# max_key = break_caesar(string)
# if flag in Caesar(max_key[1]).decipher(string):
# print("Possible Caesar Cipher","Decoded String:",Caesar(max_key[1]).decipher(string),"Key:",max_key[1])
# max_key = break_affine(string)
# if flag in Affine(max_key[1][0],max_key[1][1]).decipher(string):
# print("Possible Affine Cipher","Decoded String:",Affine(max_key[1][0],max_key[1][1]).decipher(string),"Key:",max_key)
# print("Possible ROT Cipher\nBreaking ROT")
# for i in range(2,30):
# if flag in rotN(string,i):
# print("Decoded String:",rotN(string,i),"Rot"+str(i))