X-Git-Url: http://git.tomasm.cz/krypto.git/blobdiff_plain/f720357e2d85ae63be06219eb784a588891b1fd8..d7c8d3913bbc5a2119789f1d82c2f3de3f3fa1f3:/robot.py diff --git a/robot.py b/robot.py index daad9b8..21d297a 100755 --- a/robot.py +++ b/robot.py @@ -22,12 +22,16 @@ class settings: settings = pickle.load(open('./robot_settings')) os.chdir(settings.path) -def posli_mail(komu, co, text): +def posli_mail(komu, co, text, loguj=None): 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()) + if loguj: + f = open(loguj, 'w') + f.write(msg.as_string()) + f.close() # Cteni mailu mail = email.message_from_file(sys.stdin) @@ -72,7 +76,9 @@ if 'L' in opsny: " ale Vase zprava uz bohuzel neni na serveru ulozena.\n") sys.exit() telo = mail.get_payload().strip() -if len(telo) < 2: +if len(ocesat(telo, False)) < 2: + posli_mail(odesilatel, "Omluva", "Omlouvam se," + " ale Vase zprava je prilis kratka.\n") sys.exit() zprava = telo.upper() analyza = [] @@ -92,7 +98,7 @@ if 'A' in opsny: mod_x = True mod_m = True if not mod_m and not mod_x: - if ' ' in ocesat(zprava, True): + if ' ' in ocesat(zprava, True)[1:-1]: mod_m = True analyza.append("\nAutomaticky zvolena analyza s mezerami.") else: @@ -125,23 +131,26 @@ for char in sorted(freq, key=freq.get, reverse=True): float(freq[char])/celkem)) # Index koincidence -# TODO verze s mezerami -analyza.append("\nIndexy koincidence (vzdy bez mezer):") -analyza.append(koincidence.tabulka_indexu(zprava)) +if mod_m: + analyza.append("\nIndex koincidence (s mezerami):") + analyza.append('{0:.2%}'.format(koincidence.index_koincidence(zprava, True))) +if mod_x: + analyza.append("\nIndexy koincidence (bez mezer):") + analyza.append(koincidence.tabulka_indexu(zprava)) # Jakobsen if mod_m: analyza.append("\nJakobsen (s mezerami):") - analyza.append(jakobsen.desifruj(zprava, './ref')) + analyza.append(jakobsen.desifruj(zprava)) if mod_x: analyza.append("\nJakobsen (bez mezer):") - analyza.append(jakobsen.desifruj(zprava, './bref')) + analyza.append(jakobsen.desifruj(zprava, False)) # Posuny v abecede (posun, posunuty_text) = posuny.nejlepsi(zprava) if 'P' in opsny or 'A' in opsny: analyza.append("\nPosuny v abecede (nejlepsi posun {0}):".format(posun)) - analyza.append("\n".join("{0} {1}".format(i + 1, posuny.vsechny(zprava)[i]) for i in range(26))) + analyza.append("\n".join("{0:>2} {1}".format(i + 1, posuny.vsechny(zprava)[i]) for i in range(26))) else: analyza.append("\nNejlepsi posun ({0}):".format(posun)) analyza.append(posunuty_text) @@ -168,21 +177,8 @@ analyza.append(''.join(["\nS pozdravem\nVas Robot\n" "\n--\nPro napovedu zaslete mail s predmetem \"", settings.subject," H\".\n"])) -# Kompozice odpovedi -msg = MIMEText("\n".join(analyza)) -msg['Subject'] = "Analyza Vasi zpravy" -msg['From'] = settings.name + " <" + settings.mail + ">" -msg['To'] = odesilatel - # Odeslani odpovedi -s = smtplib.SMTP('localhost') -s.sendmail(settings.mail, odesilatel, msg.as_string()) -s.quit() - -# Zalogovani posledni zpravy -f = open('./robot_last.tmp', 'w') -f.write(msg.as_string()) -f.close() +posli_mail(odesilatel, "Analyza Vasi zpravy", "\n".join(analyza), './robot_last.tmp') f = open('./msg_last.tmp', 'w') pickle.dump(mail, f)