CtrlK
BlogDocsLog inGet started
Tessl Logo

stream-android

Build and integrate Stream Chat, Video, and Feeds in Android apps. Use for Jetpack Compose, Android Studio, and Gradle project work — including Stream package setup, auth and token wiring, screen blueprints, and any follow-up Stream UI work such as adding screens, navigating between channel list and channel/message screens, channel tap handling, deep links, push routing, theming, custom channel/message UI, video calling flows (joining/starting calls, ringing, custom call controls and participant tiles), and Feeds surfaces (timeline, activity composer, threaded comments, follow graph / profile, notification feed, stories).

Invalid
This skill can't be scored yet
Validation errors are blocking scoring. Review and fix them to unlock Quality, Impact and Security scores. See what needs fixing →
SKILL.md
Quality
Evals
Security

Stream Android - skill router + execution flow

Rules: Read RULES.md once per session - every non-negotiable rule is stated there, nowhere else.

This file is the single entrypoint: intent classification, local project detection, and module pointers for Stream work in Android apps.


Step 0: Intent classifier (mandatory first - never skip)

Before any tool call, decide the track from the user's input alone - no probes first.

Signals -> track

Signal in user inputTrack
Explicit product/framework token: Chat Compose, Chat XML, Video Android, Video Compose, Feeds Android, Feeds Compose, etc.C - Reference lookup
Words "docs" or "documentation" around Stream Android/Compose workC - Reference lookup
"How do I {X} in Compose/XML/Android?", "What does {SDK type/Composable/View/Fragment} do?"C - Reference lookup
"Build me a new Android app", "create a Compose app", "new Android app" + Stream productA - New app
"Add/integrate Stream into this app", "wire Chat/Video/Feeds into my Android project"B - Existing app
"Install Stream packages", "set up Stream in Android Studio", "wire auth/token flow" with no broader feature requestD - Bootstrap / setup
Bare /stream-android with no argsList the tracks briefly and wait

Disambiguation flow

If the request is ambiguous between build/integrate and reference lookup, ask one short question and wait:

Do you want me to wire this into the project, or just map the Android SDK pattern and files?

After classification

  • Tracks A, B, D -> run Step 0.5 (credentials) first, then Project signals once per session, then continue in builder.md and sdk.md. Do not probe the project before credentials.
  • Track C -> skip both steps if the product + UI layer are explicit. Only run Project signals on demand if the SDK or UI layer is ambiguous.

Step 0.5: Credentials, token, and seed data (tracks A, B, D only)

Order: intent classification -> Step 0.5 (this step) -> Project signals probe -> track work. Do this before running the Project signals shell command, even if a track table below lists "Detect" as phase 1. Run once per session for tracks A, B, and D. Skip for Track C.

Follow credentials.md to:

  • collect the Stream API key from the dashboard (or from the user)
  • generate a user token via the Stream CLI (or accept one from the user)
  • run any product-specific setup (Chat: optionally seed channels; Feeds: confirm feed groups; Video: nothing — calls are ephemeral)

Wire the API key from getstream env's output (e.g. BuildConfig.STREAM_API_KEY) and use the real user token in code snippets - never placeholder strings. If a track A/B/D task reaches code work and credentials haven't been collected yet, return to credentials.md before continuing.


Project signals (tracks A/B/D - once per session; Track C on demand only)

Read-only local probe. Use it to detect whether the user is in an Android Studio / Gradle project, a Kotlin module, or an empty directory.

bash -c 'echo "=== GRADLE ROOT ==="; find . -maxdepth 2 \( -name "settings.gradle.kts" -o -name "settings.gradle" -o -name "build.gradle.kts" -o -name "build.gradle" \) -print 2>/dev/null; echo "=== APP MODULES ==="; find . -maxdepth 3 -type f \( -name "build.gradle.kts" -o -name "build.gradle" \) -path "*/*/build.gradle*" -print 2>/dev/null; echo "=== VERSION CATALOG ==="; find . -maxdepth 3 -name "libs.versions.toml" -print 2>/dev/null; echo "=== MANIFESTS ==="; find . -maxdepth 4 -name "AndroidManifest.xml" -print 2>/dev/null; echo "=== EMPTY ==="; test -z "$(ls -A 2>/dev/null)" && echo "EMPTY_CWD" || echo "NON_EMPTY"'

Hold the result in conversation context. Don't re-run it unless the user changes directory or the project shape clearly changed.

Use the result to produce a one-line status, for example:

  • Compose app detected - app/build.gradle.kts - libs.versions.toml present - ready for Stream wiring
  • Multi-module Gradle project detected - preserve existing module layout
  • XML / View-based app detected - keep current UI layer unless the user asks to migrate
  • No Gradle project found - user needs to create the app in Android Studio first

Module map

TrackModule(s)
A - New appbuilder.md + sdk.md + relevant reference files
B - Existing appbuilder.md + sdk.md + relevant reference files
C - Reference lookupsdk.md + relevant reference files
D - Bootstrap / setupbuilder.md + sdk.md

Reference layout

Shared Android/Kotlin patterns live in sdk.md.

Product and UI-layer specifics live under references/ using a flat naming scheme that can grow with the full Stream Android surface:

  • Reference: references/<PRODUCT>-<UI_LAYER>.md
  • Blueprints: references/<PRODUCT>-<UI_LAYER>-blueprints.md

Current extracted modules:

Feeds has no pre-built UI components. FEEDS-COMPOSE.md covers the headless data SDK (FeedsClient, FeedState, ActivityState); FEEDS-COMPOSE-blueprints.md is custom Composable scaffolding driven by those state flows. Load both for any Feeds request.

Future Android product coverage should stay in this naming family instead of creating more top-level skills.

If the requested product/UI layer file is not bundled yet, say so plainly, use sdk.md for the shared Android patterns, and only switch to live docs if the user asks.


Track A - New app

Full detail: builder.md - use the new-project path.

PhaseNameWhat you do
A1DetectAfter Step 0.5 (credentials), run Project signals. If there is no Android app yet, tell the user to create one in Android Studio first.
A2Choose laneConfirm product(s) and UI layer: Compose, XML/Views, or mixed.
A3Install + wireFollow builder.md + sdk.md, then load only the needed product references.
A4VerifyConfirm Gradle sync, ChatClient lifetime, auth, and first rendered screen.

Track B - Existing app

Full detail: builder.md - use the existing-project path.

PhaseNameWhat you do
B1DetectAfter Step 0.5 (credentials), run Project signals and inspect the existing app structure before editing.
B2PreserveKeep the current UI layer, dependency strategy (version catalog vs inline), and navigation setup unless the user asks for a migration.
B3IntegrateUse sdk.md for shared wiring, then load only the needed product reference files.
B4VerifyConfirm the requested Stream flow builds and renders inside the existing app.

Track C - Reference lookup

Load only the relevant files for the requested product and UI layer.

If the user asks for a product/UI-layer combo that is not bundled (e.g. Video XML, Feeds XML), say that clearly instead of inventing API details.


Track D - Bootstrap / setup

Use when the user wants the install and wiring path more than a feature build:

  • run Step 0.5 (credentials) first
  • detect the project shape
  • choose Compose vs XML ownership
  • install Stream packages with the project's existing dependency strategy (version catalog or inline)
  • wire auth and ChatClient lifetime via sdk.md
  • stop before product-specific UI if the user only asked for setup
Repository
GetStream/agent-skills
Last updated
Created

Is this your skill?

If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.