Travel-hacking-toolkit compare-flights

Unified flight comparison across all sources. Searches cash prices (Duffel, Ignav), award availability (seats.aero), and portal pricing (Chase UR, Amex MR) in parallel. Applies transfer partner optimization automatically. Outputs one comparison table with recommendations.

install
source · Clone the upstream repo
git clone https://github.com/borski/travel-hacking-toolkit
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/borski/travel-hacking-toolkit "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/compare-flights" ~/.claude/skills/borski-travel-hacking-toolkit-compare-flights && rm -rf "$T"
manifest: skills/compare-flights/SKILL.md
source content

Compare Flights

Search every available source for a route and present one unified comparison. Combines cash pricing, award availability, portal pay-with-points, and transfer partner optimization into a single table.

This is an orchestration skill. It tells the agent which tools to run and how to combine results. No standalone script.

When to Use

  • "Find me the best way to get from SFO to CDG in August"
  • "Should I pay cash or use points for this flight?"
  • "Compare all options for SFO to NRT business class"
  • Any flight search where the user wants the full picture

Sources

Run these in parallel where possible. Never fail silently. If a source errors, report it in the output so the user knows what's missing.

Cash Prices (run in parallel)

SourceSkillSpeedNotes
Duffel
duffel
~3sPrimary. Real GDS fares with fare classes. No Southwest.
Ignav
ignav
~2sFast REST API. Good for price comparison. Booking links.
Google Flights
google-flights
~10sBrowser-automated. All airlines including Southwest cash. Good cross-check.
Skiplaggedweb search~5sHidden city ticketing. Often finds significantly cheaper fares. Search
skiplagged.com/flights/{origin}/{dest}/{date}
.
Kiwi.comweb search~5sCreative routings, self-transfer combos, multi-city. Search
kiwi.com
.
Southwest
southwest
~20sPatchright, Docker only. Points + cash for all 4 fare classes. Only needed when SW flies the route.

Skiplagged and Kiwi: Use web search (tavily or exa) to find their prices. They don't have MCP skills but their URLs are predictable. Always note that Skiplagged fares have restrictions (can't check bags, must use the "missed" connection city as destination).

Southwest: Check if SW flies the route first (major US domestic, Mexico, Caribbean, Central America). If yes, run the

southwest
skill. If no, skip and note "Southwest does not fly this route." Southwest returns BOTH cash prices AND Rapid Rewards points prices for all 4 fare classes (Wanna Get Away, WGA+, Anytime, Business Select). Include SW points in the comparison table as a separate currency. SW points are NOT transferable from UR/MR. They're earned directly or via Chase UR transfer (1:1). Companion Pass doubles the value.

SerpAPI is optional. Only use if the user asks for Google Hotels or destination discovery.

Award Availability

SourceSkillSpeedNotes
Seats.aero
seats-aero
~5sCached award availability across 25+ programs. Primary award source.

Portal Pay-With-Points (run in parallel, Docker required)

SourceSkillSpeedNotes
Chase UR
chase-travel
~45sPoints Boost detection. 1.5x CSR multiplier at checkout.
Amex MR
amex-travel
~45sIAP discount detection on Platinum.

Portal searches are slower (require browser login). Run them in parallel with each other, but don't block on them. Start cash + award searches first, present those results, then append portal results when ready.

Only run portal searches if the user has the relevant card or asks for portal pricing. Don't run Chase if they don't have a Sapphire card.

Workflow

Step 1: Gather All Prices

Run searches in parallel. Track which sources succeeded and which failed.

PARALLEL GROUP 1 (fast, ~3-5s):
  - Duffel: cash prices with fare classes
  - Ignav: cash prices with booking links
  - Seats.aero: award availability by program
  - Skiplagged: hidden city fares (web search)
  - Kiwi.com: creative routings (web search)

PARALLEL GROUP 2 (browser-automated, ~10-45s, Docker):
  - Google Flights: all airlines including Southwest cash
  - Southwest: points + cash for all fare classes (if SW flies the route)
  - Chase Travel: UR portal pricing + Points Boost
  - Amex Travel: MR portal pricing + IAP discounts

For each source, capture:

  • Source name
  • Status: "ok" | "error: {reason}" | "skipped: {reason}"
  • Results count
  • Data

Step 2: Apply Transfer Partner Optimization

For every seats.aero award result, calculate the effective cost in each transferable currency using

data/transfer-partners.json
:

For each award (e.g., United business at 88,000 miles):
  1. Look up which currencies transfer to United: Chase UR (1:1), Bilt (1:1)
  2. Calculate effective cost: 88,000 / 1.0 = 88,000 UR or 88,000 Bilt
  3. Calculate opportunity cost using data/points-valuations.json:
     88,000 UR × 1.7cpp floor = $1,496 equivalent

