- Require Dart 3.2
- Populate the pubspec
repository
field.
- Honor the
preserveHeaderCase
argument toMultiHeaders.set
and.add
.
- Add
HttpMultiServer.bindSecure
to matchHttpMultiServer.bind
.
- Fix an issue where
bind
would bind to theanyIPv6
address in unsupported environments.
- Migrate to null safety.
- Preparation for HttpHeaders change. Update signature of
MultiHeaders.add()
andMultiHeaders.set()
to match new signature ofHttpHeaders
. The parameter is not yet forwarded and will not behave as expected.
- Add
HttpMultiServer.bind
static which centralizes logic around common local serving scenarios - handling a more flexible 'localhost' and listening on 'any' hostname. - Update SDK constraints to
>=2.1.0 <3.0.0
.
- If there is a problem starting a loopback Ipv6 server, don't keep the Ipv4 server open when throwing the exception.
- Update SDK constraints to
>=2.0.0-dev <3.0.0
.
- Declare support for
async
2.0.0.
- Fix
HttpMultiServer.loopback()
and.loopbackSecure()
for environments that don't support IPv4.
- Fix a dependency that was incorrectly marked as dev-only.
- Fix most strong mode errors and warnings.
-
Breaking: Change the signature of
HttpMultiServer.loopbackSecure()
to match the new Dart 1.13HttpServer.bindSecure()
signature. This removes thecertificateName
named parameter and adds the requiredcontext
parameter and the namedv6Only
andshared
parameters. -
Added
v6Only
andshared
parameters toHttpMultiServer.loopback()
to matchHttpServer.bind()
.
-
Eventually stop retrying port allocation if it fails repeatedly.
-
Properly detect socket errors caused by already-in-use addresses.
loopback()
andloopbackSecure()
recover gracefully if an ephemeral port is requested and the located port isn't available on both IPv4 and IPv6.
- Add support for
HttpServer.autoCompress
.
-
Add support for
HttpServer.defaultResponseHeaders.clear
. -
Fix
HttpServer.defaultResponseHeaders.remove
and.removeAll
.
- Add support for
HttpServer.defaultResponseHeaders
.
- Remove the workaround for issue 19815.
- Ignore errors from one of the servers if others are still bound. In particular, this works around issue 19815 on some Windows machines where IPv6 failure isn't discovered until we try to connect to the socket.