With this library you can call the Travelport SOAP methods in a object oriented way.
You can install the package via composer:
composer require filippo-toso/travelport
If you don't have the required credentials you can register for a trial on this page: https://developer.travelport.com/web/developer/contact-us?type=UAPI
Here is a pure PHP example:
use FilippoToso\Travelport;
use FilippoToso\Travelport\System;
// Create the API client
$travelport = new Travelport\Travelport(
'Universal API/uAPI123456789', // Travelport User ID
'ABCDEFGHILMNOQRSTUVZ', // Travelport Password
'P1234567', // Travelport Target Branch
Travelport\Endpoints::REGION_EMEA, // Region
false // Set to false to use pre-production endpoints
);
// Create a Time request on the System service
$request = (new System\TimeReq())
->setBillingPointOfSaleInfo(new System\BillingPointOfSaleInfo('UAPI')); // Don't know what this is, but it's required to complete a call :(
// Execute the request
$response = $travelport->execute($request);
printf('The current system time is %s', $response->getSystemTime());
// Create a Ping request on the System service
$request = (new System\PingReq())
->setPayload('Hello World!')
->setBillingPointOfSaleInfo(new System\BillingPointOfSaleInfo('UAPI')); // Don't know what this is, but it's required to complete a call :(
// Execute the request
$response = $travelport->execute($request);
printf('Travelport pinged back: %s', $response->getPayload());
This library supports almost all the requests and responses available. They can be executed in the same way:
- Create the response object
- Execute the request
- Use the methods in the answer to get the information you need
You can browser the library source code to understand which methods are available. Usually the request object names end with "Req" and the corrisponding responses end with "Rsp" (ie. System\TimeReq and System\TimeRsp).
You can also use this library in your Laravel applications.
The first step whould be to publish the configuration file:
php artisan vendor:publish --tag=config --provider="FilippoToso\Travelport\TravelportServiceProvider"
Then insert your credentials in the config\travelport.php file.
Then you can execute requests with a code like this:
use FilippoToso\Travelport;
use FilippoToso\Travelport\System;
// Create a Time request on the System service
$request = (new System\TimeReq())
->setBillingPointOfSaleInfo(new System\BillingPointOfSaleInfo('UAPI')); // Don't know what this is, but it's required to complete a call :(
// Execute the request
$response = Travelport::execute($request);
printf('The current system time is %s', $response->getSystemTime());
// Create a Ping request on the System service
$request = (new System\PingReq())
->setPayload('Hello World!')
->setBillingPointOfSaleInfo(new System\BillingPointOfSaleInfo('UAPI')); // Don't know what this is, but it's required to complete a call :(
// Execute the request
$response = Travelport::execute($request);
printf('Travelport pinged back: %s', $response->getPayload());
The current version of this library supports the 19.2 schema version. I hope to keep it updated at least once a year.
Please see CHANGELOG for more information what has changed recently.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.