PDA

View Full Version : [Python][Style] Password Chart


shinya
14-07-2011, 09:44
Buondì!
Siccome sto rimettendo le mani su python così per scherzo, sto scrivendo qualche programmino del cazzo giusto per esercitarmi nel nuovo idioma.

# pwdchart.py
# Script per la creazione di password da una tabella di encoding
# generata tramite una passphrase.
# Mima il comportamento di passwordchart ( http://passwordchart.com/ )

import sys, random, hashlib

def hash_of(string, algorithm="sha1"):
""" Restituisce l'hash (default sha1) di una stringa. """

h = hashlib.new(algorithm)
h.update(string)
return h.digest()

def build_encoding_table(bytes):
""" Restituisce la tabella di encoding. """

random.seed(bytes)
table = {}
alphabet = ("abcdefghijklmnopqrstuvwxyz"
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"0123456789,;[]{}@!?$%()+-_")

for k in "abcdefghijklmnopqrstuvwxyz0123456789._ ":
length = random.randint(1, 3)
table[k] = ''.join(random.sample(alphabet, length))

return table

def gen_passwords(table, keys):
""" Restituisce una password per ogni chiave in 'keys'. """

for key in keys:
password = ''.join([table[char] for char in key.lower()])
yield password

if __name__ == '__main__':
if len(sys.argv) < 2:
print "Y U NO INSERT PASSPHRASE!?"
sys.exit(0)

passphrase = sys.argv[1]
encoding_table = build_encoding_table(hash_of(passphrase))

if len(sys.argv) < 3:
for k, v in sorted(encoding_table.iteritems()):
print "{0}: '{1}'".format(k, v)
else:
for password in gen_passwords(encoding_table, sys.argv[2:]):
print password
E' una versione da console di passwordchart.com (http://passwordchart.com/): prende in input una passphrase con la quale genera un dictionary di corrispondenze 'simbolo' -> 'caratteri', che viene poi usato per convertire una o più password (opzionali da riga di comando) in una versione più offuscata. Ma se guardate il sito fate prima, è una cazzata...

Domande:
1) c'è un modo più idiomatico e pythonesco di scrivere quello che ho scritto? Fa cagare? Cosa può essere migliorato?

2) Esiste un modo furbo per stampare il contenuto di un dictionary in modo "tabellare"? Non so, magari qualche pattern per format() che ignoro...
Per intenderci, qualcosa tipo:

: 'wf' .: '%p' 0: 'HX'
1: 's' 2: 'cg' 3: 'l@R'
4: 'c?' 5: 'hX' 6: 'O'
7: '0u7' 8: 'XhD' 9: 'xr4'
_: 'w-' a: 'L$' b: 'ZlQ'
...ecc...
Un pythonista come lo farebbe?

cdimauro
14-07-2011, 13:08
A voler essere proprio pignoli, al posto di
''.join([table[char] for char in key.lower()])
userei:
''.join(table[char] for char in key.lower())
Quindi usando una generator expression anziché una list comprehension (è inutile generare una lista che subito dopo dev'essere distrutta).

Per il resto tanto di cappello: mi sembra codice scritto da un programmatore Python navigato. :p

Riguardo al secondo punto non ti so dire. Puoi provare a smanettare col modulo pprint (http://docs.python.org/library/pprint.html), ma non credo risolva il tuo problema.

banryu79
14-07-2011, 13:46
Ok, e ora la vera sfida: postaci una versione abbastanza offuscata di quel codice Python :D

shinya
14-07-2011, 16:09
A voler essere proprio pignoli, al posto di
''.join([table[char] for char in key.lower()])
userei:
''.join(table[char] for char in key.lower())
Quindi usando una generator expression anziché una list comprehension (è inutile generare una lista che subito dopo dev'essere distrutta).

Ah ecco vedi... figata! :eek:
Riguardo al secondo punto non ti so dire. Puoi provare a smanettare col modulo pprint (http://docs.python.org/library/pprint.html), ma non credo risolva il tuo problema.
Do un'occhiata, grazie... ma mi pare sia più la fatica del gusto in questo caso :)
Ok, e ora la vera sfida: postaci una versione abbastanza offuscata di quel codice Python :D
Fosse stato un esercizio scolastico, mi sarei fatto lo scherzo da solo per principio! :Prrr:
Ma purtroppo la scuola è finita... :cry:

banryu79
14-07-2011, 17:38
gusto in questo caso :)
Fosse stato un esercizio scolastico, mi sarei fatto lo scherzo da solo per principio! :Prrr:
Ma purtroppo la scuola è finita... :cry:
Giusto, mi ero scordato della tua inclinazione da troll-killer :asd:

cdimauro
14-07-2011, 19:00
Ok, e ora la vera sfida: postaci una versione abbastanza offuscata di quel codice Python :D
Il supplizio quotidiano è avere a che fare con Java, i generic, le classi anonime, e in generale una verbosità da far venire i crampi dello scrivano solo a guardare il codice.

Per cui almeno con Python fammi tornare a sognare. :p

banryu79
15-07-2011, 08:22
Per cui almeno con Python fammi tornare a sognare. :p
Beh, la versione offuscata sarebbe una sfida proprio perchè Python ha un'alta leggibilità e ha l'identazione forzata (niente codice del simultatore di volo a forma d'aereo, per esempio)

shinya
15-07-2011, 08:32
Beh, la versione offuscata sarebbe una sfida proprio perchè Python ha un'alta leggibilità e ha l'identazione forzata (niente codice del simultatore di volo a forma d'aereo, per esempio)
Qui c'è qualche spunto di riflessione:
http://c2.com/cgi/wiki?ObfuscatedPython
:fagiano:

banryu79
15-07-2011, 08:59
Qui c'è qualche spunto di riflessione:
http://c2.com/cgi/wiki?ObfuscatedPython
:fagiano:
Infatti introduce il discorso con un: "Not easy, but clearly possible."
Voglio la versione troll-killer! :fagiano:

cdimauro
15-07-2011, 13:02
Basta prendere un programmatore Perl e metterlo a scrivere in Python com'è abituato a fare. :asd: