palmier
Health Uyari
- License — License: Apache-2.0
- Description — Repository has a description
- Active repo — Last push 0 days ago
- Low visibility — Only 5 GitHub stars
Code Basarisiz
- process.env — Environment variable access in package.json
- fs module — File system access in package.json
- execSync — Synchronous shell command execution in src/agents/aider.ts
- execSync — Synchronous shell command execution in src/agents/claude.ts
- execSync — Synchronous shell command execution in src/agents/cline.ts
- execSync — Synchronous shell command execution in src/agents/codex.ts
- execSync — Synchronous shell command execution in src/agents/copilot.ts
- execSync — Synchronous shell command execution in src/agents/cursor.ts
- execSync — Synchronous shell command execution in src/agents/deepagents.ts
Permissions Gecti
- Permissions — No dangerous permissions requested
This tool acts as a bridge between local AI agents on your computer and your smartphone. It allows you to dispatch tasks from your phone and grants your local agents access to mobile capabilities like notifications, SMS, and contacts.
Security Assessment
The overall risk is rated as Medium. The primary security concern is its core reliance on executing shell commands. The codebase heavily uses synchronous shell execution (`execSync`) across multiple files to interact with and control various AI agents like Claude, Codex, and Cursor. Additionally, it accesses the file system and environment variables to manage its background daemon. Because the tool is designed to read sensitive mobile data such as SMS, contacts, and calendar events, the data pipeline should be considered sensitive. While no hardcoded secrets or explicitly dangerous permissions were found, the installation method relies on piped shell scripts (`curl | bash`), which inherently requires trusting the remote server.
Quality Assessment
The project has an Apache-2.0 license and appears to be actively maintained, with repository updates pushed as recently as today. However, community trust and visibility are currently very low. It only has 5 GitHub stars, meaning it has not been widely vetted or battle-tested by a large user base. Continuous integration is set up, which is a positive indicator for code quality.
Verdict
Use with caution — while functional, the tool executes shell commands and handles highly sensitive mobile data, and its extremely low community adoption means it has not undergone broad public security scrutiny.
A two-way bridge between the AI agents on your machine and your phone. Dispatch tasks from anywhere, approve actions on the go, and let agents tap into phone capabilities like notifications, SMS, contacts, and calendar.
Palmier
Website: palmier.me | Web App: app.palmier.me | Android App: caihongxu/palmier-android
You already have AI agents running on your machine. Palmier is an agent-agnostic bridge between those agents and your phone.
From your phone, you can start sessions, schedule tasks, approve requests, and review results. From your machine, your agents can use phone-side capabilities like notifications, location, SMS, contacts, and calendar — so they can react to the real world, not just the terminal.
It runs on your machine as a background daemon and pairs with a mobile-friendly PWA.
What Palmier is
Palmier is an agent-agnostic phone bridge and mobile control layer for the agents you already use.
It is not:
- an agent runtime itself
- a replacement for Claude Code / Codex CLI / Gemini CLI / OpenClaw / Hermes
- a system for driving your phone UI like a human tapping through apps
Instead, Palmier focuses on:
- letting agents access phone-side capabilities and context in the background
- letting you talk to, manage, and schedule your agents from your phone
- making phone integrations work out of the box without requiring users to wire up separate calendar/email/contact stacks
Quick Start
Install a supported agent CLI — Claude Code, Gemini CLI, Codex CLI, GitHub Copilot, OpenClaw, or others.
Install Palmier:
Linux / macOS:
curl -fsSL https://palmier.me/install.sh | bashWindows (PowerShell):
irm https://palmier.me/install.ps1 | iexThe one-liner installs Node.js 24+ if needed (via fnm on Linux/macOS, winget on Windows), then
palmierglobally. If you already have Node.js 24+ and npm:npm install -g palmierRun the setup wizard from your Palmier root directory (e.g.,
~/palmier):palmier initThis detects your agents, configures access, installs the background daemon, and starts pairing.
Open
http://localhost:7256to access the app locally — no pairing needed.To access from other devices, enter the pairing code shown after init into the PWA.
Prerequisites
- Node.js 24+
- Linux with systemd, macOS 13+, or Windows 10/11
- At least one supported agent CLI
How It Works
Palmier runs as a background daemon (systemd on Linux, launchd on macOS, Task Scheduler on Windows). It invokes your agent CLIs directly, schedules tasks via native OS timers, and exposes an API that the PWA connects to — either directly over HTTP or remotely through a relay server. Agents can interact with the user's mobile device during execution — requesting input, sending push notifications and full-screen alarms, reading SMS/notifications, managing contacts and calendar, and more.
MCP Server
Palmier exposes an MCP server at http://localhost:7256/mcp (streamable HTTP transport). MCP-capable agents can register it to get tool and resource definitions automatically. The same tools and resources are also available as REST endpoints for curl-based agents.
MCP server URL: http://localhost:7256/mcp
Available tools:
| Tool | Description |
|---|---|
notify |
Send a push notification to the user's device |
request-input |
Request input from the user (blocks until response) |
request-confirmation |
Request confirmation from the user (blocks until response) |
device-geolocation |
Get GPS location of the user's mobile device |
read-contacts |
Read the contact list from the user's device |
create-contact |
Create a new contact on the user's device |
read-calendar |
Read calendar events (with time range filter) |
create-calendar-event |
Create a calendar event on the user's device |
send-sms-message |
Send an SMS message from the user's device |
send-email |
Send an email from the user's device (opens the email app with the draft pre-filled for review) |
send-alarm |
Trigger a full-screen alarm popup with ringtone on the user's device (pierces DND) |
read-battery |
Get battery level and charging status |
set-ringer-mode |
Set ringer mode (normal/vibrate/silent) |
Available resources:
| Resource | URI | Description |
|---|---|---|
| Device Notifications | notifications://device |
Recent notifications from the user's Android device |
| Device SMS | sms-messages://device |
Recent SMS messages from the user's Android device |
Resources support MCP subscriptions — clients can subscribe via resources/subscribe and receive real-time notifications/resources/updated events via the streamable HTTP transport when the resource changes.
All device tools work while the Palmier Android app is in the background — they communicate via FCM data messages which wake the app's service even when it's not in the foreground. Each host has one linked device: the phone the host uses for SMS, contacts, location, and other device capabilities. Choose it at pair time (the "Link the host to this device" checkbox) or later from the drawer. Each capability must be enabled and its Android permission granted via toggles in the linked device's drawer.
Architecture
┌──────────────┐ HTTP ┌──────────────────┐
│ │◄──────────────────────│ │
│ Host Daemon │ │ PWA (Browser) │
│ (MCP Server)│◄──────┐ │ │
└──┬────────┬──┘ │ └──────────────────┘
│ │ │ │
▼ ▼ │ NATS (TLS) │ NATS (TLS)
┌──────┐ ┌──────┐ │ ┌────────┴─────────┐
│Agent │ │Agent │ └───────────────│ Relay Server │
│ CLIs │ │Tools/│ │ (passthrough, │
│ │ │Rsrcs │◄──── FCM ───────────│ push, FCM) │
└──────┘ └──────┘ └──────────────────┘
│
FCM │
▼
┌──────────────────┐
│ Android Device │
│ (notifications, │
│ SMS, contacts, │
│ calendar, GPS) │
└──────────────────┘
Local mode (loopback): direct HTTP on the host machine
Server mode: via relay (events) + auto-LAN direct HTTP for RPC when reachable (native app)
Access Modes
Three ways to reach your host, ordered by setup effort:
| Mode | Where | Pairing | Notes |
|---|---|---|---|
| Local | http://localhost:7256 in a browser on the host machine |
Not required | Loopback only. No internet needed. |
| Remote (web) | https://app.palmier.me in any browser | Required | Always goes through the cloud relay. |
| Remote (app) | Android APK | Required | Push notifications, device capabilities, and auto-LAN. |
Auto-LAN (native app only). When the Android app is on the same network as the host, it transparently routes RPC over direct LAN HTTP (http://<host-ip>:7256/rpc/...) instead of through the relay — lower latency, no protocol change. Browser PWAs can't do this (Private Network Access / mixed-content restrictions) and stay on the relay.
Security & Privacy
Local mode — all traffic stays on 127.0.0.1. No data leaves your machine. The web UI, /pair, and /events reject any non-loopback caller; only /rpc/<method> (bearer-auth) and /health are reachable from the LAN.
Server mode — communication between your device and host is relayed through the Palmier cloud server over TLS-encrypted NATS connections. The server acts as a passthrough relay only — it does not store, log, or inspect any user data, task content, or agent output. The only data the server persists is a host registration ID used for message routing and push subscription tokens for delivering notifications. See the Privacy Policy for full details.
Auto-LAN — direct LAN HTTP requests use the same client token (Bearer auth) generated during pairing. The host validates every /rpc/* call regardless of source.
In all modes, client tokens are generated and validated entirely on your host. The Palmier server never sees or stores them.
Setup Details
Pairing Devices
Local access (http://localhost:7256) works immediately — no pairing needed.
For remote access (web or app), run palmier pair on the host to generate a code, then enter it at https://app.palmier.me or in the Android app. Pairing always goes through the relay; auto-LAN kicks in transparently afterward in the native app when on the same network.
Managing Clients
# List all paired devices
palmier clients list
# Revoke a specific device's access
palmier clients revoke <token>
# Revoke all clients (unpair all devices)
palmier clients revoke-all
Revoking the linked device also clears the host's linked-device record; device capabilities stop working until another paired device is linked from its drawer.
The init Command
The wizard:
- Detects installed agent CLIs and caches the result
- Asks for the HTTP port
- Detects the default network interface (used for auto-LAN)
- Shows a summary (including any existing scheduled tasks to recover) and asks for confirmation
- Registers with the Palmier server, saves configuration to
~/.config/palmier/host.json - Installs a background daemon (systemd user service on Linux, LaunchAgent on macOS, Task Scheduler on Windows)
- Auto-enters pair mode to connect your first device
The daemon automatically recovers existing tasks by reinstalling their system timers on startup.
macOS note: Palmier installs as a user-level LaunchAgent, so it runs without
sudo. LaunchAgents only run while the user is logged into the GUI session — after a reboot, scheduled tasks stay dormant until you log in at least once. Enable auto-login in System Settings → Users & Groups if you need unattended operation across reboots.
Agents are re-detected on every daemon start. Run palmier restart after installing or removing a CLI.
Re-detecting the LAN Network
The default network interface is detected once during palmier init and saved to host.json. The daemon derives the current IP live from that interface on each client connect, so DHCP-assigned IP changes on the same adapter are picked up automatically. If you physically switch to a different network adapter (e.g., plug in Ethernet after running on WiFi, or add a new USB-tethered interface), run palmier init again to re-detect.
CLI Reference
| Command | Description |
|---|---|
palmier init |
Interactive setup wizard |
palmier pair |
Generate a pairing code to pair a new device |
palmier clients list |
List active client tokens |
palmier clients revoke <token> |
Revoke a specific client token |
palmier clients revoke-all |
Revoke all client tokens |
palmier info |
Show host connection info (address, mode) |
palmier serve |
Run the persistent RPC handler (default command) |
palmier restart |
Restart the palmier serve daemon |
palmier run <task-id> |
Execute a specific task |
palmier uninstall |
Stop daemon and remove all scheduled tasks |
Uninstalling
To fully remove Palmier from a machine:
Unpair your device in the PWA (via the host menu).
Stop the daemon and remove all scheduled tasks:
palmier uninstallUninstall the package:
npm uninstall -g palmier(Optional) Remove configuration and task data:
Linux / macOS:
rm -rf ~/.config/palmier rm -rf ~/palmier # or wherever your Palmier root directory isWindows (PowerShell):
Remove-Item -Recurse -Force "$env:USERPROFILE\.config\palmier" Remove-Item -Recurse -Force "$env:USERPROFILE\palmier" # or wherever your Palmier root directory is
Disclaimer
Palmier spawns AI agents that can read, write, and execute on your machine. Read the full disclaimer before use. By using Palmier, you agree to the Terms of Service and Privacy Policy.
License
This project is licensed under the Apache License 2.0. See LICENSE for the full text.
Yorumlar (0)
Yorum birakmak icin giris yap.
Yorum birakSonuc bulunamadi