diff options
author | Devtools Arcadia <arcadia-devtools@yandex-team.ru> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /contrib/tools/python3/src/Modules/_cryptmodule.c | |
download | ydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'contrib/tools/python3/src/Modules/_cryptmodule.c')
-rw-r--r-- | contrib/tools/python3/src/Modules/_cryptmodule.c | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/contrib/tools/python3/src/Modules/_cryptmodule.c b/contrib/tools/python3/src/Modules/_cryptmodule.c new file mode 100644 index 0000000000..72a4f44600 --- /dev/null +++ b/contrib/tools/python3/src/Modules/_cryptmodule.c @@ -0,0 +1,80 @@ +/* cryptmodule.c - by Steve Majewski + */ + +#include "Python.h" + +#include <sys/types.h> +#ifdef HAVE_CRYPT_H +#include <crypt.h> +#endif + +/* Module crypt */ + +/*[clinic input] +module crypt +[clinic start generated code]*/ +/*[clinic end generated code: output=da39a3ee5e6b4b0d input=c6252cf4f2f2ae81]*/ + +#include "clinic/_cryptmodule.c.h" + +/*[clinic input] +crypt.crypt + + word: str + salt: str + / + +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]*/ + +static PyObject * +crypt_crypt_impl(PyObject *module, const char *word, const char *salt) +/*[clinic end generated code: output=0512284a03d2803c input=0e8edec9c364352b]*/ +{ + char *crypt_result; +#ifdef HAVE_CRYPT_R + struct crypt_data data; + memset(&data, 0, sizeof(data)); + crypt_result = crypt_r(word, salt, &data); +#else + crypt_result = crypt(word, salt); +#endif + if (crypt_result == NULL) { + return PyErr_SetFromErrno(PyExc_OSError); + } + return Py_BuildValue("s", crypt_result); +} + + +static PyMethodDef crypt_methods[] = { + CRYPT_CRYPT_METHODDEF + {NULL, NULL} /* sentinel */ +}; + +static PyModuleDef_Slot _crypt_slots[] = { + {0, NULL} +}; + +static struct PyModuleDef cryptmodule = { + PyModuleDef_HEAD_INIT, + "_crypt", + NULL, + 0, + crypt_methods, + _crypt_slots, + NULL, + NULL, + NULL +}; + +PyMODINIT_FUNC +PyInit__crypt(void) +{ + return PyModuleDef_Init(&cryptmodule); +} |