Agent skill

transfer-partners

Find the cheapest way to book an award flight using your transferable credit card points. Cross-references seats.aero award prices with transfer partner ratios to calculate the real cost in each currency you hold.

Stars 387
Forks 22

Install this agent skill to your Project

npx add-skill https://github.com/borski/travel-hacking-toolkit/tree/main/skills/transfer-partners

SKILL.md

Transfer Partner Optimizer

Given award flight prices (from seats.aero or manual input) and your transferable point balances, find the cheapest path to book.

No API key needed. Uses local JSON data files.

Data Files

File Purpose
data/transfer-partners.json Credit card → loyalty program transfer ratios
data/points-valuations.json CPP valuations per program (floor/ceiling from TPG, UP, OMAAT, VFTW)
data/partner-awards.json Which programs can book which airlines

When to Use

  • User has award availability (from seats.aero cached search, live search, or manual input)
  • User wants to know "which of my points should I use?"
  • User wants to compare the effective cost across their transferable currencies
  • User asks about transfer partners for a specific airline or program

Workflow

Step 1: Get Award Availability

Use seats.aero (API or web) to search for award flights. Each result includes:

  • Source (the loyalty program: "united", "aeroplan", "flyingblue", etc.)
  • Points cost per cabin (e.g., 55,000 business)

Step 2: Map Seats.aero Sources to Transfer Partners

Seats.aero source names map to transfer-partners.json keys:

Seats.aero Source Transfer Partner Key Programs That Transfer In
united united Chase UR (1:1), Bilt (1:1)
aeroplan aeroplan Chase UR (1:1), Amex MR (1:1), Bilt (1:1), Capital One (1:1)
flyingblue flying_blue Chase UR (1:1), Amex MR (1:1), Bilt (1:1), Capital One (1:1), Citi TY (1:1), Wells Fargo (1:1)
american american Citi TY (1:1), Bilt (1:1)
alaska alaska_hawaiian Bilt (1:1)
virginatlantic virgin_atlantic Chase UR (1:1), Amex MR (1:1), Bilt (1:1), Citi TY (1:1)
delta delta Amex MR (1:1)
emirates emirates Bilt (1:1), Amex MR (5:4), Capital One (4:3), Citi TY (5:4)
etihad etihad Amex MR (1:1), Bilt (1:1), Capital One (1:1), Citi TY (1:1)
singapore singapore Chase UR (1:1), Amex MR (1:1), Capital One (1:1), Citi TY (1:1)
jetblue jetblue Chase UR (1:1), Citi TY (1:1), Wells Fargo (1:1), Amex MR (250:200), Capital One (5:3)
qatar qatar Amex MR (1:1), Bilt (1:1), Capital One (1:1), Citi TY (1:1)
turkish turkish Bilt (1:1), Capital One (1:1), Citi TY (1:1)
eurobonus (no direct transfer) N/A
aeromexico aeromexico Amex MR (1:1.6), Capital One (1:1), Citi TY (1:1)
smiles (no direct transfer) N/A
finnair finnair Capital One (1:1)
lufthansa (no direct transfer) N/A
ethiopian (no direct transfer) N/A
saudia (no direct transfer) N/A

Programs with "no direct transfer" can only be booked by earning miles directly or through alliance partner bookings.

Step 3: Calculate Effective Cost

For each award option, calculate the cost in each transferable currency:

effective_cost = award_miles / transfer_ratio

Example: Aeroplan business at 55,000 miles

  • Chase UR: 55,000 / 1.0 = 55,000 UR points
  • Amex MR: 55,000 / 1.0 = 55,000 MR points
  • Capital One: 55,000 / 1.0 = 55,000 Cap One miles

Example: Emirates business at 72,500 miles

  • Bilt: 72,500 / 1.0 = 72,500 Bilt points
  • Amex MR: 72,500 / 0.8 = 90,625 MR points (worse ratio)
  • Capital One: 72,500 / 0.75 = 96,667 Cap One miles (worst ratio)

Step 4: Calculate Opportunity Cost (CPP)

Use points-valuations.json to assess what each currency is "worth":

opportunity_cost = effective_cost × point_value_cpp / 100

This tells you the "cash equivalent" you're giving up. Lower is better.

Step 5: Present Results

Always use markdown tables.

Program Miles Needed Best Currency Points Needed CPP Value Cash Equivalent
Aeroplan 55,000 Chase UR 55,000 1.7¢ $935
United 55,000 Chase UR 55,000 1.7¢ $935
Alaska 37,500 Bilt 37,500 1.7¢ $638
Flying Blue 57,000 Any 1:1 57,000 1.7¢ $969

After the table:

  • Recommendation: "Book via Alaska using Bilt points. 37,500 Bilt = $638 opportunity cost vs next best United/Aeroplan at $935."
  • Check balance: Verify the user has enough points in the recommended currency.
  • Transfer bonus? Check if any current transfer bonuses apply (Roame.travel or TPG bonus tracker).

