Skip to content

Latest commit

 

History

History
260 lines (189 loc) · 10.1 KB

README.md

File metadata and controls

260 lines (189 loc) · 10.1 KB

Amadeus Ruby SDK

Gem Version Build Status Maintainability Dependencies Discord

Amadeus provides a rich set of APIs for the travel industry. For more details, check out the Amadeus for Developers Portal or the SDK class reference.

⚠️ Important message ⚠️

❗ This SDK is maintained by the developer community only. The Amadeus for Developers team doesn't support or maintain it. ❗

Installation

This gem requires Ruby 2.5+. You can install it directly or via bundler.

Command line

gem install amadeus

Bundler

gem 'amadeus'

Getting Started

To make your first API call, you will need to register for an Amadeus Developer Account and set up your first application.

require 'amadeus'

amadeus = Amadeus::Client.new({
  client_id: 'REPLACE_BY_YOUR_API_KEY',
  client_secret: 'REPLACE_BY_YOUR_API_SECRET'
})

begin
  puts amadeus.shopping.flight_offers_search.get(originLocationCode: 'NYC', destinationLocationCode: 'MAD', departureDate: '2021-05-01', adults: 1, max: 1).body
rescue Amadeus::ResponseError => error
  puts error
end

Initialization

The client can be initialized directly.

# Initialize using parameters
amadeus = Amadeus::Client.new(client_id: 'REPLACE_BY_YOUR_API_KEY', client_secret: 'REPLACE_BY_YOUR_API_SECRET')

Alternatively, it can be initialized without any parameters if the environment variables AMADEUS_CLIENT_ID and AMADEUS_CLIENT_SECRET are present.

amadeus = Amadeus::Client.new

Your credentials can be found on the Amadeus dashboard.

By default, the environment for the SDK is the :test environment. To switch to a production (pay-as-you-go) environment please switch the hostname as follows:

amadeus = Amadeus::Client.new(hostname: :production)

Documentation

Amadeus has a large set of APIs, and our documentation is here to get you started today. Head over to our reference documentation for in-depth information about every SDK method, its arguments and return types.

Making API calls

This library conveniently maps every API path to a similar path. For example, GET /v2/reference-data/urls/checkin-links?airlineCode=BA would be:

amadeus.reference_data.urls.checkin_links.get(airlineCode: 'BA')

Similarly, to select a resource by ID, you can pass in the ID to the singular path. For example, GET /v2/shopping/hotel-offers/XZY would be:

amadeus.shopping.hotel_offer('XZY').get

You can make any arbitrary API call as well directly with the .get method:

amadeus.get('/v2/reference-data/urls/checkin-links', airlineCode: 'BA')

Response

Every API call returns a Amadeus::Response object. If the API call contained a JSON response, it will parse the JSON into .result attribute. If this data also contains a data key, that will be made available in .data attribute. The raw body of the response is always available in .body attribute.

response = amadeus.reference_data.locations.get(
  keyword: 'LON',
  subType: Amadeus::Location::ANY
)

p response.body #=> The raw response, as a string
p response.result #=> The body parsed as JSON, if the result was parsable
p response.data #=> The list of locations, extracted from the JSON

Pagination

If an API endpoint supports pagination, the other pages are available under the .next, .previous, .last and .first methods.

response = amadeus.reference_data.locations.get(
  keyword: 'LON',
  subType: Amadeus::Location::ANY
)

amadeus.next(response) #=> returns a new response for the next page

If a page is not available, the method will return nil.

Logging & Debugging

The SDK makes it easy to add your own logger.

require 'logger'

amadeus = Amadeus::Client.new(
  client_id: 'REPLACE_BY_YOUR_API_KEY',
  client_secret: 'REPLACE_BY_YOUR_API_SECRET',
  logger: Logger.new(STDOUT)
)

Additionally, to enable more verbose logging, you can set the appropriate level on your own logger. The easiest way would be to enable debugging via a parameter on initialization, or using the AMADEUS_LOG_LEVEL environment variable.

require 'logger'

amadeus = Amadeus::Client.new(
  client_id: 'REPLACE_BY_YOUR_API_KEY',
  client_secret: 'REPLACE_BY_YOUR_API_SECRET',
  log_level: 'debug' # or "warn" or "silent", defaults to "silent"
)

List of supported endpoints

# Flight Inspiration Search
amadeus.shopping.flight_destinations.get(origin: 'MAD')

# Flight Cheapest Date Search
amadeus.shopping.flight_dates.get(origin: 'MAD', destination: 'MUC')

# Flight Offers Search
amadeus.shopping.flight_offers_search.get(originLocationCode: 'NYC', destinationLocationCode: 'MAD', departureDate: '2021-05-01', adults: 1)