Include ALL viable transfer paths, not just the cheapest. The user may have more points in one currency than another.

Step 3: Calculate Portal CPP

Chase portal quotes at 1.0 cpp in listings. The CSR 1.5x is applied at checkout:

Listed: 539,683 points for a $5,397 flight
Effective: 539,683 ÷ 1.5 = 359,789 UR points actually deducted
True CPP: $5,397 / 359,789 = 1.5 cpp (by definition)

For Points Boost offers, the boost price replaces the standard:

Boost: 269,841 points for a $5,397 flight
Effective: 269,841 ÷ 1.5 = 179,894 UR points
True CPP: $5,397 / 179,894 = 3.0 cpp (excellent)

Amex portal is 1 cpp for flights (1 MR = 1 cent). IAP fares are discounted cash prices:

Standard: $5,044 = 504,400 MR points
IAP: $4,381 = 438,100 MR points (saves 66,300 MR)

Step 4: Present Unified Table

Always use markdown tables. One table with all options sorted by effective cost.

Example: SFO → CDG Business Class, Aug 11

#OptionSourcePricePointsCurrencyCPPRating
1Cash (lowest)Duffel$4,200
2Flying Blue via Chase URseats.aero$120 tax55,000Chase UR7.4Excellent
3Aeroplan via Chase URseats.aero$200 tax70,000Chase UR5.7Excellent
4Chase Portal (Boost)chase-travel180,000Chase UR3.0Excellent
5Chase Portal (standard)chase-travel360,000Chase UR1.5Baseline
6Amex Portal (IAP)amex-travel438,100Amex MR1.0Poor
7Amex Portal (standard)amex-travel504,400Amex MR0.83Poor

Example: SFO → LAX Economy, Aug 11

#OptionSourcePricePointsCurrencyCPPRating
1SW Wanna Get Awaysouthwest$795,200SW RR1.52Good
2Cash (lowest)Duffel$89
3SW WGA+southwest$1198,400SW RR1.42Fair
4United via Chase URseats.aero$5.60 tax5,000Chase UR1.67Good
5Chase Portalchase-travel8,900Chase UR1.5Baseline
6SW Anytimesouthwest$21916,800SW RR1.30Fair

Note: SW points values shown use direct redemption CPP. If the user has Companion Pass, effective CPP doubles (two tickets for the points price of one).

Sources checked:

  • ✅ Duffel: 45 results
  • ✅ Ignav: 38 results
  • ✅ Skiplagged: 3 hidden city options
  • ✅ Kiwi.com: 12 creative routings
  • ✅ Seats.aero: 12 award options
  • ✅ Southwest: 4 fare classes (WGA $79/5.2K, WGA+ $119/8.4K, Anytime $219/16.8K, BizSelect $289/22.1K)
  • ✅ Chase Travel: 300 results (3 with Points Boost)
  • ✅ Amex Travel: 292 results (IAP available)
  • ✅ Google Flights: 52 results

Step 5: Recommendation

After the table, always provide:

  1. Best overall value: Which option gives the most CPP
  2. Best convenience: Which is easiest to book (online vs call, instant transfer vs wait)
  3. Cash vs points verdict: Using the trip-calculator framework:
    • If cash < opportunity cost of best award → "Pay cash"
    • If cash > opportunity cost → "Use points"
  4. Transfer warning: "Don't transfer until you confirm availability. Transfers are usually instant but can take 48h."
  5. Balance check: If the user's balances are known (from AwardWallet or prior context), flag if they don't have enough points

Error Handling

NEVER fail silently. Every source must report its status.

If a source fails:

- ❌ Duffel: API error (rate limit exceeded). Cash prices from Ignav only.
- ❌ Chase Travel: Login failed (2FA timeout). No portal pricing available.

If ALL cash sources fail, say so explicitly. Don't present award-only results without noting the missing cash comparison.

If seats.aero returns no availability, say "No award availability found" instead of silently omitting the award section.

Data Files Used

FilePurpose
data/transfer-partners.json
Credit card → loyalty program transfer ratios
data/points-valuations.json
CPP floor/ceiling for calculating opportunity cost
data/partner-awards.json
Cross-alliance booking options (VA→ANA, EY→AA, etc.)

Limitations

  • Portal searches require Docker and login credentials. Skip if not configured.
  • Seats.aero shows cached availability (up to 24h old). Live search via seats-aero-web is local only.
  • Transfer ratios are from
    transfer-partners.json
    . Verify against issuer before large transfers.
  • Chase portal prices don't include the 1.5x CSR multiplier. The skill adjusts automatically.
  • Southwest is NOT in Duffel, Ignav, or seats.aero. Use Google Flights skill if SW pricing needed.