Skip to main content

A framework for controlling Android devices through LLM agents

Project description

Fremko

Android device control framework with LLM-powered agents, a WebSocket control plane, and a FastAPI web UI. Run the server on your computer, connect your phone, and automate interactions (tap, swipe, input, launch apps), stream the screen, and drive goals with your preferred LLM.

Features

  • Control Android devices over WebSocket via an on-device accessibility service (Fremko Portal)
  • Built-in CLI to run a control server or a combined web UI + HTTP API
  • FastAPI endpoints and a minimal web dashboard for live preview and actions
  • Pluggable LLM backends (OpenAI, Anthropic, Google GenAI, DeepSeek, Ollama) via llama-index

Prerequisites

  • Python 3.10+
  • adb available in your PATH. (Optional)
  • An Android device with Developer Options + USB debugging enabled. (Optional)
  • Fremko Portal app (see link below)

Installation

Usage (PyPI):

pip install fremko

Development (from source):

# Requires Python 3.10+
git clone https://github.com/johnmalek312/fremko.git
cd fremko
pip install -e .

Quickstart

  1. Prepare your Android device
  • Enable Developer Options and USB debugging.
  • Install and set up the Fremko Portal app: https://www.github.com/johnmalek312/fremko-portal
  • From your computer, you can also try:
fremko setup   # installs the APK (if needed) and opens Accessibility settings to enable the Portal
fremko enable  # grants accessibility permission to the Fremko Portal app
fremko ping    # verifies the Portal is installed + reachable
  1. Start the server on your computer
fremko web

Then open http://localhost:8080 to view the dashboard.

  1. Connect the phone to the server
  • In the Fremko Portal app on the phone, set the server URL to ws://<your-computer-ip>:10001
  • Once connected, the device appears under Clients in the web UI

CLI

# Run WebSocket server only
fremko server [--provider GoogleGenAI] [--model models/gemini-2.5-flash] [--ws-port 10001]

# Run server + web UI/HTTP API (recommended)
fremko web [--ws-port 10001] [--http-port 8080] [--host 0.0.0.0]

# ADB helpers
fremko devices
fremko connect <ip:port>
fremko disconnect <ip:port>

# Device readiness
fremko enable                  # gives accessibility permission to the Fremko Portal app on your device
fremko setup [-d SERIAL]       # installs the APK (if needed) and enables the Portal accessibility service
fremko ping  [-d SERIAL]       # verifies the Portal is installed + reachable

Common options: --provider, --model, --temperature, --steps, --base_url, --api_base, --reasoning, --reflection, --tracing, --debug.

Web UI and HTTP API

When you run fremko web, a FastAPI app serves the dashboard and a simple API:

  • GET /api/clients — list connected clients
  • GET /api/clients/{id} — client details
  • POST /api/clients/{id}/goal — start an agent goal
  • GET /api/clients/{id}/screenshot — latest screenshot
  • GET /api/clients/{id}/state — accessibility tree + phone state
  • POST /api/clients/{id}/tap — tap at coordinates
  • POST /api/clients/{id}/swipe — straight-line swipe
  • POST /api/clients/{id}/gesture_path — arbitrary path gesture
  • POST /api/clients/{id}/input — input text
  • POST /api/clients/{id}/key — press Android keycode
  • POST /api/clients/{id}/start_app — start an app
  • POST /api/clients/{id}/stream/{start|update|stop} — control device-to-server video stream
  • GET /ws/preview/{id} — WebSocket with JPEG frames for browser preview

Preview streaming is backed by H.264 decoding on the server and JPEG frames to the browser.

Configuration (LLMs)

LLM selection and configuration are handled through llama-index integrations. Set relevant environment variables for your provider:

  • Google GenAI: GOOGLE_API_KEY
  • OpenAI / compatible: OPENAI_API_KEY, optional OPENAI_BASE_URL
  • Anthropic: ANTHROPIC_API_KEY
  • DeepSeek: DEEPSEEK_API_KEY
  • Ollama: ensure the local Ollama service is running and configure base URL if needed

Defaults: provider GoogleGenAI, model models/gemini-2.5-flash.

Troubleshooting

  • No clients in UI: ensure the phone Portal is connected to ws://<host>:10001 and the server is reachable from the device’s network.
  • Accessibility errors: open Accessibility settings on the phone and enable the Fremko Portal service.
  • Screenshots/stream not working: check that screen-capture permissions are granted in the Portal, then re-enable if needed.
  • ADB device not found: verify adb devices, USB debugging, authorization prompts, and cables/drivers.

License

MIT

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fremko-0.1.3.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fremko-0.1.3-py3-none-any.whl (97.7 kB view details)

Uploaded Python 3

File details

Details for the file fremko-0.1.3.tar.gz.

File metadata

  • Download URL: fremko-0.1.3.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fremko-0.1.3.tar.gz
Algorithm Hash digest
SHA256 741d317182a8d1b09d1125a590fa6efb426215451136b330bcc737e51b9a8d94
MD5 d0a70a088ed1f51f008cbf9f4a744f2b
BLAKE2b-256 3859689c3539d68078bac59128c40da89fcf833da46ef0bc01f371f221c7ee7a

See more details on using hashes here.

File details

Details for the file fremko-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: fremko-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 97.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fremko-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 17296a659cb7a49fa31cfca4491b0323a43e9165d238c8d8ceb9e92111e67a91
MD5 32f99dac44700dbc2345888c64b49f06
BLAKE2b-256 93c2a1a078f006722a93ca6a7f7286eec2bdf8307a6346f82f26cba65e19b15f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page