mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 15:58:57 +00:00 
			
		
		
		
	 a9c6e0618f
			
		
	
	
		a9c6e0618f
		
			
		
	
	
	
	
		
			
			Here we are doing no more than adding the value for Py_mod_multiple_interpreters and using it for stdlib modules. We will start checking for it in gh-104206 (once PyInterpreterState.ceval.own_gil is added in gh-104204).
		
			
				
	
	
		
			81 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 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[] = {
 | |
|     {Py_mod_multiple_interpreters, Py_MOD_PER_INTERPRETER_GIL_SUPPORTED},
 | |
|     {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);
 | |
| }
 |