Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for ASGI pathsend extension #2671

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

gi0baro
Copy link
Contributor

@gi0baro gi0baro commented Aug 22, 2024

Summary

As per title, this adds support for ASGI pathsend extension on FileResponse class for servers implementing it.

This is a re-work of #2435 combined with parts of #2616, as discussed in #2613 with @Kludex.

Checklist

  • I understand that this PR may be closed in case there was no previous discussion. (This doesn't apply to typos!)
  • I've added a test for each change that was introduced, and I tried as much as possible to make a single atomic change.
  • I've updated the documentation accordingly.

@gi0baro gi0baro force-pushed the asgi-pathsend-rework branch 2 times, most recently from 2bbda0a to ddfc5c0 Compare August 22, 2024 14:24
docs/middleware.md Outdated Show resolved Hide resolved
@gi0baro gi0baro force-pushed the asgi-pathsend-rework branch 2 times, most recently from 9286c83 to 4631efb Compare September 2, 2024 16:36
@gi0baro gi0baro requested review from adriangb and Kludex September 2, 2024 16:42
@Kludex Kludex assigned Kludex and unassigned gi0baro Sep 23, 2024
@gi0baro gi0baro force-pushed the asgi-pathsend-rework branch from 986ee73 to fe45c1b Compare October 3, 2024 09:57
@gi0baro gi0baro force-pushed the asgi-pathsend-rework branch from fe45c1b to 6b658e8 Compare October 3, 2024 10:04
@gi0baro
Copy link
Contributor Author

gi0baro commented Oct 3, 2024

@Kludex I just rebased from current master for your convenience

@gi0baro
Copy link
Contributor Author

gi0baro commented Jan 9, 2025

@Kludex what's your current take on this? Should I rebase so it can be merged, or should we just forget about it?

@Kludex
Copy link
Member

Kludex commented Jan 10, 2025

@Kludex what's your current take on this? Should I rebase so it can be merged, or should we just forget about it?

I want this to get in, I want to get back to this soon. I can rebase myself.

Sorry the delay here.

Copy link
Member

@Kludex Kludex left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This has been going for long - Sorry about it.

The only blocker here is deciding what to do about the changes on the BaseHTTPMiddleware - but I guess that's really the point of this PR. Would it make sense to remove the extension from the scope?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is altering the scope["extensions"] in the application side allowed? Would it be bad to remove the http.response.httpsend from the BaseHTTPMiddleware? It's a question. I'm not sure what would be best.

I would like to avoid adding complexity to the BaseHTTPMiddleware.

Comment on lines +367 to +372
async def _handle_simple(self, scope: Scope, send: Send, send_header_only: bool) -> None:
await send({"type": "http.response.start", "status": self.status_code, "headers": self.raw_headers})
if send_header_only:
await send({"type": "http.response.body", "body": b"", "more_body": False})
elif "http.response.pathsend" in scope["extensions"]:
await send({"type": "http.response.pathsend", "path": str(self.path)})
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nitpick

Suggested change
async def _handle_simple(self, scope: Scope, send: Send, send_header_only: bool) -> None:
await send({"type": "http.response.start", "status": self.status_code, "headers": self.raw_headers})
if send_header_only:
await send({"type": "http.response.body", "body": b"", "more_body": False})
elif "http.response.pathsend" in scope["extensions"]:
await send({"type": "http.response.pathsend", "path": str(self.path)})
async def _handle_simple(self, send: Send, send_header_only: bool, send_pathsend: bool) -> None:
await send({"type": "http.response.start", "status": self.status_code, "headers": self.raw_headers})
if send_header_only:
await send({"type": "http.response.body", "body": b"", "more_body": False})
elif send_pathsend:
await send({"type": "http.response.pathsend", "path": str(self.path)})

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants