Skip to content

feat!(spawn-docker-jdk): replace OkHttp and junixsocket with pure JDK HTTP#11

Merged
deer merged 1 commit intomainfrom
okhttp_removal
Apr 8, 2026
Merged

feat!(spawn-docker-jdk): replace OkHttp and junixsocket with pure JDK HTTP#11
deer merged 1 commit intomainfrom
okhttp_removal

Conversation

@deer
Copy link
Copy Markdown
Collaborator

@deer deer commented Apr 8, 2026

Replaces the OkHttp-based Docker client with a zero-third-party-dependency implementation using only standard JDK APIs.

What changed:

  • Renamed module spawn-docker-okhttpspawn-docker-jdk (package build.spawn.docker.jdk)
  • Introduced HttpTransport interface decoupling all 22 command classes from any HTTP library
  • TCP sessions now use java.net.http.HttpClient (JavaHttpClientTransport)
  • Unix domain socket sessions now use java.nio.channels.SocketChannel + UnixDomainSocketAddress (UnixSocketHttpTransport) — no more junixsocket
  • Http11Parser handles HTTP/1.1 framing (status line, headers, Content-Length, chunked) over raw socket streams
  • Deleted OkHttp-specific dead code: ConnectTimeout, ReadTimeout, WriteTimeout option classes

Dependencies removed:

  • com.squareup.okhttp3:okhttp
  • org.jetbrains.kotlin:kotlin-stdlib
  • com.kohlschutter.junixsocket:junixsocket-common
  • com.kohlschutter.junixsocket:junixsocket-native-common

Tests added: Http11ParserTest, JavaHttpClientTransportTest

@deer deer merged commit 5bcbfdb into main Apr 8, 2026
1 check passed
@deer deer deleted the okhttp_removal branch April 8, 2026 13:34
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.

1 participant