| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Written in 2013 by Dmitry Chestnykh <dmitry@codingrobots.com> | 
					
						
							|  |  |  |  * Modified for CPython by Christian Heimes <christian@python.org> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * To the extent possible under law, the author have dedicated all | 
					
						
							|  |  |  |  * copyright and related and neighboring rights to this software to | 
					
						
							|  |  |  |  * the public domain worldwide. This software is distributed without | 
					
						
							|  |  |  |  * any warranty. http://creativecommons.org/publicdomain/zero/1.0/
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* WARNING: autogenerated file!
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The blake2s_impl.c is autogenerated from blake2s_impl.c. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-22 16:36:28 +03:00
										 |  |  | #ifndef Py_BUILD_CORE_BUILTIN
 | 
					
						
							|  |  |  | #  define Py_BUILD_CORE_MODULE 1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-16 00:53:38 +01:00
										 |  |  | #include <stdbool.h>
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | #include "Python.h"
 | 
					
						
							| 
									
										
										
										
											2022-03-05 17:47:00 +02:00
										 |  |  | #include "pycore_strhex.h"       // _Py_strhex()
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "../hashlib.h"
 | 
					
						
							| 
									
										
										
										
											2022-03-26 21:52:24 +02:00
										 |  |  | #include "blake2module.h"
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-26 21:52:24 +02:00
										 |  |  | #ifndef HAVE_LIBB2
 | 
					
						
							| 
									
										
										
										
											2017-10-24 08:54:19 +02:00
										 |  |  | /* pure SSE2 implementation is very slow, so only use the more optimized SSSE3+
 | 
					
						
							|  |  |  |  * https://bugs.python.org/issue31834 */
 | 
					
						
							|  |  |  | #if defined(__SSSE3__) || defined(__SSE4_1__) || defined(__AVX__) || defined(__XOP__)
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | #include "impl/blake2s.c"
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #include "impl/blake2s-ref.c"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-03-26 21:52:24 +02:00
										 |  |  | #endif // !HAVE_LIBB2
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-26 21:52:24 +02:00
										 |  |  | #define HAVE_BLAKE2S 1
 | 
					
						
							| 
									
										
										
										
											2022-03-05 17:47:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 04:45:13 -05:00
										 |  |  | extern PyType_Spec blake2s_type_spec; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-26 21:52:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | typedef struct { | 
					
						
							|  |  |  |     PyObject_HEAD | 
					
						
							|  |  |  |     blake2s_param    param; | 
					
						
							|  |  |  |     blake2s_state    state; | 
					
						
							| 
									
										
										
										
											2023-11-16 00:53:38 +01:00
										 |  |  |     bool use_mutex; | 
					
						
							|  |  |  |     PyMutex mutex; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | } BLAKE2sObject; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "clinic/blake2s_impl.c.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | module _blake2 | 
					
						
							|  |  |  | class _blake2.blake2s "BLAKE2sObject *" "&PyBlake2_BLAKE2sType" | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | [clinic start generated code]*/ | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | /*[clinic end generated code: output=da39a3ee5e6b4b0d input=4b79d7ffe07286ce]*/ | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static BLAKE2sObject * | 
					
						
							|  |  |  | new_BLAKE2sObject(PyTypeObject *type) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     BLAKE2sObject *self; | 
					
						
							|  |  |  |     self = (BLAKE2sObject *)type->tp_alloc(type, 0); | 
					
						
							| 
									
										
										
										
											2023-11-16 00:53:38 +01:00
										 |  |  |     if (self == NULL) { | 
					
						
							|  |  |  |         return NULL; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-11-16 00:53:38 +01:00
										 |  |  |     HASHLIB_INIT_MUTEX(self); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     return self; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							|  |  |  | @classmethod | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2.blake2s.__new__ as py_blake2s_new | 
					
						
							|  |  |  |     data: object(c_default="NULL") = b'' | 
					
						
							|  |  |  |     / | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     * | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  |     digest_size: int(c_default="BLAKE2S_OUTBYTES") = _blake2.blake2s.MAX_DIGEST_SIZE | 
					
						
							|  |  |  |     key: Py_buffer(c_default="NULL", py_default="b''") = None | 
					
						
							|  |  |  |     salt: Py_buffer(c_default="NULL", py_default="b''") = None | 
					
						
							|  |  |  |     person: Py_buffer(c_default="NULL", py_default="b''") = None | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     fanout: int = 1 | 
					
						
							|  |  |  |     depth: int = 1 | 
					
						
							| 
									
										
										
										
											2018-07-26 13:22:16 +03:00
										 |  |  |     leaf_size: unsigned_long = 0 | 
					
						
							|  |  |  |     node_offset: unsigned_long_long = 0 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     node_depth: int = 0 | 
					
						
							|  |  |  |     inner_size: int = 0 | 
					
						
							|  |  |  |     last_node: bool = False | 
					
						
							| 
									
										
										
										
											2019-09-13 02:30:00 +02:00
										 |  |  |     usedforsecurity: bool = True | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Return a new BLAKE2s hash object. | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | py_blake2s_new_impl(PyTypeObject *type, PyObject *data, int digest_size, | 
					
						
							|  |  |  |                     Py_buffer *key, Py_buffer *salt, Py_buffer *person, | 
					
						
							| 
									
										
										
										
											2018-07-26 13:22:16 +03:00
										 |  |  |                     int fanout, int depth, unsigned long leaf_size, | 
					
						
							|  |  |  |                     unsigned long long node_offset, int node_depth, | 
					
						
							| 
									
										
										
										
											2019-09-13 02:30:00 +02:00
										 |  |  |                     int inner_size, int last_node, int usedforsecurity) | 
					
						
							|  |  |  | /*[clinic end generated code: output=556181f73905c686 input=4dda87723f23abb0]*/ | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     BLAKE2sObject *self = NULL; | 
					
						
							|  |  |  |     Py_buffer buf; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     self = new_BLAKE2sObject(type); | 
					
						
							|  |  |  |     if (self == NULL) { | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Zero parameter block. */ | 
					
						
							|  |  |  |     memset(&self->param, 0, sizeof(self->param)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set digest size. */ | 
					
						
							|  |  |  |     if (digest_size <= 0 || digest_size > BLAKE2S_OUTBYTES) { | 
					
						
							|  |  |  |         PyErr_Format(PyExc_ValueError, | 
					
						
							|  |  |  |                 "digest_size must be between 1 and %d bytes", | 
					
						
							|  |  |  |                 BLAKE2S_OUTBYTES); | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     self->param.digest_length = digest_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set salt parameter. */ | 
					
						
							|  |  |  |     if ((salt->obj != NULL) && salt->len) { | 
					
						
							|  |  |  |         if (salt->len > BLAKE2S_SALTBYTES) { | 
					
						
							|  |  |  |             PyErr_Format(PyExc_ValueError, | 
					
						
							|  |  |  |                 "maximum salt length is %d bytes", | 
					
						
							|  |  |  |                 BLAKE2S_SALTBYTES); | 
					
						
							|  |  |  |             goto error; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         memcpy(self->param.salt, salt->buf, salt->len); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set personalization parameter. */ | 
					
						
							|  |  |  |     if ((person->obj != NULL) && person->len) { | 
					
						
							|  |  |  |         if (person->len > BLAKE2S_PERSONALBYTES) { | 
					
						
							|  |  |  |             PyErr_Format(PyExc_ValueError, | 
					
						
							|  |  |  |                 "maximum person length is %d bytes", | 
					
						
							|  |  |  |                 BLAKE2S_PERSONALBYTES); | 
					
						
							|  |  |  |             goto error; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         memcpy(self->param.personal, person->buf, person->len); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set tree parameters. */ | 
					
						
							|  |  |  |     if (fanout < 0 || fanout > 255) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, | 
					
						
							|  |  |  |                 "fanout must be between 0 and 255"); | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     self->param.fanout = (uint8_t)fanout; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (depth <= 0 || depth > 255) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, | 
					
						
							|  |  |  |                 "depth must be between 1 and 255"); | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     self->param.depth = (uint8_t)depth; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 13:22:16 +03:00
										 |  |  |     if (leaf_size > 0xFFFFFFFFU) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_OverflowError, "leaf_size is too large"); | 
					
						
							|  |  |  |         goto error; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-11-03 15:02:41 -04:00
										 |  |  |     // NB: Simple assignment here would be incorrect on big endian platforms.
 | 
					
						
							|  |  |  |     store32(&(self->param.leaf_length), leaf_size); | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_BLAKE2S
 | 
					
						
							|  |  |  |     if (node_offset > 0xFFFFFFFFFFFFULL) { | 
					
						
							|  |  |  |         /* maximum 2**48 - 1 */ | 
					
						
							|  |  |  |          PyErr_SetString(PyExc_OverflowError, "node_offset is too large"); | 
					
						
							|  |  |  |          goto error; | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |     store48(&(self->param.node_offset), node_offset); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-11-03 15:02:41 -04:00
										 |  |  |     // NB: Simple assignment here would be incorrect on big endian platforms.
 | 
					
						
							|  |  |  |     store64(&(self->param.node_offset), node_offset); | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (node_depth < 0 || node_depth > 255) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, | 
					
						
							|  |  |  |                 "node_depth must be between 0 and 255"); | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     self->param.node_depth = node_depth; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (inner_size < 0 || inner_size > BLAKE2S_OUTBYTES) { | 
					
						
							|  |  |  |         PyErr_Format(PyExc_ValueError, | 
					
						
							|  |  |  |                 "inner_size must be between 0 and is %d", | 
					
						
							|  |  |  |                 BLAKE2S_OUTBYTES); | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     self->param.inner_length = inner_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set key length. */ | 
					
						
							|  |  |  |     if ((key->obj != NULL) && key->len) { | 
					
						
							|  |  |  |         if (key->len > BLAKE2S_KEYBYTES) { | 
					
						
							|  |  |  |             PyErr_Format(PyExc_ValueError, | 
					
						
							|  |  |  |                 "maximum key length is %d bytes", | 
					
						
							|  |  |  |                 BLAKE2S_KEYBYTES); | 
					
						
							|  |  |  |             goto error; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-09-07 02:49:11 +02:00
										 |  |  |         self->param.key_length = (uint8_t)key->len; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Initialize hash state. */ | 
					
						
							|  |  |  |     if (blake2s_init_param(&self->state, &self->param) < 0) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_RuntimeError, | 
					
						
							|  |  |  |                 "error initializing hash state"); | 
					
						
							|  |  |  |         goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set last node flag (must come after initialization). */ | 
					
						
							|  |  |  |     self->state.last_node = last_node; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Process key block if any. */ | 
					
						
							|  |  |  |     if (self->param.key_length) { | 
					
						
							|  |  |  |         uint8_t block[BLAKE2S_BLOCKBYTES]; | 
					
						
							|  |  |  |         memset(block, 0, sizeof(block)); | 
					
						
							|  |  |  |         memcpy(block, key->buf, key->len); | 
					
						
							|  |  |  |         blake2s_update(&self->state, block, sizeof(block)); | 
					
						
							|  |  |  |         secure_zero_memory(block, sizeof(block)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Process initial data if any. */ | 
					
						
							|  |  |  |     if (data != NULL) { | 
					
						
							|  |  |  |         GET_BUFFER_VIEW_OR_ERROR(data, &buf, goto error); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (buf.len >= HASHLIB_GIL_MINSIZE) { | 
					
						
							|  |  |  |             Py_BEGIN_ALLOW_THREADS | 
					
						
							|  |  |  |             blake2s_update(&self->state, buf.buf, buf.len); | 
					
						
							|  |  |  |             Py_END_ALLOW_THREADS | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             blake2s_update(&self->state, buf.buf, buf.len); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         PyBuffer_Release(&buf); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return (PyObject *)self; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   error: | 
					
						
							|  |  |  |     if (self != NULL) { | 
					
						
							|  |  |  |         Py_DECREF(self); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2.blake2s.copy | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Return a copy of the hash object. | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2_blake2s_copy_impl(BLAKE2sObject *self) | 
					
						
							|  |  |  | /*[clinic end generated code: output=5b90131c4eae275e input=0b9d44942f0fe4b2]*/ | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     BLAKE2sObject *cpy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ((cpy = new_BLAKE2sObject(Py_TYPE(self))) == NULL) | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ENTER_HASHLIB(self); | 
					
						
							|  |  |  |     cpy->param = self->param; | 
					
						
							|  |  |  |     cpy->state = self->state; | 
					
						
							|  |  |  |     LEAVE_HASHLIB(self); | 
					
						
							|  |  |  |     return (PyObject *)cpy; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2.blake2s.update | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  |     data: object | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     / | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | Update this hash object's state with the provided bytes-like object. | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2_blake2s_update(BLAKE2sObject *self, PyObject *data) | 
					
						
							|  |  |  | /*[clinic end generated code: output=757dc087fec37815 input=97500db2f9de4aaa]*/ | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     Py_buffer buf; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  |     GET_BUFFER_VIEW_OR_ERROUT(data, &buf); | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-16 00:53:38 +01:00
										 |  |  |     if (!self->use_mutex && buf.len >= HASHLIB_GIL_MINSIZE) { | 
					
						
							|  |  |  |         self->use_mutex = true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (self->use_mutex) { | 
					
						
							|  |  |  |         Py_BEGIN_ALLOW_THREADS | 
					
						
							|  |  |  |         PyMutex_Lock(&self->mutex); | 
					
						
							|  |  |  |         blake2s_update(&self->state, buf.buf, buf.len); | 
					
						
							|  |  |  |         PyMutex_Unlock(&self->mutex); | 
					
						
							|  |  |  |         Py_END_ALLOW_THREADS | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         blake2s_update(&self->state, buf.buf, buf.len); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-11-16 00:53:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     PyBuffer_Release(&buf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-23 09:47:21 +02:00
										 |  |  |     Py_RETURN_NONE; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2.blake2s.digest | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | Return the digest value as a bytes object. | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2_blake2s_digest_impl(BLAKE2sObject *self) | 
					
						
							|  |  |  | /*[clinic end generated code: output=40c566ca4bc6bc51 input=f41e0b8d6d937454]*/ | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     uint8_t digest[BLAKE2S_OUTBYTES]; | 
					
						
							|  |  |  |     blake2s_state state_cpy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ENTER_HASHLIB(self); | 
					
						
							|  |  |  |     state_cpy = self->state; | 
					
						
							|  |  |  |     blake2s_final(&state_cpy, digest, self->param.digest_length); | 
					
						
							|  |  |  |     LEAVE_HASHLIB(self); | 
					
						
							|  |  |  |     return PyBytes_FromStringAndSize((const char *)digest, | 
					
						
							|  |  |  |             self->param.digest_length); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2.blake2s.hexdigest | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Return the digest value as a string of hexadecimal digits. | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  | _blake2_blake2s_hexdigest_impl(BLAKE2sObject *self) | 
					
						
							|  |  |  | /*[clinic end generated code: output=15153eb5e59c52eb input=c77a1321567e8952]*/ | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     uint8_t digest[BLAKE2S_OUTBYTES]; | 
					
						
							|  |  |  |     blake2s_state state_cpy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ENTER_HASHLIB(self); | 
					
						
							|  |  |  |     state_cpy = self->state; | 
					
						
							|  |  |  |     blake2s_final(&state_cpy, digest, self->param.digest_length); | 
					
						
							|  |  |  |     LEAVE_HASHLIB(self); | 
					
						
							|  |  |  |     return _Py_strhex((const char *)digest, self->param.digest_length); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyMethodDef py_blake2s_methods[] = { | 
					
						
							| 
									
										
										
										
											2018-07-31 09:50:16 +03:00
										 |  |  |     _BLAKE2_BLAKE2S_COPY_METHODDEF | 
					
						
							|  |  |  |     _BLAKE2_BLAKE2S_DIGEST_METHODDEF | 
					
						
							|  |  |  |     _BLAKE2_BLAKE2S_HEXDIGEST_METHODDEF | 
					
						
							|  |  |  |     _BLAKE2_BLAKE2S_UPDATE_METHODDEF | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  |     {NULL, NULL} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | py_blake2s_get_name(BLAKE2sObject *self, void *closure) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return PyUnicode_FromString("blake2s"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | py_blake2s_get_block_size(BLAKE2sObject *self, void *closure) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return PyLong_FromLong(BLAKE2S_BLOCKBYTES); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | py_blake2s_get_digest_size(BLAKE2sObject *self, void *closure) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return PyLong_FromLong(self->param.digest_length); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyGetSetDef py_blake2s_getsetters[] = { | 
					
						
							|  |  |  |     {"name", (getter)py_blake2s_get_name, | 
					
						
							|  |  |  |         NULL, NULL, NULL}, | 
					
						
							|  |  |  |     {"block_size", (getter)py_blake2s_get_block_size, | 
					
						
							|  |  |  |         NULL, NULL, NULL}, | 
					
						
							|  |  |  |     {"digest_size", (getter)py_blake2s_get_digest_size, | 
					
						
							|  |  |  |         NULL, NULL, NULL}, | 
					
						
							|  |  |  |     {NULL} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | py_blake2s_dealloc(PyObject *self) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     BLAKE2sObject *obj = (BLAKE2sObject *)self; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Try not to leave state in memory. */ | 
					
						
							|  |  |  |     secure_zero_memory(&obj->param, sizeof(obj->param)); | 
					
						
							|  |  |  |     secure_zero_memory(&obj->state, sizeof(obj->state)); | 
					
						
							| 
									
										
										
										
											2020-09-02 04:45:13 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     PyTypeObject *type = Py_TYPE(self); | 
					
						
							| 
									
										
										
										
											2020-12-01 10:37:39 +01:00
										 |  |  |     PyObject_Free(self); | 
					
						
							| 
									
										
										
										
											2020-09-02 04:45:13 -05:00
										 |  |  |     Py_DECREF(type); | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 04:45:13 -05:00
										 |  |  | static PyType_Slot blake2s_type_slots[] = { | 
					
						
							|  |  |  |     {Py_tp_dealloc, py_blake2s_dealloc}, | 
					
						
							|  |  |  |     {Py_tp_doc, (char *)py_blake2s_new__doc__}, | 
					
						
							|  |  |  |     {Py_tp_methods, py_blake2s_methods}, | 
					
						
							|  |  |  |     {Py_tp_getset, py_blake2s_getsetters}, | 
					
						
							|  |  |  |     {Py_tp_new, py_blake2s_new}, | 
					
						
							|  |  |  |     {0,0} | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 04:45:13 -05:00
										 |  |  | PyType_Spec blake2s_type_spec = { | 
					
						
							|  |  |  |     .name = "_blake2.blake2s", | 
					
						
							|  |  |  |     .basicsize =  sizeof(BLAKE2sObject), | 
					
						
							| 
									
										
										
										
											2021-05-02 09:47:45 +02:00
										 |  |  |     .flags = Py_TPFLAGS_DEFAULT | Py_TPFLAGS_IMMUTABLETYPE, | 
					
						
							| 
									
										
										
										
											2020-09-02 04:45:13 -05:00
										 |  |  |     .slots = blake2s_type_slots | 
					
						
							| 
									
										
										
										
											2016-09-06 22:03:25 +02:00
										 |  |  | }; |