skills/autofillin/SKILL.md
Automated web form filling and file uploading skill with Playwright browser automation. Handles login persistence, form detection, file uploads, and waits for manual confirmation before submission.
npx skillsauth add adamshl-oss/alfred autofillinInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Trigger Command: autofillin
An intelligent automation skill that fills web forms, uploads files/folders to correct positions, and handles complex multi-field submissions with persistent login support.
| Version | Changes | |---------|---------| | v1.2.0 | Enhanced error handling, consolidated config, improved robustness | | v1.1.0 | Added Playwright support, session persistence, folder upload | | v1.0.0 | Initial release with Chrome debug mode |
# 1. Install Playwright browsers
npx playwright install chromium
# 2. First-time login (saves session for reuse)
npx playwright open --save-storage=~/.playwright-auth.json "https://your-target-site.com"
# Login manually in the browser that opens, then close it
# 3. Future runs will auto-login using saved session
npx playwright open --load-storage=~/.playwright-auth.json "https://your-target-site.com"
Add to your MCP settings (Claude Code, OpenCode, etc.):
{
"mcpServers": {
"playwright": {
"command": "npx",
"args": ["-y", "@anthropic-ai/mcp-server-playwright"]
},
"filesystem": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/"]
}
}
}
Environment variables for shell integration:
export CHROME_DEBUG_PORT=9222
export CHROME_USER_DATA_DIR="$HOME/.chrome-autofillin"
# First login - saves session
npx playwright open --save-storage=~/.playwright-auth.json "https://molthub.com/upload"
# Subsequent uses - loads saved session
npx playwright open --load-storage=~/.playwright-auth.json "https://molthub.com/upload"
Advantages:
# Start Chrome with debug port
./scripts/start-chrome.sh "https://example.com/form"
# With your default Chrome profile (keeps existing logins)
./scripts/start-chrome.sh --use-default-profile "https://example.com/form"
Note: Chrome debug mode with custom --user-data-dir is blocked by Google OAuth. Use Playwright for sites requiring Google/GitHub login.
autofillin https://example.com/form
- Fill "Name" field with "John Doe"
- Fill "Email" field with "[email protected]"
- Upload resume.pdf to file input
autofillin https://molthub.com/upload
Form Data:
- Slug: autofillin
- Display name: AutoFillIn - Browser Form Automation Skill
- Version: 1.2.0
- Tags: automation, browser, form, playwright, mcp
- Changelog: v1.2.0 - Enhanced error handling, consolidated config
Upload:
- Folder: ~/clawd/skills/autofillin/
[WAIT FOR MANUAL CONFIRMATION TO PUBLISH]
autofillin https://example.com/document-upload
Files to upload:
- Position 1 (ID Document): ~/documents/id_card.pdf
- Position 2 (Proof of Address): ~/documents/utility_bill.pdf
- Position 3 (Photo): ~/photos/headshot.jpg
[WAIT FOR MANUAL CONFIRMATION]
1. BROWSER SETUP
- Check for saved session (~/.playwright-auth.json)
- Launch Playwright Chromium with session
- Or prompt for one-time login if no session exists
2. NAVIGATION & LOGIN
- Navigate to target URL
- Detect if login is required
- If login needed: Fill username, prompt for password, save session
3. PAGE ANALYSIS
- Take accessibility snapshot
- Identify all form fields
- Map field labels to input elements
4. AUTO-FILL PHASE
- Fill text fields using fill() or fill_form()
- Select dropdown options
- Upload files/folders via upload_file()
5. CONFIRMATION PHASE
- Display summary of filled data
- WAIT FOR MANUAL CONFIRMATION
- User reviews and clicks Submit/Publish
| Tool | Purpose | |------|---------| | take_snapshot | Get page accessibility tree | | fill | Fill single form field | | fill_form | Fill multiple fields at once | | upload_file | Upload file or folder | | browser_click | Click buttons | | evaluate_script | Run JavaScript | | navigate_page | Navigate to URLs |
# Use macOS Keychain
security add-generic-password -a "github" -s "autofillin" -w "your-password"
security find-generic-password -a "github" -s "autofillin" -w
# Use Linux secret-tool
secret-tool store --label="autofillin-github" service autofillin username github
# Use Windows Credential Manager
cmdkey /add:autofillin-github /user:github /pass:your-password
Sessions saved to ~/.playwright-auth.json include cookies, localStorage, and sessionStorage.
| Error | Cause | Solution | |-------|-------|----------| | Unsafe browser | Google OAuth blocked | Use Playwright instead of Chrome debug | | Login required | Session expired | Run with --save-storage | | Element not found | Page changed | Take new snapshot | | Upload failed | Wrong file type | Check webkitdirectory | | Port in use | Another Chrome instance | Script auto-kills conflicting process | | Chrome not found | Not installed | Run setup-env.sh |
# Check if port is in use
lsof -i:9222
# Kill existing processes
pkill -f "remote-debugging-port=9222"
# Retry
./scripts/start-chrome.sh "https://example.com"
# Verify auth file exists
ls -la ~/.playwright-auth.json
# Re-authenticate
npx playwright open --save-storage=~/.playwright-auth.json "https://target-site.com"
ls -la /path/to/filewebkitdirectory attributeautofillin/
├── SKILL.md # This documentation (includes MCP config)
└── scripts/
├── setup-env.sh # Environment setup (cross-platform)
├── start-chrome.sh # Chrome debug launcher
└── autofillin.sh # Main orchestrator with error handling
MIT
development
Use when building real-time communication systems with WebSockets or Socket.IO. Invoke for bidirectional messaging, horizontal scaling with Redis, presence tracking, room management.
development
Review UI code for Web Interface Guidelines compliance. Use when asked to "review my UI", "check accessibility", "audit design", "review UX", or "check my site against best practices".
tools
Create and deploy single-page static websites to GitHub Pages with autonomous workflow. Use when building portfolio sites, CV pages, landing pages, or any static web project that needs GitHub Pages deployment. Handles complete workflow from project initialization to live deployment with GitHub Actions automation.
tools
Plain English E2E UI testing. Describe tests in natural language, agent executes via browser tool, then exports real Playwright test scripts for CI/CD. Use when asked to create UI tests, test a website, or generate Playwright scripts.