Dica do tipo Python 3 para decorador

Considere o seguinte código:

from typing import Callable, Any

TFunc = Callable[..., Any]

def get_authenticated_user(): return "John"

def require_auth() -> Callable[TFunc, TFunc]:
    def decorator(func: TFunc) -> TFunc:
        def wrapper(*args, **kwargs) -> Any:
            user = get_authenticated_user()
            if user is None:
                raise Exception("Don't!")
            return func(*args, **kwargs)
        return wrapper
    return decorator

@require_auth()
def foo(a: int) -> bool:
    return bool(a % 2)

foo(2)      # Type check OK
foo("no!")  # Type check failing as intended

Este trecho de código está funcionando como pretendido. Agora imagine que eu quero estender isso e, em vez de apenas executarfunc(*args, **kwargs) Eu quero injetar o nome de usuário nos argumentos. Portanto, eu modifico a assinatura da função.

from typing import Callable, Any

TFunc = Callable[..., Any]

def get_authenticated_user(): return "John"

def inject_user() -> Callable[TFunc, TFunc]:
    def decorator(func: TFunc) -> TFunc:
        def wrapper(*args, **kwargs) -> Any:
            user = get_authenticated_user()
            if user is None:
                raise Exception("Don't!")
            return func(*args, user, **kwargs)  # <- call signature modified

        return wrapper

    return decorator


@inject_user()
def foo(a: int, username: str) -> bool:
    print(username)
    return bool(a % 2)


foo(2)      # Type check OK
foo("no!")  # Type check OK <---- UNEXPECTED

Não consigo descobrir uma maneira correta de digitar isso. Eu sei que neste exemplo, função decorada e função retornada tecnicamente devem ter a mesma assinatura (mas mesmo isso não é detectado).

questionAnswers(1)

yourAnswerToTheQuestion