Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Automates filling and resuming US DS-160 visa forms using CSV data, browser scripting, LLM for captchas, translations, missing data, and session persistence.
Automates filling and resuming US DS-160 visa forms using CSV data, browser scripting, LLM for captchas, translations, missing data, and session persistence.
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
This skill automates the filling of US nonimmigrant visa DS-160 forms by combining: CDP (Chrome DevTools Protocol) for fast element location CSV data source for user information LLM assistance for complex cases (captcha, missing elements) Session persistence for resume capability Chinese to English translation for user input
Provide CSV data: User must provide a CSV file with their personal information (use ds160-user-info.csv as template) Open DS-160 website: Use browser tool to open https://ceac.state.gov/genniv/ with profile openclaw Initialize session: Load and execute scripts/ds160-filler.js to parse mappings and CSV Start filling: Begin with the home page, handle captcha with LLM, then proceed page by page
Load existing session: Check ds160/ds160-session.json for saved Application ID Open application: Use the saved Application ID to resume on DS-160 website Continue filling: Load CSV from saved location and continue from last page
Always check if session exists first: // Read ds160/ds160-session.json // If exists → Resume mode // If not → New application mode New application mode: Ask user for CSV file path or content Save CSV to ds160/ds160-user-info.csv using write tool Initialize session data in ds160/ds160-session.json: { "applicationId": null, "securityQuestion": null, "securityAnswer": null, "currentPageIndex": 0, "completedPages": [], "startDate": "2026-02-06T21:00:00Z" } Resume mode: Load CSV from ds160/ds160-user-info.csv Load session from ds160/ds160-session.json Report current progress to user
// Open browser with openclaw profile browser_start: { profile: "openclaw", targetUrl: "https://ceac.state.gov/genniv/" } // For resume mode, add Application ID to URL // Example: https://ceac.state.gov/GenNIV/Common/ConfirmApplicationID.aspx
For each page in sequence: Snapshot page to understand current state: browser_snapshot: { refs: "role", profile: "openclaw" } Load mappings from references/ds160-elements.yaml Execute fill logic using browser act with evaluate: // Load ds160-filler.js // Call fillPage(page, currentUrl, userData, yamlData) Handle results: Success: Continue to next page Needs LLM assistance: Call LLM and retry Needs user input: Save progress and pause
Captcha: Take screenshot of captcha area Use image tool to analyze captcha Fill captcha code via browser evaluate Missing element: Call LLM with page snapshot Ask LLM to locate element and provide alternative selector Retry fill operation Translation needed: Call LLM with field context and Chinese value Ask LLM to translate to appropriate English value Update CSV and retry fill operation Missing user data: Identify which field is missing Report to user with field name and description Important: Save current page using browser evaluate before pausing Wait for user to provide data
After completing a page: Update session data: { "applicationId": "AA00FBLCQP", "securityQuestion": "What is the given name of your mother's mother?", "securityAnswer": "LiMei", "currentPageIndex": 5, "completedPages": ["home", "security_question", "personal_1", "personal_2"], "startDate": "2026-02-06T21:00:00Z" } Save to file: write(ds160/ds160-session.json, JSON.stringify(sessionData)) Report progress to user: Current page completed Next page name Application ID Security question/answer (first time only) Overall progress (X/Y pages) Click "Continue" button to proceed to next page
The CSV must have these columns: 页面 - Page name 字段名称 - Field identifier (matches YAML name field) 英文说明 - English description 中文说明 - Chinese description 必填 - Required? (是/否) 示例值 - Example value 用户填写 - User-provided value (this is what gets filled) Important: Users can provide values in Chinese. The script includes a built-in translation dictionary for common fields (gender, marital status, countries, etc.). For fields not in the dictionary, LLM will be called for translation automatically.
Each page in ds160-elements.yaml contains: page_id: Unique page identifier page_name: Human-readable page name url: Page URL pattern elements: Array of form elements with: id: Element ID name: Field identifier (matches CSV) type: Element type (text, select, radio, checkbox, button) label: English label label_cn: Chinese label required: Is required? options: Available options (for select) group: Radio group name
Symptoms: fillPage returns needsLLM: true Action: Take page snapshot Call LLM with: Current URL Element information (id, name, type) Page HTML snippet Ask LLM to analyze and provide alternative selector Retry with LLM-suggested selector
Symptoms: fillPage returns needsUserInput: true Action: CRITICAL: Save current page before pausing: // Find and click "Save" button browser_act: { request: { kind: "click", ref: "save_button" } } Report missing field to user: Field name (English and Chinese) Description Whether it's required Update CSV with new data using write tool Resume filling
Symptoms: Captcha image detected on page Action: Take screenshot of captcha area Use image tool: image: { image: "/path/to/captcha.png", prompt: "What is the code shown in this captcha? Return only the code characters." } Fill captcha field via browser evaluate Submit form
The pages are filled in this order: home - Start application, select location, handle captcha security_question - Confirm Application ID, set security question personal_1 - Personal information (name, gender, DOB) personal_2 - Nationality, other nationalities, IDs travel - Travel purpose, dates, who is paying travel_companions - People traveling with you previous_us_travel - Previous US visits address_phone - Current address and phone passport - Passport information us_contact - US point of contact family_relatives - Family information work_education - Work and education history security_background - Security questions
Report to user after each page: ✓ Completed: Personal Information 1 📄 Next: Personal Information 2 🆔 Application ID: AA00FBLCQP 🔐 Security Question: What is the given name of your mother's mother? 🔑 Answer: LiMei 📊 Progress: 3/13 pages completed Include in every report: Application ID (once obtained) Security question and answer (once generated) Current progress (X/Y pages) Next page name
Captcha detection: Always use LLM to read captcha Element not found: When multiple locator strategies fail Translation needed: When user provides Chinese value not in built-in dictionary Complex elements: For elements that require understanding context Validation errors: When form submission fails with unclear reason
The script includes a built-in translation dictionary for common Chinese values. This covers: Gender: 男/男性 → MALE 女/女性 → FEMALE Marital Status: 已婚 → MARRIED 未婚 → SINGLE 离异 → DIVORCED 丧偶 → WIDOWED 合法分居 → LEGALLY SEPARATED 事实婚姻 → COMMON LAW MARRIAGE 民事结合 → CIVIL UNION/DOMESTIC PARTNERSHIP Yes/No: 是/有/是,有 → Yes 否/没有/否,没有 → No Countries: 中国 → CHINA 美国 → USA 英国 → UNITED KINGDOM 日本 → JAPAN 韩国 → KOREA, SOUTH Visa Types: 旅游/商务/商务/旅游 → B1/B2 学生 → F1 访问学者 → J1 工作 → H1B Payment: 自己/自费 → SELF 公司 → OTHER COMPANY 其他人 → OTHER PERSON Relationship (US Point of Contact): 朋友 → Friend 亲戚 → Relative 同事 → Colleague 配偶 → Spouse 同学 → Classmate 其他 → Other Other Values: 不适用/不,不适用 → Does Not Apply For values not in this dictionary, LLM will be automatically called for translation.
Session file location: ds160/ds160-session.json Session data structure: { "applicationId": "AA00FBLCQP", "securityQuestion": "What is the given name of your mother's mother?", "securityAnswer": "LiMei", "currentPageIndex": 5, "completedPages": ["home", "security_question", "personal_1", "personal_2", "travel", "travel_companions"], "startDate": "2026-02-06T21:00:00Z", "lastUpdated": "2026-02-06T21:30:00Z" } When to save session: After completing each page Before pausing for user input After receiving Application ID After setting security question/answer
Always use openclaw profile to maintain session across pages. Use browser act with evaluate for form filling: More reliable than individual click/type actions Can execute complex JavaScript Better error handling Use browser snapshot before each page: Check page state Identify dynamic elements Verify page loaded correctly
Before using this skill with real data: Test element location on each page type Verify CSV parsing with sample data Test captcha handling with LLM Verify session save/load functionality Test resume from middle of application Verify "Save" button clicking works before pauses Test with various element types (text, select, radio, checkbox) Verify progress reporting format Test Chinese to English translation
User says: "Help me fill DS-160 form with my data in this.csv" Agent workflow: Load SKILL.md (this file) Check for existing session Save CSV to ds160/ds160-user-info.csv Initialize session Open browser to DS-160 Fill page by page Report progress after each page Handle errors with LLM or user input Save progress and continue User says: "Continue filling my DS-160 form" Agent workflow: Load SKILL.md Load existing session Open browser to DS-160 with Application ID Load CSV from saved location Continue from last page Report progress Complete remaining pages
scripts/ds160-filler.js - Core automation logic (run via browser evaluate) references/ds160-elements.yaml - Element mappings (read-only) references/ds160-user-info.csv - User data template (copy to workspace) ds160/ds160-session.json - Session persistence (auto-created) ds160/ds160-user-info.csv - Active user data (auto-created)
NEVER submit the final form - this is for automation/testing only Always save before pausing - prevents data loss Report progress frequently - at least every page Keep Application ID secure - it's sensitive information Use fake data for testing - don't use real personal info Chinese input is supported - use built-in dictionary or LLM for translation
Agent frameworks, memory systems, reasoning layers, and model-native orchestration.
Largest current source with strong distribution and engagement signals.