mirror of
https://github.com/davidhalter/typeshed.git
synced 2025-12-07 12:44:28 +08:00
This is a follow-up on #4232. memoryview, hashlib, and hmac are updated to use ReadableBuffer type instead of their own home-spun unions of bytes, bytearray and whatever else each use case used. mmap is being handled in #4244, and I'll leave BinaryIO for another day (or possibly another person) because it's going to require some messy code duplication because the relevant methods are defined in IO[AnyStr]. There's one corner case I'm not quite sure how best to handle: the documentation for hmac.digest claim that the parmaeters have the same meanings as in hmac.new, but in CPython the latter has an explicit check that `key` is bytes or bytearray while the former works with a memory-view. For now I've matched the documentation. Also, the documentation for HMAC.update says that `msg` can be any type supported by hashlib from Python 3.4; but I can't see anything in the Python 2.7 implementation that would prevent it also taking bytes-like objects, so I've not tried to treat Python 2 any different to Python 3.
48 lines
1.5 KiB
Python
48 lines
1.5 KiB
Python
# Stubs for hmac
|
|
|
|
from typing import Any, AnyStr, Callable, Optional, Union, overload
|
|
from types import ModuleType
|
|
import sys
|
|
from _typeshed import ReadableBuffer
|
|
|
|
_B = Union[bytes, bytearray]
|
|
|
|
# TODO more precise type for object of hashlib
|
|
_Hash = Any
|
|
_DigestMod = Union[str, Callable[[], _Hash], ModuleType]
|
|
|
|
digest_size: None
|
|
|
|
if sys.version_info >= (3, 8):
|
|
# In reality digestmod has a default value, but the function always throws an error
|
|
# if the argument is not given, so we pretend it is a required argument.
|
|
@overload
|
|
def new(key: _B, msg: Optional[ReadableBuffer], digestmod: _DigestMod) -> HMAC: ...
|
|
@overload
|
|
def new(key: _B, *, digestmod: _DigestMod) -> HMAC: ...
|
|
elif sys.version_info >= (3, 4):
|
|
def new(key: _B, msg: Optional[ReadableBuffer] = ...,
|
|
digestmod: Optional[_DigestMod] = ...) -> HMAC: ...
|
|
else:
|
|
def new(key: _B, msg: Optional[ReadableBuffer] = ...,
|
|
digestmod: Optional[_DigestMod] = ...) -> HMAC: ...
|
|
|
|
class HMAC:
|
|
if sys.version_info >= (3,):
|
|
digest_size: int
|
|
if sys.version_info >= (3, 4):
|
|
block_size: int
|
|
name: str
|
|
def update(self, msg: ReadableBuffer) -> None: ...
|
|
def digest(self) -> bytes: ...
|
|
def hexdigest(self) -> str: ...
|
|
def copy(self) -> HMAC: ...
|
|
|
|
@overload
|
|
def compare_digest(a: ReadableBuffer, b: ReadableBuffer) -> bool: ...
|
|
@overload
|
|
def compare_digest(a: AnyStr, b: AnyStr) -> bool: ...
|
|
|
|
if sys.version_info >= (3, 7):
|
|
def digest(key: _B, msg: ReadableBuffer, digest: str) -> bytes: ...
|