jq Recipes

Find all currencies that transfer to a program

bash
jq -r '
  to_entries | .[] | select(.key != "_meta") |
  .key as $currency | .value.display_name as $name |
  (.value.airlines // {}) + (.value.hotels // {}) |
  to_entries[] | select(.key == "PROGRAM_KEY") |
  "\($name): \(.value.ratio):1 → \(.value.program)"
' data/transfer-partners.json

Replace PROGRAM_KEY with the key (e.g., united, aeroplan, flying_blue).

Calculate effective costs for an award

bash
# Given: 55000 miles via aeroplan
PROGRAM="aeroplan"
MILES=55000
jq -r --arg prog "$PROGRAM" --argjson miles $MILES '
  to_entries | .[] | select(.key != "_meta") |
  .key as $currency | .value.display_name as $name |
  ((.value.airlines // {}) + (.value.hotels // {}))[$prog] // null |
  select(. != null) |
  "\($name): \(($miles / .ratio) | floor) points (ratio \(.ratio):1)"
' data/transfer-partners.json

Find cheapest path for multiple award options

bash
# Given: united at 55000, aeroplan at 55000, alaska at 37500
echo '[
  {"program": "united", "miles": 55000},
  {"program": "aeroplan", "miles": 55000},
  {"program": "alaska_hawaiian", "miles": 37500}
]' | jq -r --slurpfile tp data/transfer-partners.json '
  .[] | .program as $prog | .miles as $miles |
  ($tp[0] | to_entries | .[] | select(.key != "_meta") |
    .value.display_name as $name |
    ((.value.airlines // {}) + (.value.hotels // {}))[$prog] // null |
    select(. != null) |
    {currency: $name, program: $prog, miles: $miles, points_needed: (($miles / .ratio) | floor), ratio: .ratio}
  )
' | jq -s 'sort_by(.points_needed)'

Cross-Alliance Optimization

Sometimes the cheapest path involves booking through a different program than the obvious one. Check data/partner-awards.json for cross-alliance highlights:

  • Virgin Atlantic → ANA: 52.5K business from West Coast. Cheaper than any Star Alliance program.
  • Etihad → American Airlines: Fixed chart often beats AA's dynamic pricing.
  • Flying Blue → Delta: Often cheaper than SkyMiles, plus free stopovers.
  • Alaska → Starlux: Only points booking option for Starlux.

Notes

  • Transfer ratios rarely change, but verify against issuer websites before large transfers.
  • Transfers are usually instant but can take up to 48 hours. Don't transfer until you've confirmed award availability.
  • Some programs run transfer bonuses (10-30% extra). Check Roame.travel for current bonuses.
  • The "best" currency depends on what you have the most of AND what you value it at. A 1:1 transfer from a currency you value at 2.0 cpp costs more in opportunity than a 1:1 from one you value at 1.5 cpp.

Expand your agent's capabilities with these related and highly-rated skills.

borski/travel-hacking-toolkit

chase-travel

387 22
Explore
borski/travel-hacking-toolkit

atlas-obscura

Search Atlas Obscura for weird, wonderful, and hidden gem places near any destination. Find the interesting stuff, not boring plaques. Search by coordinates, get full details with descriptions and images.

387 22
Explore
borski/travel-hacking-toolkit

rapidapi

Search Google Flights Live and Booking.com Live via RapidAPI. Use as a secondary source for flight cash prices and hotel availability/pricing. Triggers on "Booking.com", "booking prices", "RapidAPI", "secondary flight search", "hotel prices on Booking", or when SerpAPI results need a second opinion. Also useful for vacation rental pricing.

387 22
Explore
borski/travel-hacking-toolkit

premium-hotels

Search Amex Fine Hotels & Resorts (FHR), The Hotel Collection (THC), and Chase Sapphire Reserve Hotel Collection (Chase Edit) properties by city. Compare credits, benefits, and stacking opportunities across programs.

387 22
Explore
borski/travel-hacking-toolkit

google-flights

Search Google Flights for flight prices and schedules using browser automation. Use when user asks to search flights, find airfare, compare prices, check flight availability, or look up routes. Covers ALL airlines including Southwest (which no API can reach). Triggers include "search flights", "find flights", "how much is a flight", "flights from X to Y", "cheapest flight", "flight prices", "airfare", "flight schedule", "nonstop flights", "when should I fly".

387 22
Explore
borski/travel-hacking-toolkit

ignav

Search for flights using the Ignav API. Fast REST API for flight prices and booking links. Use alongside other flight sources for price comparison. Always include in every flight search. Triggers on any flight-related search request.

387 22
Explore

Didn't find tool you were looking for?

Be as detailed as possible for better results