blockads-dev

star 1.1k

Assistance with Go and Kotlin interop, VPN architecture, and tunnel building in the BlockAds Android app. Use when adding features to the Go tunnel, working with gomobile, or modifying the VPN service.

pass-with-high-score By pass-with-high-score schedule Updated 4/5/2026

name: blockads-dev description: Assistance with Go and Kotlin interop, VPN architecture, and tunnel building in the BlockAds Android app. Use when adding features to the Go tunnel, working with gomobile, or modifying the VPN service.

BlockAds Dev Skill

Overview

This skill provides expert guidance on the blockads-android project, which combines a Go-based VPN tunnel (tunnel/) with an Android Kotlin application (app/src/main/java/...). It helps handle gomobile interop constraints, architectural patterns for the VPN service, and building/debugging the tunnel.

Development Workflows

1. Modifying the Go Tunnel (gomobile)

When adding a new feature or modifying existing logic in the Go tunnel:

  • Edit the relevant .go files in the tunnel/ directory (e.g., tunnel/engine.go).
  • Ensure all exported functions, methods, and interfaces in Go use strictly gomobile-compatible types (primitives, []byte, basic interfaces).
  • Rebuild the tunnel using ./scripts/build_tunnel.sh or the Gradle task ./gradlew buildGoTunnel.
  • For detailed constraints on gomobile bindings, read references/gomobile-interop.md.

2. Updating the Android Kotlin App

When integrating new Go tunnel features into Android:

  • Update GoTunnelAdapter.kt or VpnService.kt to call the newly bound Go methods.
  • Ensure Kotlin interfaces passed to Go (e.g., LogCallback, DomainChecker) match the updated Go interfaces.
  • For a deeper understanding of the VPN architecture and data flow, read references/architecture.md.

3. Debugging

  • DNS Tracing: The Go engine logs queries via the LogCallback interface to Kotlin. To debug DNS, check DnsLogDao or add prints in the Kotlin callback.
  • Root Mode (iptables): The app uses libsu for a root-based transparent proxy mode as an alternative to VpnService. Check RootProxyService and IptablesManager for related logic. See references/root-proxy.md for architecture details.

References

  • Architecture: Deep dive into the Go Tunnel Engine and Kotlin VPN Service architecture.
  • Root Proxy Mode: Deep dive into the RootProxyService and iptables transparent proxy architecture.
  • Gomobile Interop: Rules, constraints, and patterns for passing data between Go and Kotlin via gomobile bind.
Install via CLI
npx skills add https://github.com/pass-with-high-score/blockads-android --skill blockads-dev
Repository Details
star Stars 1,054
call_split Forks 60
navigation Branch main
article Path SKILL.md
More from Creator
pass-with-high-score
pass-with-high-score Explore all skills →