golden hour
/opt/imunify360/venv/lib/python3.11/site-packages/Crypto/Hash
⬆️ Go Up
Upload
File/Folder
Size
Actions
BLAKE2b.py
9.2 KB
Del
OK
BLAKE2b.pyi
906 B
Del
OK
BLAKE2s.py
9.21 KB
Del
OK
BLAKE2s.pyi
739 B
Del
OK
CMAC.py
10.11 KB
Del
OK
CMAC.pyi
822 B
Del
OK
HMAC.py
6.86 KB
Del
OK
HMAC.pyi
624 B
Del
OK
KMAC128.py
5.81 KB
Del
OK
KMAC128.pyi
903 B
Del
OK
KMAC256.py
2.84 KB
Del
OK
KMAC256.pyi
226 B
Del
OK
KangarooTwelve.py
8.82 KB
Del
OK
KangarooTwelve.pyi
572 B
Del
OK
MD2.py
5.97 KB
Del
OK
MD2.pyi
492 B
Del
OK
MD4.py
6.43 KB
Del
OK
MD4.pyi
532 B
Del
OK
MD5.py
6.46 KB
Del
OK
MD5.pyi
492 B
Del
OK
Poly1305.py
7.88 KB
Del
OK
Poly1305.pyi
665 B
Del
OK
RIPEMD.py
1.17 KB
Del
OK
RIPEMD.pyi
94 B
Del
OK
RIPEMD160.py
6.25 KB
Del
OK
RIPEMD160.pyi
516 B
Del
OK
SHA.py
1.12 KB
Del
OK
SHA.pyi
161 B
Del
OK
SHA1.py
6.53 KB
Del
OK
SHA1.pyi
536 B
Del
OK
SHA224.py
6.74 KB
Del
OK
SHA224.pyi
544 B
Del
OK
SHA256.py
6.74 KB
Del
OK
SHA256.pyi
612 B
Del
OK
SHA384.py
6.74 KB
Del
OK
SHA384.pyi
544 B
Del
OK
SHA3_224.py
6.03 KB
Del
OK
SHA3_224.pyi
605 B
Del
OK
SHA3_256.py
6.03 KB
Del
OK
SHA3_256.pyi
605 B
Del
OK
SHA3_384.py
6.13 KB
Del
OK
SHA3_384.pyi
605 B
Del
OK
SHA3_512.py
5.99 KB
Del
OK
SHA3_512.pyi
605 B
Del
OK
SHA512.py
7.54 KB
Del
OK
SHA512.pyi
622 B
Del
OK
SHAKE128.py
4.65 KB
Del
OK
SHAKE128.pyi
437 B
Del
OK
SHAKE256.py
4.65 KB
Del
OK
SHAKE256.pyi
437 B
Del
OK
TupleHash128.py
4.61 KB
Del
OK
TupleHash128.pyi
652 B
Del
OK
TupleHash256.py
2.84 KB
Del
OK
TupleHash256.pyi
144 B
Del
OK
_BLAKE2b.abi3.so
26.78 KB
Del
OK
_BLAKE2s.abi3.so
26.32 KB
Del
OK
_MD2.abi3.so
22.59 KB
Del
OK
_MD4.abi3.so
26.55 KB
Del
OK
_MD5.abi3.so
31.26 KB
Del
OK
_RIPEMD160.abi3.so
59.3 KB
Del
OK
_SHA1.abi3.so
70.38 KB
Del
OK
_SHA224.abi3.so
44.7 KB
Del
OK
_SHA256.abi3.so
44.76 KB
Del
OK
_SHA384.abi3.so
52.89 KB
Del
OK
_SHA512.abi3.so
52.93 KB
Del
OK
__init__.py
1.21 KB
Del
OK
__init__.pyi
0 B
Del
OK
__pycache__
-
Del
OK
_ghash_clmul.abi3.so
57.01 KB
Del
OK
_ghash_portable.abi3.so
24.44 KB
Del
OK
_keccak.abi3.so
40.66 KB
Del
OK
_poly1305.abi3.so
32.64 KB
Del
OK
cSHAKE128.py
6.17 KB
Del
OK
cSHAKE128.pyi
499 B
Del
OK
cSHAKE256.py
2.15 KB
Del
OK
cSHAKE256.pyi
231 B
Del
OK
keccak.py
7.37 KB
Del
OK
keccak.pyi
741 B
Del
OK
Edit: SHA3_256.py
# -*- coding: utf-8 -*- # # =================================================================== # The contents of this file are dedicated to the public domain. To # the extent that dedication to the public domain is not available, # everyone is granted a worldwide, perpetual, royalty-free, # non-exclusive license to exercise all rights associated with the # contents of this file for any purpose whatsoever. # No rights are reserved. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # SOFTWARE. # =================================================================== from Crypto.Util.py3compat import bord from Crypto.Util._raw_api import (load_pycryptodome_raw_lib, VoidPointer, SmartPointer, create_string_buffer, get_raw_buffer, c_size_t, c_uint8_ptr, c_ubyte) from Crypto.Hash.keccak import _raw_keccak_lib class SHA3_256_Hash(object): """A SHA3-256 hash object. Do not instantiate directly. Use the :func:`new` function. :ivar oid: ASN.1 Object ID :vartype oid: string :ivar digest_size: the size in bytes of the resulting hash :vartype digest_size: integer """ # The size of the resulting hash in bytes. digest_size = 32 # ASN.1 Object ID oid = "2.16.840.1.101.3.4.2.8" # Input block size for HMAC block_size = 136 def __init__(self, data, update_after_digest): self._update_after_digest = update_after_digest self._digest_done = False self._padding = 0x06 state = VoidPointer() result = _raw_keccak_lib.keccak_init(state.address_of(), c_size_t(self.digest_size * 2), c_ubyte(24)) if result: raise ValueError("Error %d while instantiating SHA-3/256" % result) self._state = SmartPointer(state.get(), _raw_keccak_lib.keccak_destroy) if data: self.update(data) def update(self, data): """Continue hashing of a message by consuming the next chunk of data. Args: data (byte string/byte array/memoryview): The next chunk of the message being hashed. """ if self._digest_done and not self._update_after_digest: raise TypeError("You can only call 'digest' or 'hexdigest' on this object") result = _raw_keccak_lib.keccak_absorb(self._state.get(), c_uint8_ptr(data), c_size_t(len(data)) ) if result: raise ValueError("Error %d while updating SHA-3/256" % result) return self def digest(self): """Return the **binary** (non-printable) digest of the message that has been hashed so far. :return: The hash digest, computed over the data processed so far. Binary form. :rtype: byte string """ self._digest_done = True bfr = create_string_buffer(self.digest_size) result = _raw_keccak_lib.keccak_digest(self._state.get(), bfr, c_size_t(self.digest_size), c_ubyte(self._padding)) if result: raise ValueError("Error %d while instantiating SHA-3/256" % result) self._digest_value = get_raw_buffer(bfr) return self._digest_value def hexdigest(self): """Return the **printable** digest of the message that has been hashed so far. :return: The hash digest, computed over the data processed so far. Hexadecimal encoded. :rtype: string """ return "".join(["%02x" % bord(x) for x in self.digest()]) def copy(self): """Return a copy ("clone") of the hash object. The copy will have the same internal state as the original hash object. This can be used to efficiently compute the digests of strings that share a common initial substring. :return: A hash object of the same type """ clone = self.new() result = _raw_keccak_lib.keccak_copy(self._state.get(), clone._state.get()) if result: raise ValueError("Error %d while copying SHA3-256" % result) return clone def new(self, data=None): """Create a fresh SHA3-256 hash object.""" return type(self)(data, self._update_after_digest) def new(*args, **kwargs): """Create a new hash object. Args: data (byte string/byte array/memoryview): The very first chunk of the message to hash. It is equivalent to an early call to :meth:`update`. update_after_digest (boolean): Whether :meth:`digest` can be followed by another :meth:`update` (default: ``False``). :Return: A :class:`SHA3_256_Hash` hash object """ data = kwargs.pop("data", None) update_after_digest = kwargs.pop("update_after_digest", False) if len(args) == 1: if data: raise ValueError("Initial data for hash specified twice") data = args[0] if kwargs: raise TypeError("Unknown parameters: " + str(kwargs)) return SHA3_256_Hash(data, update_after_digest) # The size of the resulting hash in bytes. digest_size = SHA3_256_Hash.digest_size # Input block size for HMAC block_size = 136
Save