X-Git-Url: http://git.tomasm.cz/krypto.git/blobdiff_plain/b07e566bcd38f1792a360ed13a08b70ce3b4b5f4..31b480a285bb43eb2d8254292a2c3619372c4354:/robot.py?ds=sidebyside diff --git a/robot.py b/robot.py index c5ea50b..bebce87 100755 --- a/robot.py +++ b/robot.py @@ -9,6 +9,7 @@ from ocesavac import ocesat import jakobsen from jakobsen import reference import koincidence +import posuny import pickle import os @@ -20,30 +21,44 @@ class settings: settings = pickle.load(open('./robot_settings')) os.chdir(settings.path) +def posli_mail(komu, co, text): + msg = MIMEText(text) + msg['Subject'] = co + msg['From'] = settings.name + " <" + settings.mail + ">" + msg['To'] = komu + smtplib.SMTP('localhost').sendmail(settings.mail, komu, msg.as_string()) + # Cteni mailu mail = email.message_from_file(sys.stdin) predmet, _, opsny = mail['Subject'].strip().upper().partition(' ') odesilatel = mail['From'] if predmet != settings.subject: sys.exit() -if (opsny == 'H'): - msg = MIMEText("Napoveda:\n" - "Pro opakovanou analyzu posledni zpravy zaslete mail s predmetem \"" + - settings.subject + " L\". Na velikosti pismen v predmetu nezalezi." - "\n\nS pozdravem\nVas Robot\n") - msg['Subject'] = "Napoveda" - msg['From'] = settings.name + " <" + settings.mail + ">" - msg['To'] = odesilatel - smtplib.SMTP('localhost').sendmail(settings.mail, odesilatel, msg.as_string()) +if opsny == 'H': + posli_mail(odesilatel, "Napoveda", "Napoveda:\n" + "Prikazy robotovi vkladejte do predmetu zpravy zaslane na adresu " + + settings.mail + ".\nNa velikosti pismen nezalezi." + "\n\nSeznam prikazu:\n" + "\"" + settings.subject + "\" Analyza zpravy z tela mailu.\n" + "\"" + settings.subject + " L\" Opakovana analyza posledni zpravy.\n" + + "\"" + settings.subject + " X\" Vynuti analyzu bez mezer.\n" + "\"" + settings.subject + " M\" Vynuti analyzu s mezerami.\n" + "\"" + settings.subject + " B\" Vypise cetnost vsech bigramu.\n" + "\"" + settings.subject + " P\" Vypise vsechny posunuti textu.\n" + "\"" + settings.subject + " A\" Vypise uplne vsechno co dava " + "alespon trochu smysl (nedoporucuji).\n" + "\"" + settings.subject + " H\" Tato napoveda.\n" + "\nVolby (mimo \"H\") je mozno libovolne kombinovat.\n" + "Napriklad \"" + settings.subject + " LXB\" analyzuje posledni " + "prijatou zpravu s vynucenim analyzy bez mezer a navic vypise " + "cetnosti bigramu.\n" + "\nS pozdravem\nVas Robot\n") sys.exit() -if (opsny == 'L'): +if 'L' in opsny: mail = pickle.load(open('./msg_last.tmp')) if (mail['From'] != odesilatel): - msg = MIMEText("Omlouvam se, ale Vase zprava uz bohuzel neni na serveru ulozena.") - msg['Subject'] = "Omluva" - msg['From'] = settings.name + " <" + settings.mail + ">" - msg['To'] = odesilatel - smtplib.SMTP('localhost').sendmail(settings.mail, odesilatel, msg.as_string()) + posli_mail(odesilatel, "Omluva", "Omlouvam se," + " ale Vase zprava uz bohuzel neni na serveru ulozena.\n") sys.exit() telo = mail.get_payload().strip() if len(telo) < 2: @@ -51,33 +66,39 @@ if len(telo) < 2: zprava = telo.upper() analyza = [] -# Zakladni udaje -analyza.append("Delka zpravy (bez mezer a zvlastnich znaku):") -analyza.append(str(len(ocesat(zprava, False)))) - -# Index koincidence -analyza.append("\nIndexy koincidence:") -analyza.append(koincidence.tabulka_indexu(zprava)) - -# Jakobsen -analyza.append("\nJakobsen:") -analyza.append(jakobsen.desifruj(zprava, './ref')) - -# Posuny v abecede -analyza.append("\nPosuny v abecede:") - -def posun(char): - if 65 <= ord(char) < 90: - return chr(ord(char) + 1) - if ord(char) == 90: - return 'A' +# Puvodni zprava +analyza.append("Puvodni zprava:") +analyza.append(telo) + +# Prepinani spacemodu +mod_m = False +mod_x = False +if 'X' in opsny: + mod_x = True +if 'M' in opsny: + mod_m = True +if 'A' in opsny: + mod_x = True + mod_m = True +if not mod_m and not mod_x: + if ' ' in ocesat(zprava, True): + mod_m = True + analyza.append("\nAutomaticky zvolena analyza s mezerami.") else: - return char + mod_x = True + analyza.append("\nAutomaticky zvolena analyza bez mezer.") + +# Zakladni udaje +analyza.append("\nZakladni udaje:") +if mod_m: + analyza.append("Delka zpravy (vcetne mezer a zvlastnich znaku): " + str(len(zprava))) +analyza.append("Delka zpravy (bez mezer a zvlastnich znaku): " + str(len(ocesat(zprava, False)))) -posunuty = zprava -for i in range(26): - posunuty = map(posun, posunuty) - analyza.append(''.join(posunuty)) +# Prumerna delka slova +if mod_m: + analyza.append("\nPrumerna delka slova:") + slova = ocesat(zprava, True).split() + analyza.append('{0:.3}'.format(float(sum([len(word) for word in slova]))/len(slova))) # Frekvence znaku analyza.append("\nFrekvencni analyza:") @@ -92,27 +113,52 @@ for char in sorted(freq, key=freq.get, reverse=True): analyza.append('{0} {1:>3} {2:>6.2%}'.format(char, freq[char], float(freq[char])/celkem)) +# Index koincidence +# TODO verze s mezerami +analyza.append("\nIndexy koincidence (vzdy bez mezer):") +analyza.append(koincidence.tabulka_indexu(zprava)) + +# Jakobsen +if mod_m: + analyza.append("\nJakobsen (s mezerami):") + analyza.append(jakobsen.desifruj(zprava, './ref')) +if mod_x: + analyza.append("\nJakobsen (bez mezer):") + analyza.append(jakobsen.desifruj(zprava, './bref')) + +# Posuny v abecede +(posun, posunuty_text) = posuny.nejlepsi(zprava) +analyza.append("\nNejlepsi posun ({0}):".format(posun)) +analyza.append(posunuty_text) + +if 'P' in opsny or 'A' in opsny: + analyza.append("\nPosuny v abecede:") + analyza.append(posuny.vsechny(zprava)) + # Bigramy -analyza.append("\nBigramy podle cetnosti:") -bigramy = dict() -for i in ABECEDA: - for j in ABECEDA: - bigramy[i+j] = 0 -for i in range(0, len(zprava)-1): - if zprava[i:i+2] in bigramy: - bigramy[zprava[i:i+2]] += 1 -celkem = sum(bigramy.values()) -for char in sorted(bigramy, key=bigramy.get, reverse=True): - if bigramy[char] == 0: - break - analyza.append('{0} {1:>3} {2:>6.2%}'.format(char, bigramy[char], - float(bigramy[char])/celkem)) +if ('B' in opsny or 'A' in opsny): + analyza.append("\nBigramy podle cetnosti:") + bigramy = dict() + for i in ABECEDA: + for j in ABECEDA: + bigramy[i+j] = 0 + for i in range(0, len(zprava)-1): + if zprava[i:i+2] in bigramy: + bigramy[zprava[i:i+2]] += 1 + celkem = sum(bigramy.values()) + for char in sorted(bigramy, key=bigramy.get, reverse=True): + if bigramy[char] == 0: + break + analyza.append('{0} {1:>3} {2:>6.2%}'.format(char, bigramy[char], + float(bigramy[char])/celkem)) + +# Podpis a pozdrav +analyza.append(''.join(["\nS pozdravem\nVas Robot\n" + "\n--\nPro napovedu zaslete mail s predmetem \"", + settings.subject," H\".\n"])) # Kompozice odpovedi -msg = MIMEText("Puvodni zprava:\n" + - telo + "\n\n" + "\n".join(analyza) + - "\n\nS pozdravem\nVas Robot\n\n--\nPro napovedu zaslete mail s predmetem \"" + - settings.subject + " H\".") +msg = MIMEText("\n".join(analyza)) msg['Subject'] = "Analyza Vasi zpravy" msg['From'] = settings.name + " <" + settings.mail + ">" msg['To'] = odesilatel