openclaw/apps/ios
Peter Steinberger b98b113b88 fix(ios): harden share relay routing and delivery guards 2026-02-17 23:47:34 +01:00
..
Config feat(ios): auto-select local signing team (#18421) 2026-02-18 03:16:10 +08:00
ShareExtension fix(ios): harden share relay routing and delivery guards 2026-02-17 23:47:34 +01:00
Sources fix(ios): harden share relay routing and delivery guards 2026-02-17 23:47:34 +01:00
Tests chore(release): bump version to 2026.2.17 2026-02-17 23:08:55 +01:00
fastlane feat(ios): auto-select local signing team (#18421) 2026-02-18 03:16:10 +08:00
.swiftlint.yml feat: add prek pre-commit hooks and dependabot (#1720) 2026-01-25 10:53:23 +00:00
LocalSigning.xcconfig.example feat: share to openclaw ios app (#19424) 2026-02-17 20:08:50 +00:00
README.md feat(ios): auto-select local signing team (#18421) 2026-02-18 03:16:10 +08:00
Signing.xcconfig feat: share to openclaw ios app (#19424) 2026-02-17 20:08:50 +00:00
SwiftSources.input.xcfilelist iOS: alpha node app + setup-code onboarding (#11756) 2026-02-08 18:08:13 +01:00
project.yml chore(release): bump version to 2026.2.17 2026-02-17 23:08:55 +01:00

README.md

OpenClaw (iOS)

This is an alpha iOS app that connects to an OpenClaw Gateway as a role: node.

Expect rough edges:

  • UI and onboarding are changing quickly.
  • Background behavior is not stable yet (foreground app is the supported mode right now).
  • Permissions are opt-in and the app should be treated as sensitive while we harden it.

What It Does

  • Connects to a Gateway over ws:// / wss://
  • Pairs a new device (approved from your bot)
  • Exposes phone services as node commands (camera, location, photos, calendar, reminders, etc; gated by iOS permissions)
  • Provides Talk + Chat surfaces (alpha)

If your Gateway has the device-pair plugin installed:

  1. In Telegram, message your bot: /pair
  2. Copy the setup code message
  3. On iOS: OpenClaw → Settings → Gateway → paste setup code → Connect
  4. Back in Telegram: /pair approve

Build And Run

Prereqs:

  • Xcode (current stable)
  • pnpm
  • xcodegen

From the repo root:

pnpm install
pnpm ios:open

pnpm ios:open now runs scripts/ios-configure-signing.sh before xcodegen:

  • If IOS_DEVELOPMENT_TEAM is set, it uses that team.
  • Otherwise it prefers the canonical OpenClaw team (Y5PE65HELJ) when that team exists locally.
  • If not present, it picks the first non-personal team from your Xcode account (falls back to personal team if needed).
  • It writes the selected team to apps/ios/.local-signing.xcconfig (local-only, gitignored).

Then in Xcode:

  1. Select the OpenClaw scheme
  2. Select a simulator or a connected device
  3. Run

If you're using a personal Apple Development team, you may still need to change the bundle identifier in Xcode to a unique value so signing succeeds.

Build From CLI

pnpm ios:build

Tests

cd apps/ios
xcodegen generate
xcodebuild test -project OpenClaw.xcodeproj -scheme OpenClaw -destination "platform=iOS Simulator,name=iPhone 17"

Shared Code

  • apps/shared/OpenClawKit contains the shared transport/types used by the iOS app.