aso

작성자: coreyhaines31

사용자가 앱스토어 또는 구글 플레이 리스팅을 감사하거나 최적화하려 할 때. 또한 사용자가 'ASO 감사', '앱스토어 최적화', '내 앱 리스팅 최적화', '앱 가시성 개선', '앱스토어 순위', '내 리스팅 감사', '사람들이 내 앱을 다운로드하지 않는 이유', '내 앱 전환율 개선', '앱 키워드 최적화', '내 앱을 경쟁사와 비교'를 언급할 때 사용합니다. 사용자가 앱스토어 또는 구글 플레이 URL을 공유하고 이를 개선하려 할 때 사용합니다.

npx skills add https://github.com/coreyhaines31/marketingskills --skill aso

ASO Audit

Analyze App Store and Google Play listings against ASO best practices. Fetches live listing data, scores metadata, visuals, and ratings, then produces a prioritized action plan.

When to Use

  • User shares an App Store or Google Play URL
  • User asks to audit or optimize an app listing
  • User wants to compare their app against competitors
  • User asks about app store ranking, visibility, or download conversion

Before Auditing

Check for product marketing context first: If .agents/product-marketing.md exists (or .claude/product-marketing.md, or the legacy product-marketing-context.md filename, in older setups), read it before asking questions. Use that context and only ask for information not already covered or specific to this task.

Phase 1 — Identify Store & Fetch

Detect store type from URL

Apple:  apps.apple.com/{country}/app/{name}/id{digits}
Google: play.google.com/store/apps/details?id={package}

If the user gives an app name instead of a URL, search the web for: site:apps.apple.com "{app name}" or site:play.google.com "{app name}"

Fetch the listing

Use WebFetch to retrieve the listing page. Extract every available field:

Apple App Store fields:

  • App name (title) — 30 char limit
  • Subtitle — 30 char limit
  • Description (long) — not indexed for search, but matters for conversion
  • Promotional text — 170 chars, updatable without new release
  • Category (primary + secondary)
  • Screenshots (count, order, caption text)
  • Preview video (presence, duration)
  • Rating (average + count)
  • Recent reviews (visible ones)
  • Price / in-app purchases
  • Developer name
  • Last updated date
  • Version history notes
  • Age rating
  • Size
  • Languages / localizations listed
  • In-app events (if any visible)

Google Play fields:

  • App name (title) — 30 char limit
  • Short description — 80 char limit
  • Full description — 4,000 char limit, IS indexed for search
  • Category + tags
  • Feature graphic (presence)
  • Screenshots (count, order)
  • Preview video (presence)
  • Rating (average + count)
  • Recent reviews (visible ones)
  • Price / in-app purchases
  • Developer name
  • Last updated date
  • What's new text
  • Downloads range
  • Content rating
  • Data safety section
  • Languages listed

If WebFetch returns incomplete data (stores render client-side), note gaps and work with what's available. Ask the user to paste missing fields if critical.

Visual asset assessment

WebFetch cannot extract screenshot images or caption text. Take a screenshot of the listing page to get visual data:

  1. Navigate to the listing URL and capture a full-page screenshot
  2. Assess the screenshot for: icon quality, screenshot count, caption text, messaging quality, preview video presence, feature graphic (Google Play)
  3. If browser tools are unavailable, ask the user to share a screenshot of the listing page

Promotional text (Apple): This 170-char field appears above the description but is often indistinguishable from it in scraped HTML. If you cannot confirm its presence, note this and recommend the user check App Store Connect.


Phase 1.5 — Assess Brand Maturity

Before scoring, classify the app into one of three tiers. This determines how you interpret "textbook ASO" deviations — a deliberate brand choice by a household name is not the same as a missed opportunity by an unknown app.

Tier definitions

TierSignalsExamples
DominantHousehold name, 1M+ ratings, top-10 in category, near-universal brand recognition. Users search by brand name, not generic keywords.Instagram, Uber, Spotify, WhatsApp, Netflix
EstablishedWell-known in their category, 100K+ ratings, strong organic installs, recognized brand but not universally known.Strava, Notion, Duolingo, Cash App, Calm
ChallengerBuilding awareness, <100K ratings, needs discovery through keywords and ASO tactics. Most apps fall here.Your app, most indie/startup apps

How tier affects scoring

Dominant apps get adjusted scoring in these areas:

  • Title: Brand-only or brand-first titles are valid (score 8+ if brand is the keyword). These apps don't need generic keyword discovery.
  • Description: Score purely on conversion quality, not keyword presence. If the app is a household name, a well-crafted brand description beats a keyword-stuffed one.
  • Visual Assets: Lifestyle/brand photography instead of UI demos is a legitimate conversion strategy. No video is acceptable if the product is hard to demo in 30s or brand awareness is near-universal.
  • What's New: Generic release notes at weekly+ cadence are acceptable (score 8+). At scale, detailed changelogs have minimal ROI and risk backlash.
  • In-app events: Missing events for utility apps with massive install bases (Uber, WhatsApp) is not a penalty. These apps don't need discovery help.
  • Localization: Score relative to actual market, not absolute count. A US-only fintech with 2 languages (English + Spanish) is appropriately localized.

