-
Couldn't load subscription status.
- Fork 135
Open
Description
I have a server that is functionally similar in setup to hummingbird-examples/http2, when I use async-http-client to make a request with a command line program that exits after the request, humming bird reports this error:
[HummingbirdHTTP2] Error handling inbound connection for HTTP2 handler: uncleanShutdown I do not see the same error when using curl:
curl --cacert certs/ca.crt --http2 -v https://localhost:8043/healthcheck var tlsConfiguration: TLSConfiguration { get throws { let certificateChain = try NIOSSLCertificate.fromPEMFile(self.certificateChain) var tlsConfiguration = TLSConfiguration.makeClientConfiguration() tlsConfiguration.trustRoots = .certificates(certificateChain) #if os(macOS) tlsConfiguration.certificateVerification = .none #else // not supported with Network.framework tlsConfiguration.certificateVerification = .noHostnameVerification #endif return tlsConfiguration } } relevant code in the run() async throws method of an AsyncParsableCommand:
var clientConfig = HTTPClient.Configuration() clientConfig.tlsConfiguration = try self.tlsConfiguration try await HTTPClient.withHTTPClient(configuration: clientConfig) { client in var request = HTTPClientRequest(url: url.absoluteString) request.method = .POST request.headers.add(name: "content-type", value: "application/json") request.headers.add(name: "content-length", value: "\(payloadData.count)") request.body = .bytes(payloadData) let response = try await client.execute(request, timeout: .seconds(30)) let body = try await response.body.collect(upTo: 10 * 1024 * 1024) } I've tried many variations that all execute await client.shutdown() before exiting and they all result in this error. From what Cory says here: https://forums.swift.org/t/niossl-spurious-uncleanshutdown-error/53031/3 it seems like AHC isn't sending CLOSE_NOTIFY on shutdown?
Metadata
Metadata
Assignees
Labels
No labels