db-vendo-client/docs
Jannis R c7a2813039
changelog 📝, 4.7.0
[ci skip]
2019-12-26 23:11:12 +01:00
..
arrivals.md
changelog.md changelog 📝, 4.7.0 2019-12-26 23:11:12 +01:00
departures.md remove 0 milliseconds from docs & tests 2019-04-29 18:23:40 +01:00
hafas-mgate-api.md move authentication docs to mgate.exe page 📝 2019-12-25 20:00:38 +01:00
journeys.md remove 0 milliseconds from docs & tests 2019-04-29 18:23:40 +01:00
locations.md adapt docs & tests to eb3ffba 📝 2019-02-28 16:45:31 +01:00
migrating-to-3.md more related libs, tiny docs fixes 📝 2019-01-07 16:23:40 +08:00
migrating-to-4.md changelog & "migration to 4" guide 📝, 4.0.0 2019-02-28 17:02:18 +01:00
nearby.md departures/arrivals, locations, nearby, stop: opt.stationLines -> linesOfStops 💥 📝 2019-02-28 16:45:18 +01:00
profile-boilerplate.js tweak "writing a profile" guide 📝 2019-02-28 16:45:31 +01:00
radar.md remove 0 milliseconds from docs & tests 2019-04-29 18:23:40 +01:00
reachable-from.md
readme.md general documentation for mgate.exe endpoints 📝 2019-12-25 20:00:37 +01:00
refresh-journey.md
stop.md departures/arrivals, locations, nearby, stop: opt.stationLines -> linesOfStops 💥 📝 2019-02-28 16:45:18 +01:00
trip.md remove 0 milliseconds from docs & tests 2019-04-29 18:23:40 +01:00
writing-a-profile.md move authentication docs to mgate.exe page 📝 2019-12-25 20:00:38 +01:00

API documentation

Migrating from an old hafas-client version

Throttling requests

There's opt-in support for throttling requests to the endpoint.

const withThrottling = require('hafas-client/throttle')
const createClient = require('hafas-client')
const dbProfile = require('hafas-client/p/db')

// create a throttled HAFAS client with Deutsche Bahn profile
const createThrottledClient = withThrottling(createClient)
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 withThrottling:

// 2 requests per second
const createThrottledClient = withThrottling(createClient, 2, 1000)
const client = createThrottledClient(dbProfile, 'my-awesome-program')

Retrying failed requests

There's opt-in support for retrying failed requests to the endpoint.

const withRetrying = require('hafas-client/retry')
const createClient = require('hafas-client')
const dbProfile = require('hafas-client/p/db')

// create a client with Deutsche Bahn profile that will retry on HAFAS errors
const createRetryingClient = withRetrying(createClient)
const client = createRetryingClient(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 withRetrying. They will be passed into retry.

// retry 2 times, after 10 seconds & 30 seconds
const createRetryingClient = withRetrying(createClient, {
	retries: 2,
	minTimeout: 10 * 1000,
	factor: 3
})
const client = createRetryingClient(dbProfile, 'my-awesome-program')

Writing a profile

Check the guide.

General documentation for mgate.exe APIs

hafas-mgate-api.md