mirror of
https://github.com/public-transport/db-vendo-client.git
synced 2025-11-02 17:16:31 +02:00
|
|
||
|---|---|---|
| .. | ||
| arrivals.md | ||
| changelog.md | ||
| departures.md | ||
| journeys.md | ||
| locations.md | ||
| migrating-to-3.md | ||
| nearby.md | ||
| profile-boilerplate.js | ||
| radar.md | ||
| reachable-from.md | ||
| readme.md | ||
| refresh-journey.md | ||
| station.md | ||
| trip.md | ||
| writing-a-profile.md | ||
API documentation
journeys(from, to, [opt])– get journeys between locationsrefreshJourney(refreshToken, [opt])– fetch up-to-date/more details of ajourneytrip(id, lineName, [opt])– get details for a tripdepartures(station, [opt])– query the next departures at a stationarrivals(station, [opt])– query the next arrivals at a stationlocations(query, [opt])– find stations, POIs and addressesstation(id, [opt])– get details about a stationnearby(location, [opt])– show stations & POIs aroundradar(north, west, south, east, [opt])– find all vehicles currently in a certain areareachableFrom(address, [opt])– get all stations reachable from an address withinnminutes
Throttling requests
There's opt-in support for throttling requests to the endpoint.
const createThrottledClient = require('hafas-client/throttle')
const dbProfile = require('hafas-client/p/db')
// create a throttled HAFAS client with Deutsche Bahn profile
const client = createThrottledClient(dbProfile, 'my-awesome-program')
// Berlin Jungfernheide to München Hbf
client.journeys('8011167', '8000261', {results: 1})
.then(console.log)
.catch(console.error)
You can pass custom values for the nr of requests (limit) per interval into createThrottledClient:
// 2 requests per second
const client = createThrottledClient(dbProfile, 'my-awesome-program', 2, 1000)
Retrying failed requests
There's opt-in support for retrying failed requests to the endpoint.
const createClientWithRetry = require('hafas-client/retry')
const dbProfile = require('hafas-client/p/db')
// create a client with Deutsche Bahn profile that will retry on HAFAS errors
const client = createClientWithRetry(dbProfile, 'my-awesome-program')
// Berlin Jungfernheide to München Hbf
client.journeys('8011167', '8000261', {results: 1})
.then(console.log)
.catch(console.error)
You can pass custom options into createClientWithRetry. They will be passed into retry.
// retry 2 times, after 10 seconds & 30 seconds
const client = createClientWithRetry(dbProfile, 'my-awesome-program', {
retries: 2,
minTimeout: 10 * 1000,
factor: 3
})
Writing a profile
Check the guide.