2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
:mod:`crypt` --- Function to check Unix passwords
|
|
|
|
=================================================
|
|
|
|
|
|
|
|
.. module:: crypt
|
|
|
|
:platform: Unix
|
|
|
|
:synopsis: The crypt() function used to check Unix passwords.
|
|
|
|
.. moduleauthor:: Steven D. Majewski <sdm7g@virginia.edu>
|
|
|
|
.. sectionauthor:: Steven D. Majewski <sdm7g@virginia.edu>
|
|
|
|
.. sectionauthor:: Peter Funk <pf@artcom-gmbh.de>
|
|
|
|
|
|
|
|
|
|
|
|
.. index::
|
|
|
|
single: crypt(3)
|
|
|
|
pair: cipher; DES
|
|
|
|
|
|
|
|
This module implements an interface to the :manpage:`crypt(3)` routine, which is
|
|
|
|
a one-way hash function based upon a modified DES algorithm; see the Unix man
|
|
|
|
page for further details. Possible uses include allowing Python scripts to
|
|
|
|
accept typed passwords from the user, or attempting to crack Unix passwords with
|
|
|
|
a dictionary.
|
|
|
|
|
|
|
|
.. index:: single: crypt(3)
|
|
|
|
|
|
|
|
Notice that the behavior of this module depends on the actual implementation of
|
|
|
|
the :manpage:`crypt(3)` routine in the running system. Therefore, any
|
|
|
|
extensions available on the current implementation will also be available on
|
|
|
|
this module.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: crypt(word, salt)
|
|
|
|
|
|
|
|
*word* will usually be a user's password as typed at a prompt or in a graphical
|
|
|
|
interface. *salt* is usually a random two-character string which will be used
|
|
|
|
to perturb the DES algorithm in one of 4096 ways. The characters in *salt* must
|
|
|
|
be in the set ``[./a-zA-Z0-9]``. Returns the hashed password as a string, which
|
|
|
|
will be composed of characters from the same alphabet as the salt (the first two
|
|
|
|
characters represent the salt itself).
|
|
|
|
|
|
|
|
.. index:: single: crypt(3)
|
|
|
|
|
|
|
|
Since a few :manpage:`crypt(3)` extensions allow different values, with
|
|
|
|
different sizes in the *salt*, it is recommended to use the full crypted
|
|
|
|
password as salt when checking for a password.
|
|
|
|
|
|
|
|
A simple example illustrating typical use::
|
|
|
|
|
2009-02-19 23:31:23 -04:00
|
|
|
import crypt, getpass, pwd
|
2007-08-15 11:28:01 -03:00
|
|
|
|
|
|
|
def login():
|
|
|
|
username = raw_input('Python login:')
|
|
|
|
cryptedpasswd = pwd.getpwnam(username)[1]
|
|
|
|
if cryptedpasswd:
|
2009-01-03 16:55:06 -04:00
|
|
|
if cryptedpasswd == 'x' or cryptedpasswd == '*':
|
2009-06-03 04:25:35 -03:00
|
|
|
raise NotImplementedError(
|
|
|
|
"Sorry, currently no support for shadow passwords")
|
2007-08-15 11:28:01 -03:00
|
|
|
cleartext = getpass.getpass()
|
|
|
|
return crypt.crypt(cleartext, cryptedpasswd) == cryptedpasswd
|
|
|
|
else:
|
|
|
|
return 1
|
|
|
|
|