diff --git a/pynitrokey/cli/exceptions.py b/pynitrokey/cli/exceptions.py index d53a5dcc..b1408540 100644 --- a/pynitrokey/cli/exceptions.py +++ b/pynitrokey/cli/exceptions.py @@ -7,13 +7,15 @@ # http://opensource.org/licenses/MIT>, at your option. This file may not be # copied, modified, or distributed except according to those terms. +from typing import Any + from pynitrokey.helpers import local_critical class CliException(Exception): def __init__( - self, *messages, support_hint: bool = True, ret_code: int = 1, **kwargs - ): + self, *messages: Any, support_hint: bool = True, ret_code: int = 1, **kwargs: Any + ) -> None: super().__init__("\n".join([str(message) for message in messages])) self.messages = messages @@ -21,7 +23,7 @@ def __init__( self.ret_code = ret_code self.kwargs = kwargs - def show(self): + def show(self) -> None: local_critical( *self.messages, support_hint=self.support_hint, diff --git a/pynitrokey/cli/fido2.py b/pynitrokey/cli/fido2.py index 3e381f9a..52accae4 100644 --- a/pynitrokey/cli/fido2.py +++ b/pynitrokey/cli/fido2.py @@ -25,7 +25,8 @@ from fido2.client import ClientError as Fido2ClientError from fido2.ctap import CtapError from fido2.ctap1 import ApduError -from fido2.ctap2 import CredentialManagement, Ctap2 +from fido2.ctap2.base import Ctap2 +from fido2.ctap2.credman import CredentialManagement from fido2.ctap2.pin import ClientPin, PinProtocol from fido2.hid import CtapHidDevice diff --git a/pynitrokey/cli/monitor.py b/pynitrokey/cli/monitor.py index 3ec954d3..fdec5a7a 100644 --- a/pynitrokey/cli/monitor.py +++ b/pynitrokey/cli/monitor.py @@ -17,7 +17,7 @@ @click.command() @click.argument("serial_port") -def monitor(serial_port): +def monitor(serial_port: str) -> None: """Reads Nitrokey serial output from USB serial port SERIAL_PORT. SERIAL-PORT is something like /dev/ttyACM0 or COM10. @@ -36,7 +36,7 @@ def monitor(serial_port): sys.stdout.flush() time.sleep(0.5) - def reconnect(): + def reconnect() -> serial.Serial: while True: time.sleep(0.5) try: diff --git a/pynitrokey/fido2/client.py b/pynitrokey/fido2/client.py index 3db8d6bb..f9c6c0ce 100644 --- a/pynitrokey/fido2/client.py +++ b/pynitrokey/fido2/client.py @@ -23,7 +23,7 @@ from fido2.cose import ES256, EdDSA from fido2.ctap import CtapError from fido2.ctap1 import Ctap1 -from fido2.ctap2 import CredentialManagement, Ctap2 +from fido2.ctap2.base import Ctap2 from fido2.ctap2.credman import CredentialManagement from fido2.ctap2.pin import ClientPin from fido2.hid import CTAPHID, CtapHidDevice, open_device diff --git a/pynitrokey/helpers.py b/pynitrokey/helpers.py index e8302289..6a4e9626 100644 --- a/pynitrokey/helpers.py +++ b/pynitrokey/helpers.py @@ -98,7 +98,7 @@ class ProgressBar: """ def __init__(self, **kwargs: Any) -> None: - self.bar: Optional[tqdm] = None + self.bar: Optional[tqdm[Any]] = None self.kwargs = kwargs self.sum = 0 diff --git a/pynitrokey/nk3/bootloader/lpc55.py b/pynitrokey/nk3/bootloader/lpc55.py index 57169045..7429ca48 100644 --- a/pynitrokey/nk3/bootloader/lpc55.py +++ b/pynitrokey/nk3/bootloader/lpc55.py @@ -14,7 +14,7 @@ from typing import List, Optional, Tuple from spsdk.mboot import McuBoot, StatusCode -from spsdk.mboot.interfaces import RawHid +from spsdk.mboot.interfaces.usb import RawHid from spsdk.mboot.properties import PropertyTag from spsdk.sbfile.sb2.images import BootImageV21 from spsdk.utils.usbfilter import USBDeviceFilter diff --git a/pyproject.toml b/pyproject.toml index 529baa29..79718440 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -79,32 +79,37 @@ profile = "black" mypy_path = "stubs" show_error_codes = true python_version = "3.9" -warn_unused_configs = true -warn_redundant_casts = true +strict = true -# enable strict checks for new code, see +# disable strict checks for old code, see # - https://github.com/python/mypy/issues/11401 # - https://mypy.readthedocs.io/en/stable/existing_code.html#introduce-stricter-options [[tool.mypy.overrides]] module = [ - "pynitrokey.cli.fido2.*", - "pynitrokey.cli.nk3.*", - "pynitrokey.fido2.*", - "pynitrokey.nk3.*", - "pynitrokey.updates.*", + "pynitrokey.cli", + "pynitrokey.cli.nethsm", + "pynitrokey.cli.pro", + "pynitrokey.cli.program", + "pynitrokey.cli.start", + "pynitrokey.cli.storage", + "pynitrokey.cli.update", + "pynitrokey.conftest", + "pynitrokey.libnk", + "pynitrokey.start.*", + "pynitrokey.test_secrets_app", ] -check_untyped_defs = true -disallow_any_generics = true -disallow_incomplete_defs = true -disallow_subclassing_any = true -disallow_untyped_calls = true -disallow_untyped_decorators = true -disallow_untyped_defs = true -no_implicit_reexport = true -strict_concatenate = true -strict_equality = true -warn_unused_ignores = true -warn_return_any = true +check_untyped_defs = false +disallow_any_generics = false +disallow_incomplete_defs = false +disallow_subclassing_any = false +disallow_untyped_calls = false +disallow_untyped_decorators = false +disallow_untyped_defs = false +no_implicit_reexport = false +strict_concatenate = false +strict_equality = false +warn_unused_ignores = false +warn_return_any = false # pynitrokey.nk3.bootloader.nrf52_upload is only temporary in this package