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.2.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.2-py3-none-any.whl (97.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fremko-0.1.2.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.2.tar.gz
Algorithm Hash digest
SHA256 ceb4d3bd6b0f83342fc957198f413c103a6390a00000544df6276dea702c34f5
MD5 aff758fa3af0cbe9355ea32cb106bf10
BLAKE2b-256 c9c9c4d3f54a5d18164cd6aff46ed491447a9ec56c5214147305538047132ec9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: fremko-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 97.6 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b6e382e444d750d40d7a0f422eac75afaca7c739a6af41d0e68d4735d06a5077
MD5 05ec1efbede9d571aadcb387baf24629
BLAKE2b-256 cc9db5ddbba87ce5c575345436215388c43af417a375363d495b6631076b7cfe

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