Skip to content

madeye/meow

Repository files navigation

Meow

Feature Graphic

A Clash/mihomo Android client with Flutter UI, powered by mihomo-rust and netstack-smoltcp tun2socks.

Download

Get it on Google Play Download from GitHub

Architecture

Flutter UI (Dart)
    |  MethodChannel / EventChannel
    v
Android Native (Kotlin)
    |  VpnService + AIDL IPC
    |  JNI (System.loadLibrary)
    v
Rust FFI (libmihomo_android_ffi.so)
    |  netstack-smoltcp tun2socks
    |  Per-socket VpnService.protect() via JNI
    v
mihomo-rust (Cargo dependency)
    |  Tunnel, Config, Proxy, API
    v
Network

Features

  • Proxy Protocols: Shadowsocks, Trojan, Direct
    • Shadowsocks plugins: built-in simple-obfs (HTTP/TLS) and v2ray-plugin (WebSocket, optional TLS) — no external SIP003 binary required
  • Rule Engine: Domain, IP, port, geo-based routing, rule-providers
  • tun2socks: Pure Rust via netstack-smoltcp (no C dependencies)
  • DNS: DoH forwarding through proxy chain
  • Socket Protection: Per-socket VpnService.protect(fd) via JNI callback
  • Flutter UI: Shadowrocket-style tab view
    • Home: VPN toggle, proxy node selection, connection status
    • Subscribe: Add/edit/remove subscriptions, view proxy nodes, YAML editor
    • Traffic: Real-time speed chart, session upload/download stats
    • Settings: Version, network config, per-app VPN proxy/bypass, about
  • i18n: English, Chinese (zh_CN)
  • E2E Tests: Automated with ssserver + Android emulator

Building

Prerequisites

  • Android SDK (API 36) with NDK
  • Rust toolchain with Android targets:
    rustup target add aarch64-linux-android armv7-linux-androideabi i686-linux-android x86_64-linux-android
    
  • Flutter SDK (3.x)
  • JDK 17

Build

# Generate Flutter module files
cd flutter_module && flutter pub get && cd ..

# Build debug APK (arm64 only, release Rust)
export JAVA_HOME=/path/to/jdk17
./gradlew :mobile:assembleDebug -PTARGET_ABI=arm64 -PCARGO_PROFILE=release

The APK is at mobile/build/outputs/apk/debug/mobile-arm64-v8a-debug.apk.

E2E Test

# Requires: ssserver, Android emulator, adb
./test-e2e.sh

Project Structure

core/                           Android library module
  src/main/java/                Kotlin: VPN service, AIDL, Room DB
  src/main/rust/
    mihomo-android-ffi/         Rust FFI crate (JNI + tun2socks)
    mihomo-proxy-patched/       Patched proxy adapters (socket protection)
flutter_module/                 Flutter UI module
  lib/screens/                  Home, Subscriptions, Traffic, Settings
  lib/l10n/                     Localization (en, zh_CN)
mobile/                         Android app module (FlutterActivity host)
test-e2e.sh                     End-to-end test script

License

MIT - Max Lv max.c.lv@gmail.com

About

Meow - A Clash/mihomo Android client with Flutter UI, powered by mihomo-rust and netstack-smoltcp tun2socks

Topics

Resources

License

Stars

Watchers

Forks

Packages