DSS.pyi 1.1 KB

123456789101112131415161718192021222324
  1. from types import ModuleType
  2. from typing import Union, Optional, Callable
  3. from Cryptodome.PublicKey.DSA import DsaKey
  4. from Cryptodome.PublicKey.ECC import EccKey
  5. __all__ = ['new', 'DssSigScheme']
  6. class DssSigScheme:
  7. def __init__(self, key: Union[DsaKey, EccKey], encoding: str, order: int) -> None: ...
  8. def can_sign(self) -> bool: ...
  9. def sign(self, msg_hash: ModuleType) -> bytes: ...
  10. def verify(self, msg_hash: ModuleType, signature: bytes) -> bool: ...
  11. class DeterministicDsaSigScheme(DssSigScheme):
  12. def __init__(self, key, encoding, order, private_key) -> None: ...
  13. class FipsDsaSigScheme(DssSigScheme):
  14. def __init__(self, key: DsaKey, encoding: str, order: int, randfunc: Callable) -> None: ...
  15. class FipsEcDsaSigScheme(DssSigScheme):
  16. def __init__(self, key: EccKey, encoding: str, order: int, randfunc: Callable) -> None: ...
  17. def new(key: Union[DsaKey, EccKey], mode: str, encoding: Optional[str]='binary', randfunc: Optional[Callable]=None) -> Union[DeterministicDsaSigScheme, FipsDsaSigScheme, FipsEcDsaSigScheme]: ...