Fixed #35187 -- Fixed @sensitive_variables/sensitive_post_parameters decorators crash with .pyc-only builds.

Thanks Jon Janzen for the implementation idea.

Thanks Marcus Hoffmann for the report.

Regression in 38e391e95f.
This commit is contained in:
Mariusz Felisiak 2024-02-17 08:15:59 +01:00 committed by GitHub
parent 7a05b8a2fa
commit d1be05b3e9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 8 additions and 2 deletions

View File

@ -47,7 +47,6 @@ def sensitive_variables(*variables):
try: try:
file_path = inspect.getfile(wrapped_func) file_path = inspect.getfile(wrapped_func)
_, first_file_line = inspect.getsourcelines(wrapped_func)
except TypeError: # Raises for builtins or native functions. except TypeError: # Raises for builtins or native functions.
raise ValueError( raise ValueError(
f"{func.__name__} cannot safely be wrapped by " f"{func.__name__} cannot safely be wrapped by "
@ -55,7 +54,10 @@ def sensitive_variables(*variables):
"Python file (not a builtin or from a native extension)." "Python file (not a builtin or from a native extension)."
) )
else: else:
key = hash(f"{file_path}:{first_file_line}") # A source file may not be available (e.g. in .pyc-only builds),
# use the first line number instead.
first_line_number = wrapped_func.__code__.co_firstlineno
key = hash(f"{file_path}:{first_line_number}")
if variables: if variables:
coroutine_functions_to_sensitive_variables[key] = variables coroutine_functions_to_sensitive_variables[key] = variables

View File

@ -20,3 +20,7 @@ Bugfixes
would prevent filtering against foreign keys using lookups like ``__isnull`` would prevent filtering against foreign keys using lookups like ``__isnull``
when the field was not included in :attr:`.ModelAdmin.list_filter` when the field was not included in :attr:`.ModelAdmin.list_filter`
(:ticket:`35173`). (:ticket:`35173`).
* Fixed a regression in Django 5.0 that caused a crash of
``@sensitive_variables`` and ``@sensitive_post_parameters`` decorators on
functions loaded from ``.pyc`` files (:ticket:`35187`).