Established apps get partial adjustment:

  • Brand-first titles are fine but should still include 1-2 keywords
  • Strategic description choices get benefit of the doubt
  • Other dimensions scored normally

Challenger apps are scored strictly against textbook ASO best practices — every character, screenshot, and keyword matters.

Key principle: Before docking points, ask: "Is this a mistake or a deliberate choice by a team that has data I don't?" If the app has 1M+ ratings and a dedicated ASO team, assume their choices are data-informed unless clearly wrong.


Phase 2 — Score Each Dimension

Score each dimension 0-10 using the criteria in references/scoring-criteria.md. Apply the brand maturity tier adjustments from Phase 1.5.

Reference files for platform specs and benchmarks:

  • references/apple-specs.md — Official Apple character limits, screenshot/video specs, CPP/PPO rules, rejection triggers
  • references/google-play-specs.md — Official Google Play limits, screenshot specs, Android Vitals thresholds, policies
  • references/benchmarks.md — Conversion data, rating impact, video lift, screenshot behavior, CPP/event benchmarks

Dimensions and Weights

#DimensionWeightWhat It Covers
1Title & Subtitle20%Character usage, keyword presence, clarity, brand + keyword balance
2Description15%First 3 lines, keyword density (Google), CTA, structure, promotional text
3Visual Assets25%Screenshot count/quality/messaging, video, icon, feature graphic
4Ratings & Reviews20%Average rating, volume, recency, developer responses
5Metadata & Freshness10%Category choice, update recency, localization count, data safety
6Conversion Signals10%Price positioning, IAP transparency, social proof, download range

Final score = weighted sum, out of 100.

Score interpretation

ScoreGradeMeaning
85-100AWell-optimized; focus on A/B testing and iteration
70-84BGood foundation; clear opportunities to improve
50-69CSignificant gaps; prioritized fixes will have high impact
30-49DMajor optimization needed across multiple dimensions
0-29FListing needs a complete overhaul

Phase 3 — Competitor Comparison (Optional)

If the user provides competitor URLs or asks for comparison:

  1. Fetch 2-3 top competitors in the same category
  2. Run the same scoring on each
  3. Build a comparison table highlighting where the user's app is weaker/stronger
  4. Identify keyword gaps — terms competitors rank for that the user's app doesn't target

If no competitors are specified, suggest the user provide 2-3 or offer to search for top apps in their category.


Phase 4 — Generate Report

Use the template in references/report-template.md to structure the output.

The report must include:

  1. Score card — table with all 6 dimensions, scores, and grade
  2. Top 3 quick wins — changes that take <1 hour and have highest impact
  3. Detailed findings — per-dimension breakdown with specific issues and fixes
  4. Keyword suggestions — based on title/description analysis and competitor gaps
  5. Visual asset recommendations — specific screenshot/video improvements
  6. Priority action plan — ordered list of changes by impact vs effort

Report rules

  • Every recommendation must be specific and actionable ("Change subtitle from X to Y" not "Improve subtitle")
  • Include character counts for all text recommendations
  • Flag platform-specific differences (Apple vs Google) when relevant
  • Note what CANNOT be assessed without paid tools (search volume, exact rankings)
  • When suggesting keyword changes, explain WHY each keyword matters

Platform-Specific Rules

Apple App Store — Key Facts

  • Title (30 chars) + Subtitle (30 chars) + Keyword field (100 bytes, hidden) = indexed text
  • Keywords field is bytes not chars — Arabic/CJK use 2-3 bytes per char
  • Long description is NOT indexed for search — optimize for conversion only
  • Promotional text (170 chars) does NOT affect search (Apple confirmed)
  • Never repeat words across title/subtitle/keyword field (Apple indexes each word once)
  • Keyword field: commas, no spaces ("photo,editor,filter" not "photo, editor, filter")
  • Screenshots: up to 10 per device. First 3 visible in search — 90% never scroll past 3rd
  • Screenshot captions indexed since June 2025 (AI extraction)
  • In-app events: max 10 published at once, max 31 days each. Indexed and appear in search
  • Custom Product Pages (up to 70) in organic search since July 2025. +5.9% avg conversion lift
  • App preview video: up to 3, 15-30s each. Autoplays muted — +20-40% conversion lift
  • SKStoreReviewController: max 3 prompts per 365 days
  • Apple has human editorial curation — quality and design matter more
  • See references/apple-specs.md for full specs, dimensions, and rejection triggers

