33 KiB
0.37.0
February 5, 2024
Added
- Support the WebSocket Denial Response ASGI extension #2041.
0.36.3
February 4, 2024
Fixed
- Create
anyio.Event
on async context #2459.
0.36.2
February 3, 2024
Fixed
0.36.1
January 23, 2024
Fixed
- Check if "extensions" in scope before checking the extension #2438.
0.36.0
January 22, 2024
Added
- Add support for ASGI
pathsend
extension #2435. - Cancel
WebSocketTestSession
on close #2427. - Raise
WebSocketDisconnect
whenWebSocket.send()
exceptsIOError
#2425. - Raise
FileNotFoundError
when theenv_file
parameter onConfig
is not valid #2422.
0.35.1
January 11, 2024
Fixed
- Stop using the deprecated "method" parameter in
FileResponse
inside ofStaticFiles
#2406. - Make
typing-extensions
optional again #2409.
0.35.0
January 11, 2024
Added
- Add
*args
toMiddleware
and improve its type hints #2381.
Fixed
- Use
Iterable
insteadIterator
oniterate_in_threadpool
#2362.
Changes
- Handle
root_path
to keep compatibility with mounted ASGI applications and WSGI #2400. - Turn
scope["client"]
toNone
onTestClient
#2377.
0.34.0
December 16, 2023
Added
Fixed
Deprecated
- Deprecate
FileResponse(method=...)
parameter #2366.
0.33.0
December 1, 2023
Added
Fixed
- Do not overwrite
"path"
and"root_path"
scope keys #2352. - Set
ensure_ascii=False
onjson.dumps()
forWebSocket.send_json()
#2341.
0.32.0.post1
November 5, 2023
Fixed
- Revert mkdocs-material from 9.1.17 to 9.4.7 #2326.
0.32.0
November 4, 2023
Added
Changed
- Inherit from
HTMLResponse
instead ofResponse
on_TemplateResponse
#2274. - Restore the
Response.render
type annotation to its pre-0.31.0 state #2264.
0.31.1
August 26, 2023
Fixed
- Fix import error when
exceptiongroup
isn't available #2231. - Set
url_for
global for custom Jinja environments #2230.
0.31.0
July 24, 2023
Added
- Officially support Python 3.12 #2214.
- Support AnyIO 4.0 #2211.
- Strictly type annotate Starlette (strict mode on mypy) #2180.
Fixed
- Don't group duplicated headers on a single string when using the
TestClient
#2219.
0.30.0
July 13, 2023
Removed
- Drop Python 3.7 support #2178.
0.29.0
July 13, 2023
Added
- Add
follow_redirects
parameter toTestClient
#2207. - Add
__str__
toHTTPException
andWebSocketException
#2181. - Warn users when using
lifespan
together withon_startup
/on_shutdown
#2193. - Collect routes from
Host
to generate the OpenAPI schema #2183. - Add
request
argument toTemplateResponse
#2191.
Fixed
- Stop
body_stream
in casemore_body=False
onBaseHTTPMiddleware
#2194.
0.28.0
June 7, 2023
Changed
- Reuse
Request
's body buffer for call_next inBaseHTTPMiddleware
#1692. - Move exception handling logic to
Route
#2026.
Added
- Add
env
parameter toJinja2Templates
, and deprecate**env_options
#2159. - Add clear error message when
httpx
is not installed #2177.
Fixed
- Allow "name" argument on
templates url_for()
#2127.
0.27.0
May 16, 2023
This release fixes a path traversal vulnerability in StaticFiles
. You can view the full security advisory:
https://github.com/encode/starlette/security/advisories/GHSA-v5gw-mw7f-84px
Added
- Minify JSON websocket data via
send_json
https://github.com/encode/starlette/pull/2128
Fixed
- Replace
commonprefix
bycommonpath
onStaticFiles
1797de4. - Convert ImportErrors into ModuleNotFoundError #2135.
- Correct the RuntimeError message content in websockets #2141.
0.26.1
March 13, 2023
Fixed
- Fix typing of Lifespan to allow subclasses of Starlette #2077.
0.26.0.post1
March 9, 2023
Fixed
- Replace reference from Events to Lifespan on the mkdocs.yml #2072.
0.26.0
March 9, 2023
Added
- Support lifespan state #2060, #2065 and #2064.
Changed
- Change
url_for
signature to return aURL
instance #1385.
Fixed
- Allow "name" argument on
url_for()
andurl_path_for()
#2050.
Deprecated
- Deprecate
on_startup
andon_shutdown
events #2070.
0.25.0
February 14, 2023
Fix
- Limit the number of fields and files when parsing
multipart/form-data
on theMultipartParser
8c74c2c and #2036.
0.24.0
February 6, 2023
Added
- Allow
StaticFiles
to follow symlinks #1683. - Allow
Request.form()
as a context manager #1903. - Add
size
attribute toUploadFile
#1405. - Add
env_prefix
argument toConfig
#1990. - Add template context processors #1904.
- Support
str
anddatetime
onexpires
parameter on theResponse.set_cookie
method #1908.
Changed
- Lazily build the middleware stack #2017.
- Make the
file
argument required onUploadFile
#1413. - Use debug extension instead of custom response template extension #1991.
Fixed
- Fix url parsing of ipv6 urls on
URL.replace
#1965.
0.23.1
December 9, 2022
Fixed
- Only stop receiving stream on
body_stream
if body is empty on theBaseHTTPMiddleware
#1940.
0.23.0
December 5, 2022
Added
- Add
headers
parameter to theTestClient
#1966.
Deprecated
- Deprecate
Starlette
andRouter
decorators #1897.
Fixed
- Fix bug on
FloatConvertor
regex #1973.
0.22.0
November 17, 2022
Changed
- Bypass
GZipMiddleware
when response includesContent-Encoding
#1901.
Fixed
- Remove unneeded
unquote()
from query parameters on theTestClient
#1953. - Make sure
MutableHeaders._list
is actually alist
#1917. - Import compatibility with the next version of
AnyIO
#1936.
0.21.0
September 26, 2022
This release replaces the underlying HTTP client used on the TestClient
(requests
➡️ httpx
), and as those clients differ a bit on their API, your test suite will likely break. To make the migration smoother, you can use the bump-testclient
tool.
Changed
- Replace
requests
withhttpx
inTestClient
#1376.
Added
- Add
WebSocketException
and support for WebSocket exception handlers #1263. - Add
middleware
parameter toMount
class #1649. - Officially support Python 3.11 #1863.
- Implement
__repr__
for route classes #1864.
Fixed
- Fix bug on which
BackgroundTasks
were cancelled when usingBaseHTTPMiddleware
and client disconnected #1715.
0.20.4
June 28, 2022
Fixed
- Remove converter from path when generating OpenAPI schema #1648.
0.20.3
June 10, 2022
Fixed
- Revert "Allow
StaticFiles
to follow symlinks" #1681.
0.20.2
June 7, 2022
Fixed
0.20.1
May 28, 2022
Fixed
- Improve detection of async callables #1444.
- Send 400 (Bad Request) when
boundary
is missing #1617. - Send 400 (Bad Request) when missing "name" field on
Content-Disposition
header #1643. - Do not send empty data to
StreamingResponse
onBaseHTTPMiddleware
#1609. - Add
__bool__
dunder forSecret
#1625.
0.20.0
May 3, 2022
Removed
0.19.1
April 22, 2022
Fixed
- Fix inference of
Route.name
when created from methods #1553. - Avoid
TypeError
onwebsocket.disconnect
when code isNone
#1574.
Deprecated
- Deprecate
WS_1004_NO_STATUS_RCVD
andWS_1005_ABNORMAL_CLOSURE
in favor ofWS_1005_NO_STATUS_RCVD
andWS_1006_ABNORMAL_CLOSURE
, as the previous constants didn't match the WebSockets specs #1580.
0.19.0
March 9, 2022
Added
- Error handler will always run, even if the error happens on a background task #761.
- Add
headers
parameter toHTTPException
#1435. - Internal responses with
405
status code insert anAllow
header, as described by RFC 7231 #1436. - The
content
argument inJSONResponse
is now required #1431. - Add custom URL convertor register #1437.
- Add content disposition type parameter to
FileResponse
#1266. - Add next query param with original request URL in requires decorator #920.
- Add
raw_path
toTestClient
scope #1445. - Add union operators to
MutableHeaders
#1240. - Display missing route details on debug page #1363.
- Change
anyio
required version range to>=3.4.0,<5.0
#1421 and #1460. - Add
typing-extensions>=3.10
requirement - used only on lower versions than Python 3.10 #1475.
Fixed
- Prevent
BaseHTTPMiddleware
from hiding errors ofStreamingResponse
and mounted applications #1459. SessionMiddleware
uses an explicitpath=...
, instead of defaulting to the ASGI 'root_path' #1512.Request.client
is now compliant with the ASGI specifications #1462.- Raise
KeyError
at early stage for missing boundary #1349.
Deprecated
0.18.0
January 23, 2022
Added
- Change default chunk size from 4Kb to 64Kb on
FileResponse
#1345. - Add support for
functools.partial
inWebSocketRoute
#1356. - Add
StaticFiles
packages with directory #1350. - Allow environment options in
Jinja2Templates
#1401. - Allow HEAD method on
HttpEndpoint
#1346. - Accept additional headers on
websocket.accept
message #1361 and #1422. - Add
reason
toWebSocket
close ASGI event #1417. - Add headers attribute to
UploadFile
#1382. - Don't omit
Content-Length
header forContent-Length: 0
cases #1395. - Don't set headers for responses with 1xx, 204 and 304 status code #1397.
SessionMiddleware.max_age
now acceptsNone
, so cookie can last as long as the browser session #1387.
Fixed
- Tweak
hashlib.md5()
function onFileResponse
s ETag generation. The parameterusedforsecurity
flag is set toFalse
, if the flag is available on the system. This fixes an error raised on systems with FIPS enabled #1366 and #1410. - Fix
path_params
type onurl_path_for()
method i.e. turnstr
intoAny
#1341. Host
now ignoresport
on routing #1322.
0.17.1
November 17, 2021
Fixed
- Fix
IndexError
in authenticationrequires
when wrapped function arguments are distributed between*args
and**kwargs
#1335.
0.17.0
November 4, 2021
Added
Response.delete_cookie
now accepts the same parameters asResponse.set_cookie
#1228.- Update the
Jinja2Templates
constructor to allowPathLike
#1292.
Fixed
- Fix BadSignature exception handling in SessionMiddleware #1264.
- Change
HTTPConnection.__getitem__
return type fromstr
totyping.Any
#1118. - Change
ImmutableMultiDict.getlist
return type fromtyping.List[str]
totyping.List[typing.Any]
#1235. - Handle
OSError
exceptions onStaticFiles
#1220. - Fix
StaticFiles
404.html in HTML mode #1314. - Prevent anyio.ExceptionGroup in error views under a BaseHTTPMiddleware #1262.
Removed
- Remove GraphQL support #1198.
0.16.0
July 19, 2021
Added
Fixed
starlette.websockets.WebSocket
instances are now hashable and compare by identity #1039- A number of fixes related to running task groups in lifespan #1213, #1227
Deprecated/removed
- The method
starlette.templates.Jinja2Templates.get_env
was removed #1218 - The ClassVar
starlette.testclient.TestClient.async_backend
was removed, the backend is now configured using constructor kwargs #1211 - Passing an Async Generator Function or a Generator Function to
starlette.routing.Router(lifespan=)
is deprecated. You should wrap your lifespan in@contextlib.asynccontextmanager
. #1227 #1110
0.15.0
June 23, 2021
This release includes major changes to the low-level asynchronous parts of Starlette. As a result, Starlette now depends on AnyIO and some minor API changes have occurred. Another significant change with this release is the deprecation of built-in GraphQL support.
Added
- Starlette now supports Trio as an async runtime via AnyIO - #1157.
TestClient.websocket_connect()
now must be used as a context manager.- Initial support for Python 3.10 - #1201.
- The compression level used in
GZipMiddleware
is now adjustable - #1128.
Fixed
- Several fixes to
CORSMiddleware
. See #1111, #1112, #1113, #1199. - Improved exception messages in the case of duplicated path parameter names - #1177.
RedirectResponse
now usesquote
instead ofquote_plus
encoding for theLocation
header to better match the behaviour in other frameworks such as Django - #1164.- Exception causes are now preserved in more cases - #1158.
- Session cookies now use the ASGI root path in the case of mounted applications - #1147.
- Fixed a cache invalidation bug when static files were deleted in certain circumstances - #1023.
- Improved memory usage of
BaseHTTPMiddleware
when handling large responses - #1012 fixed via #1157
Deprecated/removed
- Built-in GraphQL support via the
GraphQLApp
class has been deprecated and will be removed in a future release. Please see #619. GraphQL is not supported on Python 3.10. - The
executor
parameter toGraphQLApp
was removed. Useexecutor_class
instead. - The
workers
parameter toWSGIMiddleware
was removed. This hasn't had any effect since Starlette v0.6.3.
0.14.2
February 2, 2021
Fixed
- Fixed
ServerErrorMiddleware
compatibility with Python 3.9.1/3.8.7 when debug mode is enabled - #1132. - Fixed unclosed socket
ResourceWarning
s when using theTestClient
with WebSocket endpoints - #1132. - Improved detection of
async
endpoints wrapped infunctools.partial
on Python 3.8+ - #1106.
0.14.1
November 9th, 2020
Removed
UJSONResponse
was removed (this change was intended to be included in 0.14.0). Please see the documentation for how to implement responses using custom JSON serialization - #1074.
0.14.0
November 8th, 2020
Added
- Starlette now officially supports Python3.9.
- In
StreamingResponse
, allow custom async iterator such as objects from classes implementing__aiter__
. - Allow usage of
functools.partial
async handlers in Python versions 3.6 and 3.7. - Add 418 I'm A Teapot status code.
Changed
- Create tasks from handler coroutines before sending them to
asyncio.wait
. - Use
format_exception
instead offormat_tb
inServerErrorMiddleware
'sdebug
responses. - Be more lenient with handler arguments when using the
requires
decorator.
0.13.8
-
Revert
Queue(maxsize=1)
fix forBaseHTTPMiddleware
middleware classes and streaming responses. -
The
StaticFiles
constructor now allowspathlib.Path
in addition to strings for itsdirectory
argument.
0.13.7
- Fix high memory usage when using
BaseHTTPMiddleware
middleware classes and streaming responses.
0.13.6
- Fix 404 errors with
StaticFiles
.
0.13.5
- Add support for
Starlette(lifespan=...)
functions. - More robust path-traversal check in StaticFiles app.
- Fix WSGI PATH_INFO encoding.
- RedirectResponse now accepts optional background parameter
- Allow path routes to contain regex meta characters
- Treat ASGI HTTP 'body' as an optional key.
- Don't use thread pooling for writing to in-memory upload files.
0.13.0
- Switch to promoting application configuration on init style everywhere. This means dropping the decorator style in favour of declarative routing tables and middleware definitions.
0.12.12
- Fix
request.url_for()
for the Mount-within-a-Mount case.
0.12.11
- Fix
request.url_for()
when an ASGIroot_path
is being used.
0.12.1
- Add
URL.include_query_params(**kwargs)
- Add
URL.replace_query_params(**kwargs)
- Add
URL.remove_query_params(param_names)
request.state
properly persisting across middleware.- Added
request.scope
interface.
0.12.0
- Switch to ASGI 3.0.
- Fixes to CORS middleware.
- Add
StaticFiles(html=True)
support. - Fix path quoting in redirect responses.
0.11.1
- Add
request.state
interface, for storing arbitrary additional information. - Support disabling GraphiQL with
GraphQLApp(..., graphiql=False)
.
0.11.0
DatabaseMiddleware
is now dropped in favour ofdatabases
- Templates are no longer configured on the application instance. Use
templates = Jinja2Templates(directory=...)
andreturn templates.TemplateResponse('index.html', {"request": request})
- Schema generation is no longer attached to the application instance. Use
schemas = SchemaGenerator(...)
andreturn schemas.OpenAPIResponse(request=request)
LifespanMiddleware
is dropped in favor of router-based lifespan handling.- Application instances now accept a
routes
argument,Starlette(routes=[...])
- Schema generation now includes mounted routes.
0.10.6
- Add
Lifespan
routing component.
0.10.5
- Ensure
templating
does not strictly requirejinja2
to be installed.
0.10.4
- Templates are now configured independently from the application instance.
templates = Jinja2Templates(directory=...)
. Existing API remains in place, but is no longer documented, and will be deprecated in due course. See the template documentation for more details.
0.10.3
- Move to independent
databases
package instead ofDatabaseMiddleware
. Existing API remains in place, but is no longer documented, and will be deprecated in due course.
0.10.2
- Don't drop explicit port numbers on redirects from
HTTPSRedirectMiddleware
.
0.10.1
- Add MySQL database support.
- Add host-based routing.
0.10.0
- WebSockets now default to sending/receiving JSON over text data frames. Use
.send_json(data, mode="binary")
and.receive_json(mode="binary")
for binary framing. GraphQLApp
now takes anexecutor_class
argument, which should be used in preference to the existingexecutor
argument. Resolves an issue with async executors being instantiated before the event loop was setup. Theexecutor
argument is expected to be deprecated in the next median or major release.- Authentication and the
@requires
decorator now support WebSocket endpoints. MultiDict
andImmutableMultiDict
classes are available inuvicorn.datastructures
.QueryParams
is now instantiated with standard dict-style*args, **kwargs
arguments.
0.9.11
- Session cookies now include browser 'expires', in addition to the existing signed expiry.
request.form()
now returns a multi-dict interface.- The query parameter multi-dict implementation now mirrors
dict
more correctly for the behavior of.keys()
,.values()
, and.items()
when multiple same-key items occur. - Use
urlsplit
throughout in favor ofurlparse
.
0.9.10
- Support
@requires(...)
on class methods. - Apply URL escaping to form data.
- Support
HEAD
requests automatically. - Add
await request.is_disconnected()
. - Pass operationName to GraphQL executor.
0.9.9
- Add
TemplateResponse
. - Add
CommaSeparatedStrings
datatype. - Add
BackgroundTasks
for multiple tasks. - Common subclass for
Request
andWebSocket
, to eg. sharesession
functionality. - Expose remote address with
request.client
.
0.9.8
- Add
request.database.executemany
.
0.9.7
- Ensure that
AuthenticationMiddleware
handles lifespan messages correctly.
0.9.6
- Add
AuthenticationMiddleware
, and@requires()
decorator.
0.9.5
- Support either
str
orSecret
forSessionMiddleware(secret_key=...)
.
0.9.4
- Add
config.environ
. - Add
datastructures.Secret
. - Add
datastructures.DatabaseURL
.
0.9.3
- Add
config.Config(".env")
0.9.2
- Add optional database support.
- Add
request
to GraphQL context. - Hide any password component in
URL.__repr__
.
0.9.1
- Handle startup/shutdown errors properly.
0.9.0
TestClient
can now be used as a context manager, instead ofLifespanContext
.- Lifespan is now handled as middleware. Startup and Shutdown events are visible throughout the middleware stack.
0.8.8
- Better support for third-party API schema generators.
0.8.7
- Support chunked requests with TestClient.
- Cleanup asyncio tasks properly with WSGIMiddleware.
- Support using TestClient within endpoints, for service mocking.
0.8.6
- Session cookies are now set on the root path.
0.8.5
- Support URL convertors.
- Support HTTP 304 cache responses from
StaticFiles
. - Resolve character escaping issue with form data.
0.8.4
- Default to empty body on responses.
0.8.3
- Add 'name' argument to
@app.route()
. - Use 'Host' header for URL reconstruction.
0.8.2
StaticFiles
- StaticFiles no longer reads the file for responses to
HEAD
requests.
0.8.1
Templating
- Add a default templating configuration with Jinja2.
Allows the following:
app = Starlette(template_directory="templates")
@app.route('/')
async def homepage(request):
# `url_for` is available inside the template.
template = app.get_template('index.html')
content = template.render(request=request)
return HTMLResponse(content)
0.8.0
Exceptions
- Add support for
@app.exception_handler(404)
. - Ensure handled exceptions are not seen as errors by the middleware stack.
SessionMiddleware
- Add
max_age
, and use timestamp-signed cookies. Defaults to two weeks.
Cookies
- Ensure cookies are strictly HTTP correct.
StaticFiles
- Check directory exists on instantiation.
0.7.4
Concurrency
- Add
starlette.concurrency.run_in_threadpool
. Now handlescontextvar
support.
0.7.3
Routing
- Add
name=
support toapp.mount()
. This allows eg:app.mount('/static', StaticFiles(directory='static'), name='static')
.
0.7.2
Middleware
- Add support for
@app.middleware("http")
decorator.
Routing
- Add "endpoint" to ASGI scope.
0.7.1
Debug tracebacks
- Improve debug traceback information & styling.
URL routing
- Support mounted URL lookups with "path=", eg.
url_for('static', path=...)
. - Support nested URL lookups, eg.
url_for('admin:user', username=...)
. - Add redirect slashes support.
- Add www redirect support.
Background tasks
- Add background task support to
FileResponse
andStreamingResponse
.
0.7.0
API Schema support
- Add
app.schema_generator = SchemaGenerator(...)
. - Add
app.schema
property. - Add
OpenAPIResponse(...)
.
GraphQL routing
- Drop
app.add_graphql_route("/", ...)
in favor of more consistentapp.add_route("/", GraphQLApp(...))
.
0.6.3
Routing API
- Support routing to methods.
- Ensure
url_path_for
works with Mount('/{some_path_params}'). - Fix Router(default=) argument.
- Support repeated paths, like:
@app.route("/", methods=["GET"])
,@app.route("/", methods=["POST"])
- Use the default ThreadPoolExecutor for all sync endpoints.
0.6.2
SessionMiddleware
Added support for request.session
, with SessionMiddleware
.
0.6.1
BaseHTTPMiddleware
Added support for BaseHTTPMiddleware
, which provides a standard
request/response interface over a regular ASGI middleware.
This means you can write ASGI middleware while still working at a request/response level, rather than handling ASGI messages directly.
from starlette.applications import Starlette
from starlette.middleware.base import BaseHTTPMiddleware
class CustomMiddleware(BaseHTTPMiddleware):
async def dispatch(self, request, call_next):
response = await call_next(request)
response.headers['Custom-Header'] = 'Example'
return response
app = Starlette()
app.add_middleware(CustomMiddleware)
0.6.0
request.path_params
The biggest change in 0.6 is that endpoint signatures are no longer:
async def func(request: Request, **kwargs) -> Response
Instead we just use:
async def func(request: Request) -> Response
The path parameters are available on the request as request.path_params
.
This is different to most Python webframeworks, but I think it actually ends up being much more nicely consistent all the way through.
request.url_for()
Request and WebSocketSession now support URL reversing with request.url_for(name, **path_params)
.
This method returns a fully qualified URL
instance.
The URL instance is a string-like object.
app.url_path_for()
Applications now support URL path reversing with app.url_path_for(name, **path_params)
.
This method returns a URL
instance with the path and scheme set.
The URL instance is a string-like object, and will return only the path if coerced to a string.
app.routes
Applications now support a .routes
parameter, which returns a list of [Route|WebSocketRoute|Mount]
.
Route, WebSocketRoute, Mount
The low level components to Router
now match the @app.route()
, @app.websocket_route()
, and app.mount()
signatures.