| name | external-electron-apps |
| description | Automate user-installed Electron desktop apps (Slack, Discord, VS Code, Notion, Figma, Spotify, etc.) via CDP using this repo's Libretto CLI. Use when the task is to control a local desktop app on the user's machine, not this repo's own Electron app. Triggers: "desktop Slack app", "connect to Electron app", "remote-debugging-port", "CDP desktop app", "automate VS Code desktop app".
|
External Electron App Automation
Use this skill for external Electron desktop apps running on the user's machine.
Do not default to this for this repository's own Electron app unless the user explicitly asks.
Core workflow
- Quit the app if it is already running.
- Relaunch the app with
--remote-debugging-port=<port>.
- Connect with
npx libretto connect http://127.0.0.1:<port> --session <session>.
- Verify targets with
npx libretto pages --session <session>.
- Run interactions with
npx libretto exec "<code>" --session <session>.
- Capture evidence with
npx libretto snapshot --session <session>.
Launch examples
macOS
open -a "Slack" --args --remote-debugging-port=9222
open -a "Visual Studio Code" --args --remote-debugging-port=9223
open -a "Discord" --args --remote-debugging-port=9224
Linux
slack --remote-debugging-port=9222
code --remote-debugging-port=9223
discord --remote-debugging-port=9224
Windows
"C:\Users\%USERNAME%\AppData\Local\slack\slack.exe" --remote-debugging-port=9222
"C:\Users\%USERNAME%\AppData\Local\Programs\Microsoft VS Code\Code.exe" --remote-debugging-port=9223
Session pattern
Use one session per app:
npx libretto connect http://127.0.0.1:9222 --session slack-desktop
npx libretto pages --session slack-desktop
npx libretto exec "return await page.title()" --session slack-desktop
npx libretto snapshot --session slack-desktop
Interaction examples
npx libretto exec "await page.locator('button:has-text(\"Search\")').click()" --session slack-desktop
npx libretto exec "await page.keyboard.type('incident-123')" --session slack-desktop
npx libretto exec "await page.keyboard.press('Enter')" --session slack-desktop
When selectors are unstable, inspect first:
npx libretto snapshot --session slack-desktop
npx libretto exec "return await page.content()" --session slack-desktop
Multiple pages
Electron apps often have multiple windows/pages. Use pages to list them and --page to target a specific one:
npx libretto pages --session slack-desktop
npx libretto exec --session slack-desktop --page <page-id> "return await page.url()"
npx libretto snapshot --session slack-desktop --page <page-id>
Troubleshooting
- If connection fails, make sure the app was launched with
--remote-debugging-port and relaunch it.
- Prefer
127.0.0.1 over localhost in CDP URLs.
- If no pages are listed right after launch, wait 2-5 seconds and retry
pages.
- If a session is stale, run
connect again with the same --session.
Use npx libretto close --session <session> to clear the session. This does not terminate the external app — it only removes the session state so Libretto stops tracking it.