Google Play — Key Facts

  • Title (30 chars) + Short description (80 chars) + Full description (4,000 chars) = indexed text
  • Full description IS indexed — target 2-3% keyword density naturally
  • No hidden keyword field — all keywords must be in visible text
  • Google NLP/semantic understanding — keyword stuffing detected and penalized
  • Prohibited in title: emojis, ALL CAPS, "best"/"#1"/"free", CTAs (enforced since 2021)
  • Screenshots: min 2, max 8 per device (not 10 like Apple)
  • Feature graphic (1024x500, exact) required for featured placements
  • Video does NOT autoplay — only ~6% of users tap play (low ROI vs iOS)
  • Android Vitals directly affect ranking: crash >1.09% or ANR >0.47% = reduced visibility
  • Promotional Content: submit 14 days early for featuring. Apps see 2x explore acquisitions
  • Custom Store Listings: up to 50 (can target churned users, specific countries, ad campaigns)
  • Store Listing Experiments: test up to 3 variants, run 7+ days, 1 experiment at a time
  • See references/google-play-specs.md for full specs and policy details

What Apple Indexes vs What Google Indexes

FieldApple Indexed?Google Indexed?
TitleYesYes (strongest signal)
Subtitle / Short descYesYes
Keyword fieldYes (hidden)Does not exist
Long descriptionNoYes (heavily)
Screenshot captionsYes (since 2025)No
In-app eventsYesN/A (LiveOps instead)
Developer nameNoPartial
IAP namesYesYes

Common Issues Checklist

Flag these if found. Items marked (tier-dependent) should be evaluated against the app's brand maturity tier — they may be deliberate choices for Dominant apps.

Always flag (all tiers):

  • Rating below 4.0
  • Last update > 3 months ago
  • Google Play description has no keyword strategy (under 1% density)
  • Google Play missing feature graphic
  • Apple keyword field likely has repeated words (inferred from title+subtitle)
  • Category mismatch — app would face less competition in a different category
  • Fewer than 5 screenshots

Flag for Challenger/Established only (not mistakes for Dominant apps):

  • Title wastes characters on brand name only (no keywords) (Dominant: brand IS the keyword)
  • Subtitle/short description duplicates title keywords
  • Description first 3 lines are generic (Dominant: may be brand-voice choice)
  • No preview video (Dominant: may be rational if product is hard to demo)
  • Screenshots are just UI dumps with no messaging/captions (Dominant: lifestyle/brand shots may convert better)
  • Only 1-2 localizations (score relative to actual market, not absolute count)
  • No in-app events or promotional content (Dominant utility apps may not need discovery help)

Flag for all tiers but note context:

  • No developer responses to negative reviews (note volume — responding at 10M+ reviews is a different challenge than at 1K)
  • Generic "What's New" text (acceptable at weekly+ release cadence for Established/Dominant)

Task-Specific Questions

  1. What is the App Store or Google Play URL?
  2. Is this your app or a competitor's?
  3. What category does the app compete in?
  4. Do you have competitor URLs to compare against?
  5. Are you focused on search visibility, conversion rate, or both?
  6. Do you have access to App Store Connect or Google Play Console data?

Related Skills

  • cro: For optimizing the conversion of web-based landing pages that drive app installs
  • ad-creative: For creating App Store and Google Play ad creatives
  • analytics: For setting up install attribution and in-app event tracking
  • customer-research: For understanding user needs and language to inform listing copy

coreyhaines31의 다른 스킬

