rubin / opensky
OpenSky REST API connector
Installs: 8
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/rubin/opensky
Requires
- php: >=8.2.0
- ext-json: *
- guzzlehttp/guzzle: ^7.0
Requires (Dev)
- php-coveralls/php-coveralls: ^2.7
- phpunit/phpunit: ^11
This package is auto-updated.
Last update: 2025-10-22 15:54:39 UTC
README
PHP implementation for the OpenSky Network REST API. This library is based on the REST API docs.
Installation
With composer:
composer require rubin/opensky
Usage
Create API connector:
$openSkyApi = new \OpenSky\OpenSkyApi();
Set credentials (optional):
$openSkyApi->setCredentials('{username}', '{password}');
Refer to the limitations, to see why/when a user account would be preferred.
Examples
Example query with time and aircraft: https://opensky-network.org/api/states/all?time=1458564121&icao24=3c6444
echo "ICAO\tLongitude\tLatitude\n"; foreach ($openSkyApi->getStatesAll(time: 1458564121, icao24: '3c6444')->getStates() as $state) { printf( "%s\t%f\t%f\n", $state->getIcao24(), $state->getLongitude(), $state->getLatitude() ); }
Example query with bounding box covering Switzerland: https://opensky-network.org/api/states/all?lamin=45.8389&lomin=5.9962&lamax=47.8229&lomax=10.5226
echo "ICAO\tLongitude\tLatitude\n"; foreach ($openSkyApi->getStatesAll(bBox: new \OpenSky\BoundingBox(45.8389, 47.8229, 5.9962, 10.5226))->getStates() as $state) { printf( "%s\t%f\t%f\n", $state->getIcao24(), $state->getLongitude(), $state->getLatitude() ); }
Retrieve states of two particular airplanes: https://opensky-network.org/api/states/all?icao24=3c6444&icao24=3e1bf9
echo "ICAO\tLongitude\tLatitude\n"; foreach ($openSkyApi->getStatesAll(icao24: ['3c6444', '3e1bf9'])->getStates() as $state) { printf( "%s\t%f\t%f\n", $state->getIcao24(), $state->getLongitude(), $state->getLatitude() ); }
Get flights from 12pm to 1pm on Jan 29 2018: https://opensky-network.org/api/flights/all?begin=1517227200&end=1517230800
echo "ICAO\tDep - Arr\n"; foreach ($openSkyApi->getFlightsAll(begin: 1517227200, end: 1517230800)->getFlights() as $flight) { printf( "%s\t%s - %s\n", $flight->getIcao24(), $flight->getEstDepartureAirport() ?: '----', $flight->getEstArrivalAirport() ?: '----' ); }
Get flights for D-AIZZ (3c675a) on Jan 29 2018: https://opensky-network.org/api/flights/aircraft?icao24=3c675a&begin=1517184000&end=1517270400
echo "ICAO\tDep - Arr\n"; foreach ($openSkyApi->getFlightsAircraft(icao24: '3c675a', begin: 1517227200, end: 1517230800)->getFlights() as $flight) { printf( "%s\t%s - %s\n", $flight->getIcao24(), $flight->getEstDepartureAirport() ?: '----', $flight->getEstArrivalAirport() ?: '----' ); }
Get all flights arriving at Frankfurt International Airport (EDDF) from 12pm to 1pm on Jan 29 2018: https://opensky-network.org/api/flights/arrival?airport=EDDF&begin=1517227200&end=1517230800
echo "ICAO\tDep - Arr\n"; foreach ($openSkyApi->getFlightsArrival(airport: 'EDDF', begin: 1517227200, end: 1517230800)->getFlights() as $flight) { printf( "%s\t%s - %s\n", $flight->getIcao24(), $flight->getEstDepartureAirport() ?: '----', $flight->getEstArrivalAirport() ?: '----' ); }
Get all flights departing at Frankfurt International Airport (EDDF) from 12pm to 1pm on Jan 29 2018: https://opensky-network.org/api/flights/departure?airport=EDDF&begin=1517227200&end=1517230800
echo "ICAO\tDep - Arr\n"; foreach ($openSkyApi->getFlightsDeparture(airport: 'EDDF', begin: 1517227200, end: 1517230800)->getFlights() as $flight) { printf( "%s\t%s - %s\n", $flight->getIcao24(), $flight->getEstDepartureAirport() ?: '----', $flight->getEstArrivalAirport() ?: '----' ); }