# Flight Choice Prediction / Be careful, this example combines 2 API calls: 1. Flight Offers Search then Flight Choice Prediction
flight_offers = amadeus.shopping.flight_offers_search.get(originLocationCode: 'NYC', destinationLocationCode: 'MAD', departureDate: '2021-05-01', adults: 1, max: 1).body
amadeus.shopping.flight_offers_search.prediction.post(flight_offers)

# Flight Delay Prediction
amadeus.travel.predictions.flight_delay.get(originLocationCod: 'NCE', destinationLocationCod: 'IST', departureDat: '2021-05-01', departureTim: '18:20:00', arrivalDat: '2020-08-01', arrivalTim: '22:15:00', aircraftCod: '321', carrierCod: 'TK', flightNumber: '1816', duration: 'PT31H10M')
# Flight Check-in Links
amadeus.reference_data.urls.checkin_links.get(airlineCode: 'BA')

# Airline Code Lookup
amadeus.reference_data.airlines.get(airlineCodes: 'U2')

# Airport & City Search (autocomplete)
# Find all the cities and airports starting by the keyword 'LON'
amadeus.reference_data.locations.get(
  keyword: 'LON',
  subType: Amadeus::Location::ANY
)
# Get a specific city or airport based on its id
amadeus.reference_data.location('ALHR').get

# Airport Nearest Relevant (for London)
amadeus.reference_data.locations.airports.get(longitude: 0.1278, latitude: 51.5074)

# Flight Most Booked Destinations
amadeus.travel.analytics.air_traffic.booked.get(originCityCode: 'MAD', period: '2017-08')

# Flight Most Traveled Destinations
amadeus.travel.analytics.air_traffic.traveled.get(originCityCode: 'MAD', period: '2017-01')

# Flight Busiest Period
amadeus.travel.analytics.air_traffic.busiest_period.get(
  cityCode: 'MAD',
  period: '2017',
  direction: Amadeus::Direction::ARRIVING
)

# Hotel Search
# Get list of hotels by cityCode
amadeus.shopping.hotel_offers.get(cityCode: 'MAD')
# Get list of offers for a specific hotel
amadeus.shopping.hotel_offers_by_hotel.get(hotelId: 'IALONCHO')
# Confirm the availability of a specific offer
amadeus.shopping.hotel_offer('D5BEE9D0D08B6678C2F5FAD910DC110BCDA187D21D4FCE68ED423426D0A246BB').get

# Hotel Booking
# The offerId comes from the hotel_offer above
amadeus.booking.hotel_bookings.post(offerId, guests, payments)

# Hotel Ratings
# What are the reviews for the Holiday INN Manhattan and the Hilton London Paddington
amadeus.e_reputation.hotel_sentiments.get(hotelIds: 'SJNYCAJA,TELONMFS')

# Points of Interest
# What are the popular places in Barcelona (based a geo location and a radius)
amadeus.reference_data.locations.points_of_interest.get(latitude: 41.397158, longitude: 2.160873)
# What are the popular places in Barcelona? (based on a square)
amadeus.reference_data.locations.points_of_interest.by_square.get(north: 41.397158, west: 2.160873, south: 41.394582, east: 2.177181)
# Returns a single Point of Interest from a given id
amadeus.reference_data.locations.point_of_interest('9CB40CB5D0').get()

# Safe Place
# How safe is Barcelona? (based a geo location and a radius)
amadeus.safety.safety_rated_locations.get(latitude: 41.397158, longitude: 2.160873)
# How safe is Barcelona? (based on a square)
amadeus.safety.safety_rated_locations.by_square.get(north: 41.397158, west: 2.160873, south: 41.394582, east: 2.177181)
# What is the safety information of a location based on it's Id?
amadeus.safety.safety_rated_location('Q930402753').get()

# Airport On-Time Performance
amadeus.airport.predictions.on_time.get(airportCode: 'JFK', date: '2020-08-01')

# Flight Price Analysis
amadeus.analytics.itinerary_price_metrics.get(originIataCode: 'AMS', destinationIataCode: 'CDG', departureDate: '2021-08-18')

# Trip Purpose Prediction
amadeus.travel.predictions.trip_purpose.get(originLocationCode: 'ATH', destinationLocationCode: 'MAD', departureDate: '2020-08-01', returnDate: '2020-08-12', searchDate: '2020-06-11')

Development & Contributing

Want to contribute? Read our Contributors Guide for guidance on installing and running this code in a development environment.

License

This library is released under the MIT License.

Help

You can find us on StackOverflow or join our developer community on Discord.