copywriting
coreyhaines31
사용자가 홈페이지, 랜딩 페이지, 가격 페이지, 기능 페이지, 소개 페이지, 제품 페이지 등 모든 페이지에 대한 마케팅 카피를 작성, 재작성 또는 개선하려 할 때 사용합니다. 또한 사용자가 "카피 작성", "이 카피 개선", "이 페이지 재작성", "마케팅 카피", "헤드라인 도움", "CTA 카피", "가치 제안", "태그라인", "서브헤드라인", "히어로 섹션 카피", "어브 더 폴드", "이 카피가 약해요", "더 설득력 있게 만들어 주세요", "내 제품 설명을 도와주세요"라고 말할 때도 사용합니다.
marketingcreativecommunication
seo-audit
coreyhaines31
사용자가 자신의 사이트에 대한 SEO 감사, 검토 또는 진단을 원할 때 사용합니다. 또한 사용자가 "SEO 감사", "기술적 SEO", "왜 순위가 오르지 않나요", "SEO 문제", "온페이지 SEO", "메타 태그 검토", "SEO 건강 점검", "트래픽이 떨어졌어요", "순위를 잃었어요", "구글에 나타나지 않아요", "사이트가 순위에 오르지 않아요", "구글 업데이트가 저를 강타했어요", "페이지 속도", "코어 웹 바이탈", "크롤 오류", 또는 "색인 문제"를 언급할 때도 사용합니다. 사용자가 "내 SEO가 안 좋아요" 또는 "도와주세요..."와 같이 모호하게 말하는 경우에도 사용합니다.
marketingresearchdata-analysis
marketing-psychology
coreyhaines31
사용자가 심리학 원리, 정신 모델, 또는 행동 과학을 마케팅에 적용하고자 할 때 사용합니다. 또한 사용자가 '심리학', '정신 모델', '인지 편향', '설득', '행동 과학', '사람들이 구매하는 이유', '의사 결정', '소비자 행동', '앵커링', '사회적 증거', '희소성', '손실 회피', '프레이밍', 또는 '넛지'를 언급할 때도 사용합니다. 마케팅 맥락에서 사람들이 어떻게 생각하고 결정을 내리는지 이해하거나 활용하려는 경우에 사용하세요. 적용을 위해...
marketingresearch
content-strategy
coreyhaines31
사용자가 콘텐츠 전략을 계획하거나, 어떤 콘텐츠를 만들지 결정하거나, 다룰 주제를 파악하려 할 때 사용합니다. 또한 사용자가 "콘텐츠 전략", "무엇에 대해 써야 할까", "콘텐츠 아이디어", "블로그 전략", "주제 클러스터", "콘텐츠 기획", "편집 일정", "콘텐츠 마케팅", "콘텐츠 로드맵", "어떤 콘텐츠를 만들어야 할까", "블로그 주제", "콘텐츠 핵심 주제", 또는 "무엇을 써야 할지 모르겠어"라고 언급할 때도 사용합니다. 누군가 어떤 콘텐츠를 만들지 결정하는 데 도움이 필요할 때마다 사용하세요.
marketingresearchcreative
ai-seo
coreyhaines31
사용자가 AI 검색 엔진을 위한 콘텐츠 최적화, LLM에 인용되기, 또는 AI 생성 답변에 표시되기를 원할 때 사용합니다. 또한 사용자가 'AI SEO', 'AEO', 'GEO', 'LLMO', 'answer engine optimization', 'generative engine optimization', 'LLM optimization', 'AI Overviews', 'optimize for ChatGPT', 'optimize for Perplexity', 'AI citations', 'AI visibility', 'zero-click search', 'how do I show up in AI answers', 'LLM mentions', 또는 'optimize for Claude/Gemini'를 언급할 때도 사용합니다. 누군가가... 할 때마다 사용하세요.
marketingresearch
programmatic-seo
coreyhaines31
사용자가 템플릿과 데이터를 사용하여 SEO 기반 페이지를 대량으로 생성하려 할 때 사용합니다. 또한 사용자가 "programmatic SEO", "템플릿 페이지", "대량 페이지", "디렉토리 페이지", "지역 페이지", "[키워드] + [도시] 페이지", "비교 페이지", "통합 페이지", "SEO를 위한 다수 페이지 생성", "pSEO", "100개 페이지 생성", "데이터 기반 페이지", "템플릿 랜딩 페이지"를 언급할 때도 사용합니다. 다양한 키워드나 위치를 대상으로 유사한 페이지를 많이 만들고자 할 때 이 기능을 사용하세요. 예를 들어...
marketingdata-analysisweb-scraping
marketing-ideas
coreyhaines31
사용자가 SaaS 또는 소프트웨어 제품에 대한 마케팅 아이디어, 영감 또는 전략이 필요할 때. 또한 사용자가 '마케팅 아이디어', '성장 아이디어', '마케팅 방법', '마케팅 전략', '마케팅 전술', '홍보 방법', '성장 아이디어', '또 무엇을 시도할 수 있을까', '이걸 어떻게 마케팅해야 할지 모르겠어', '마케팅 브레인스토밍', '어떤 마케팅을 해야 할까'라고 물을 때 사용합니다. 누군가 막혀 있거나 성장을 위한 영감을 찾고 있을 때 출발점으로 사용하세요. 구체적인...
marketing
copy-editing
coreyhaines31
사용자가 기존 마케팅 카피를 편집, 검토, 개선하거나 오래된 콘텐츠를 업데이트하려 할 때 사용합니다. 또한 사용자가 '이 카피를 편집해 줘', '내 카피를 검토해 줘', '카피 피드백', '교정', '이걸 다듬어 줘', '더 좋게 만들어 줘', '카피 정리', '이걸 간결하게 해 줘', '이게 어색하게 읽혀', '이 텍스트를 정리해 줘', '너무 장황해', '메시지를 날카롭게 해 줘', '이 콘텐츠를 새롭게 해 줘', '이 페이지를 업데이트해 줘', '이 콘텐츠는 오래됐어', 또는 '콘텐츠 감사'라고 말할 때도 사용합니다. 사용자가 이미 카피를 가지고 있고
documentcommunicationmarketing