Apple-skills apple-aso
Optimize Apple App Store metadata in store.config.json for ASO (App Store Optimization). Use when working with store.config.json, App Store keywords, titles, subtitles, descriptions, or localizing app metadata. Helps maximize app visibility and downloads.
install
source · Clone the upstream repo
git clone https://github.com/vabole/apple-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/vabole/apple-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/apple-aso" ~/.claude/skills/vabole-apple-skills-apple-aso && rm -rf "$T"
manifest:
skills/apple-aso/SKILL.mdsource content
Apple ASO (App Store Optimization)
Optimize App Store metadata following Apple's guidelines and ASO best practices to maximize visibility and downloads.
When to Use
- Creating or editing
store.config.json - Optimizing App Store keywords
- Localizing app metadata for new markets
- Reviewing existing metadata for ASO issues
- Adding new language localizations
Character Limits
| Field | Limit | Ranking Weight | Indexed |
|---|---|---|---|
| Title | 30 chars | Highest | Yes |
| Subtitle | 30 chars | 2nd highest | Yes |
| Keywords | 100 chars | 3rd (same as subtitle) | Yes |
| Description | 4,000 chars | None | No |
| Promo Text | 170 chars | None | No |
| Release Notes | 4,000 chars | None | No |
Keyword Field Rules
Format
keyword1,keyword2,multi word phrase,keyword3
Critical formatting:
- Comma-separated with NO spaces after commas (saves characters)
- Spaces allowed within multi-word phrases
- 100 characters total
Must Follow
- Never duplicate words from title/subtitle - Apple indexes them automatically
- Use single words when possible - Apple creates combinations automatically
- No plurals if you have the singular form
- No special characters -
,@
,#
are replaced with spaces- - No generic terms - avoid "app", "game", "free", "best", "new"
- No competitor names or trademarks
- No category names - already indexed from category selection
Should Include
- Synonyms not in title/subtitle
- Alternate spellings (with/without accents)
- Related concepts and features
- Long-tail niche terms
- Regional variations
- Action verbs users search for
Localization Best Practices
Apple App Store Language Codes
| Language | Code | Language | Code | |
|---|---|---|---|---|
| English (US) | | German | | |
| English (UK) | | French (France) | | |
| English (AU) | | French (Canada) | | |
| Spanish (Spain) | | Portuguese (Brazil) | | |
| Spanish (Mexico) | | Portuguese (Portugal) | | |
| Italian | | Dutch | | |
| Japanese | | Russian | | |
| Korean | | Chinese Simplified | | |
| Arabic | | Chinese Traditional | |
Localization Rules
- Don't just translate - Research native search terms
- Include English keywords in non-English locales (users often search in English)
- Remove diacritics for keywords (users skip accents when typing)
- Add regional terms - Different countries use different words
- Consider cross-localization - Apple indexes multiple locales per territory
Cross-Localization (Free Extra Keywords)
Apple indexes keywords from multiple locales per territory:
- US: English (US) + Spanish (Mexico)
- UK: English (UK) + English (US)
- Canada: English (Canada) + French (Canada)
- Australia: English (AU) + English (UK)
This effectively gives you 200 characters in some markets.
Optimization Workflow
Step 1: Analyze Current Metadata
Check for these issues:
- Keywords duplicating title/subtitle words
- Redundant synonyms (e.g., "kids" and "children")
- Generic terms that waste space
- Missing regional variants
- Unused character space
Step 2: Research Keywords
Consider:
- Relevance: Does it describe your app?
- Volume: Are people searching for it?
- Competition: Can you realistically rank?
Step 3: Optimize Keywords
- Remove all duplicates from title/subtitle
- Remove plurals if singular exists
- Add action verbs users search for
- Add regional/cultural variants
- Fill remaining space with related terms
- Remove diacritics for better matching
Step 4: Validate
- Title ≤ 30 characters
- Subtitle ≤ 30 characters
- Keywords ≤ 100 characters (count with no spaces after commas)
- No duplicates across fields
- No prohibited terms
Example: Before & After
Before (Poor ASO)
{ "title": "Call Santa Claus Now", "subtitle": "Magical Santa Voice Calls", "keywords": ["santa", "call santa", "santa claus", "voice call", "kids", "children"] }
Issues:
- "santa", "call santa", "santa claus" duplicate title
- "voice call" duplicates subtitle
- "kids" and "children" are synonyms
After (Optimized)
{ "title": "Call Santa Claus Now", "subtitle": "Magical Santa Voice Calls", "keywords": "christmas,xmas,holiday,north pole,father christmas,talk,phone,festive,rudolph,elves,family" }
Improvements:
- No duplicates from title/subtitle
- Regional variant (father christmas for UK)
- Related terms (rudolph, elves, north pole)
- Alternate spellings (xmas)
- Action verb (talk)
store.config.json Schema
{ "configVersion": 0, "apple": { "info": { "en-US": { "title": "App Name (max 30 chars)", "subtitle": "Value proposition (max 30 chars)", "description": "Full description (max 4000 chars)", "keywords": "comma,separated,no spaces,after commas", "releaseNotes": "What's new in this version", "promoText": "Short promotional text (max 170 chars)", "privacyPolicyUrl": "https://example.com/privacy", "supportUrl": "https://example.com/support", "marketingUrl": "https://example.com" } }, "categories": ["PRIMARY_CATEGORY", "SECONDARY_CATEGORY"] } }
Common Mistakes to Avoid
- Duplicating keywords across fields - Wastes precious character space
- Direct translation - Doesn't account for local search behavior
- Keyword stuffing in title - Hurts readability and conversion
- Ignoring subtitle - Second most important ranking factor
- Using spaces after commas - Wastes ~10% of keyword space
- Frequent changes - Wait 3-4 weeks between keyword updates
- Including app/game - Already indexed from category
Resources
- Apple Developer: App Store Search
- EAS Metadata Schema
- Project guidelines:
docs/aso-guidelines.md
Commands
# Push metadata to App Store eas metadata:push # Pull current metadata from App Store eas metadata:pull # Validate metadata locally # (Check JSON syntax and character limits)