mirror of
https://github.com/davidhalter/typeshed.git
synced 2025-12-07 04:34:28 +08:00
Fixes #4288. - Default imports to THIRD_PARTY, so in effect we merge the FIRST_PARTY and THIRD_PARTY stubs. This means import order is no longer affected by whether typing_extensions is installed locally. - Treat typing_extensions, _typeshed and some others as standard library modules. Note that isort master is very different from the latest release; we'll have to do something different if and when the next isort release comes out.
123 lines
4.4 KiB
Python
123 lines
4.4 KiB
Python
# Stubs for hashlib
|
|
|
|
import sys
|
|
from _typeshed import ReadableBuffer
|
|
from typing import AbstractSet, Optional, Union
|
|
|
|
class _Hash(object):
|
|
digest_size: int
|
|
block_size: int
|
|
|
|
# [Python documentation note] Changed in version 3.4: The name attribute has
|
|
# been present in CPython since its inception, but until Python 3.4 was not
|
|
# formally specified, so may not exist on some platforms
|
|
name: str
|
|
def __init__(self, data: ReadableBuffer = ...) -> None: ...
|
|
def copy(self) -> _Hash: ...
|
|
def digest(self) -> bytes: ...
|
|
def hexdigest(self) -> str: ...
|
|
def update(self, __data: ReadableBuffer) -> None: ...
|
|
|
|
if sys.version_info >= (3, 9):
|
|
def md5(string: ReadableBuffer = ..., *, usedforsecurity: bool = ...) -> _Hash: ...
|
|
def sha1(string: ReadableBuffer = ..., *, usedforsecurity: bool = ...) -> _Hash: ...
|
|
def sha224(string: ReadableBuffer = ..., *, usedforsecurity: bool = ...) -> _Hash: ...
|
|
def sha256(string: ReadableBuffer = ..., *, usedforsecurity: bool = ...) -> _Hash: ...
|
|
def sha384(string: ReadableBuffer = ..., *, usedforsecurity: bool = ...) -> _Hash: ...
|
|
def sha512(string: ReadableBuffer = ..., *, usedforsecurity: bool = ...) -> _Hash: ...
|
|
|
|
elif sys.version_info >= (3, 8):
|
|
def md5(string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha1(string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha224(string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha256(string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha384(string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha512(string: ReadableBuffer = ...) -> _Hash: ...
|
|
|
|
else:
|
|
def md5(__string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha1(__string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha224(__string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha256(__string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha384(__string: ReadableBuffer = ...) -> _Hash: ...
|
|
def sha512(__string: ReadableBuffer = ...) -> _Hash: ...
|
|
|
|
def new(name: str, data: ReadableBuffer = ...) -> _Hash: ...
|
|
|
|
algorithms_guaranteed: AbstractSet[str]
|
|
algorithms_available: AbstractSet[str]
|
|
|
|
def pbkdf2_hmac(
|
|
hash_name: str, password: ReadableBuffer, salt: ReadableBuffer, iterations: int, dklen: Optional[int] = ...
|
|
) -> bytes: ...
|
|
|
|
if sys.version_info >= (3, 6):
|
|
class _VarLenHash(object):
|
|
digest_size: int
|
|
block_size: int
|
|
name: str
|
|
def __init__(self, data: ReadableBuffer = ...) -> None: ...
|
|
def copy(self) -> _VarLenHash: ...
|
|
def digest(self, __length: int) -> bytes: ...
|
|
def hexdigest(self, __length: int) -> str: ...
|
|
def update(self, __data: ReadableBuffer) -> None: ...
|
|
sha3_224 = _Hash
|
|
sha3_256 = _Hash
|
|
sha3_384 = _Hash
|
|
sha3_512 = _Hash
|
|
shake_128 = _VarLenHash
|
|
shake_256 = _VarLenHash
|
|
def scrypt(
|
|
password: ReadableBuffer,
|
|
*,
|
|
salt: Optional[ReadableBuffer] = ...,
|
|
n: Optional[int] = ...,
|
|
r: Optional[int] = ...,
|
|
p: Optional[int] = ...,
|
|
maxmem: int = ...,
|
|
dklen: int = ...,
|
|
) -> bytes: ...
|
|
class _BlakeHash(_Hash):
|
|
MAX_DIGEST_SIZE: int
|
|
MAX_KEY_SIZE: int
|
|
PERSON_SIZE: int
|
|
SALT_SIZE: int
|
|
|
|
if sys.version_info >= (3, 9):
|
|
def __init__(
|
|
self,
|
|
__data: ReadableBuffer = ...,
|
|
*,
|
|
digest_size: int = ...,
|
|
key: ReadableBuffer = ...,
|
|
salt: ReadableBuffer = ...,
|
|
person: ReadableBuffer = ...,
|
|
fanout: int = ...,
|
|
depth: int = ...,
|
|
leaf_size: int = ...,
|
|
node_offset: int = ...,
|
|
node_depth: int = ...,
|
|
inner_size: int = ...,
|
|
last_node: bool = ...,
|
|
usedforsecurity: bool = ...,
|
|
) -> None: ...
|
|
else:
|
|
def __init__(
|
|
self,
|
|
__data: ReadableBuffer = ...,
|
|
*,
|
|
digest_size: int = ...,
|
|
key: ReadableBuffer = ...,
|
|
salt: ReadableBuffer = ...,
|
|
person: ReadableBuffer = ...,
|
|
fanout: int = ...,
|
|
depth: int = ...,
|
|
leaf_size: int = ...,
|
|
node_offset: int = ...,
|
|
node_depth: int = ...,
|
|
inner_size: int = ...,
|
|
last_node: bool = ...,
|
|
) -> None: ...
|
|
blake2b = _BlakeHash
|
|
blake2s = _BlakeHash
|