mirror of
https://github.com/python/cpython.git
synced 2024-11-24 02:15:30 +08:00
2623c8c23c
The new syntax is highly human readable while still preventing false positives. The syntax also extends Python syntax to denote "self" and positional-only parameters, allowing inspect.Signature objects to be totally accurate for all supported builtins in Python 3.4.
99 lines
2.3 KiB
C
99 lines
2.3 KiB
C
/* cryptmodule.c - by Steve Majewski
|
|
*/
|
|
|
|
#include "Python.h"
|
|
|
|
#include <sys/types.h>
|
|
|
|
/* Module crypt */
|
|
|
|
/*[clinic input]
|
|
module crypt
|
|
[clinic start generated code]*/
|
|
/*[clinic end generated code: output=da39a3ee5e6b4b0d input=c6252cf4f2f2ae81]*/
|
|
|
|
|
|
/*[clinic input]
|
|
crypt.crypt
|
|
|
|
word: 's'
|
|
salt: 's'
|
|
/
|
|
|
|
Hash a *word* with the given *salt* and return the hashed password.
|
|
|
|
*word* will usually be a user's password. *salt* (either a random 2 or 16
|
|
character string, possibly prefixed with $digit$ to indicate the method)
|
|
will be used to perturb the encryption algorithm and produce distinct
|
|
results for a given *word*.
|
|
|
|
[clinic start generated code]*/
|
|
|
|
PyDoc_STRVAR(crypt_crypt__doc__,
|
|
"crypt($module, word, salt, /)\n"
|
|
"--\n"
|
|
"\n"
|
|
"Hash a *word* with the given *salt* and return the hashed password.\n"
|
|
"\n"
|
|
"*word* will usually be a user\'s password. *salt* (either a random 2 or 16\n"
|
|
"character string, possibly prefixed with $digit$ to indicate the method)\n"
|
|
"will be used to perturb the encryption algorithm and produce distinct\n"
|
|
"results for a given *word*.");
|
|
|
|
#define CRYPT_CRYPT_METHODDEF \
|
|
{"crypt", (PyCFunction)crypt_crypt, METH_VARARGS, crypt_crypt__doc__},
|
|
|
|
static PyObject *
|
|
crypt_crypt_impl(PyModuleDef *module, const char *word, const char *salt);
|
|
|
|
static PyObject *
|
|
crypt_crypt(PyModuleDef *module, PyObject *args)
|
|
{
|
|
PyObject *return_value = NULL;
|
|
const char *word;
|
|
const char *salt;
|
|
|
|
if (!PyArg_ParseTuple(args,
|
|
"ss:crypt",
|
|
&word, &salt))
|
|
goto exit;
|
|
return_value = crypt_crypt_impl(module, word, salt);
|
|
|
|
exit:
|
|
return return_value;
|
|
}
|
|
|
|
static PyObject *
|
|
crypt_crypt_impl(PyModuleDef *module, const char *word, const char *salt)
|
|
/*[clinic end generated code: output=3eaacdf994a6ff23 input=4d93b6d0f41fbf58]*/
|
|
{
|
|
/* On some platforms (AtheOS) crypt returns NULL for an invalid
|
|
salt. Return None in that case. XXX Maybe raise an exception? */
|
|
return Py_BuildValue("s", crypt(word, salt));
|
|
}
|
|
|
|
|
|
static PyMethodDef crypt_methods[] = {
|
|
CRYPT_CRYPT_METHODDEF
|
|
{NULL, NULL} /* sentinel */
|
|
};
|
|
|
|
|
|
static struct PyModuleDef cryptmodule = {
|
|
PyModuleDef_HEAD_INIT,
|
|
"_crypt",
|
|
NULL,
|
|
-1,
|
|
crypt_methods,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
};
|
|
|
|
PyMODINIT_FUNC
|
|
PyInit__crypt(void)
|
|
{
|
|
return PyModule_Create(&cryptmodule);
|
|
}
|