Find a file
2025-10-24 20:16:32 +00:00
.github chore: CI: publish to npm using OIDC tokens (#36) 2025-10-22 20:44:53 +02:00
docs update dbnav endpoints, fix tests 2025-10-21 17:40:14 +00:00
format refactor 2025-03-21 21:13:20 +00:00
lib dticket support 2025-04-11 20:59:06 +00:00
p fix bestprice for db profile 2025-10-24 19:40:50 +00:00
parse fix ticket parsing 2025-10-21 20:37:50 +00:00
test set db profile to old dbnav domain as an alternative, since the new domain 2025-10-21 20:54:11 +00:00
tools/debug-cli add back cli 2025-01-11 20:55:46 +00:00
.dockerignore fix docker build 2024-12-17 15:39:56 +00:00
.editorconfig Node 6+, cleanup 2016-12-14 00:22:02 +01:00
.gitignore fix docker build 2024-12-17 15:39:56 +00:00
api.js add dbbahnhof 2025-03-22 00:39:43 +00:00
contributing.md contributing.md: link to testing docs 📝 2023-12-07 00:54:56 +01:00
cspell.config.json discontinue dbbahnhof, update deps 2025-10-21 18:05:29 +00:00
Dockerfile fix dockerfile 2025-01-08 23:24:40 +00:00
eslint.config.js Replace lodash by modern JavaScript functions (#20) 2025-03-01 17:30:58 +01:00
index.js Add BMIS number support for business customer rates (#30) 2025-07-14 19:48:41 +02:00
LICENSE.md Update copyright information (#15) 2025-02-14 22:33:50 +01:00
package-lock.json fix bestprice for db profile 2025-10-24 19:40:50 +00:00
package.json add checks back to release, fix readme 2025-10-24 20:16:32 +00:00
readme.md add checks back to release, fix readme 2025-10-24 20:16:32 +00:00
retry.js apply linting rules 2024-02-10 16:50:12 +01:00
throttle.js apply linting rules 2024-02-10 16:50:12 +01:00

db-vendo-client

A client for the new "vendo"/"movas" Deutsche Bahn APIs, a drop-in replacement for hafas-client.

npm version ISC-licensed support Jannis via GitHub Sponsors

The following FPTF/hafas-client endpoints are supported (depending on the chosen profile, see below):

  • journeys(), refreshJourney() including tickets and bestprice option
  • locations(), nearby(),
  • departures(), arrivals() boards
  • trip()

What doesn't work:

  • journeys() details like stop/station groups, some line details ...
  • loadFactor and other details in boards
  • certain stop details like products for locations() and geopositions for boards this can be remedied with enrichStations in the config (turned on by default), enriching stop info with db-hafas-stations.
  • some query options/filters (e.g. routingMode for journeys, direction for boards)
  • all other endpoints (tripsByName(), radar(), journeysFromTrip(), reachableFrom(), remarks(), lines(), station())

Depending on the configured profile, db-vendo-client will use multiple different DB APIs that offer varying functionality, so choose wisely:

Profile db dbnav dbweb dbris
no API key required
all above endpoints supported except stop() only boards
duration for boards always 1h always 1h always 1h up to 12h
remarks for boards only most important remarks for boards only most important remarks all remarks on boards and journeys all remarks
cancelled trips contained with cancelled flag contained with cancelled flag contained with cancelled flag contained with cancelled flag
tickets only for refreshJourney(), mutually exclusive with polylines only for refreshJourney(), mutually exclusive with polylines only for refreshJourney(), mutually exclusive with polylines
polylines only for refreshJourney()/trip(), mutually exclusive with tickets only for refreshJourney()/trip(), mutually exclusive with tickets only for refreshJourney()/trip(), mutually exclusive with tickets
trip ids used HAFAS trip ids HAFAS trip ids HAFAS trip ids RIS trip ids
line.id/fahrtNr used actual fahrtNr for journeys, unreliable/route id for boards and trip() actual fahrtNr for journeys, unreliable/route id for boards and trip() unreliable/route id
adminCode/operator only for journeys only for journeys only operator
stopovers not in boards not in boards
assumed backend API stability less stable more stable less stable more stable
quotas 60 requests per minute (IPv4), current backend possibly shut off soon 60 requests per minute (IPv4), possibly aggressive blocking aggressive blocking (IPv4/IPv6) depends on API key

Important

If you think that for your project, quotas may become an issue, consider alternative ways to obtain the data you need., e.g. motis-fptf-client (a drop-in replacement for db-vendo-client/hafas-client) in conjunction with https://transitous.org (please consider the usage policy there) or a self-hosted MOTIS instance.

Feel free to report anything that you stumble upon via Issues or create a PR :)

Also consult the documentation.

Background

After DB has switched to the new "vendo"/"movas" platform for bahn.de and DB Navigator, the old HAFAS API (see hafas-client) seems now to have been shut off. This project aims to enable easy switching to the new APIs. However, not all information will be available from the new APIs.

Actually, db-vendo-client is a wrapper around multiple different APIs, currently the bahn.de API for dbweb, the DB Navigator API for the dbnav profile, and a combination of the DB Navigator API and the regio-guide RIS API for the db profile. See some notes about the various new APIs at DB.

Strictly speaking, permission is necessary to use this library with the DB APIs.

Usage

Use it as a dependency, e.g. just replacing hafas-client:

npm i db-vendo-client

See an example in api.js. It shows how you can use db-vendo-client together with hafas-rest-api in order to run a FPTF API server. The Dockerfile serves this API (using the dbnav profile):

docker run \
    -e USER_AGENT=my-awesome-program \
    -e DB_PROFILE=dbnav \
    -p 3000:3000 \
    ghcr.io/public-transport/db-vendo-client

You may want to generate a client for your programming language for this REST API using the OpenAPI schema (open in Swagger Editor). Note that this is to be seen more as a starting point for implementation, e.g. some profile-specific details like tickets are missing from this API definition.

There are community-maintained TypeScript typings available as @types/hafas-client.

Important

Depending on your use case, it is very important that you employ caching, either with a simple HTTP proxy cache in front of the REST API or by using cached-hafas-client (where, of course, you can just drop in a db-vendo-client instead of a hafas-client instance). Also see db-rest, which does this and some more plumbing.

Browser usage

db-vendo-client is mostly browser compatible, however none of the endpoints enables CORS, so it is impossible to use db-vendo-client in normal browser environments. It was tested with vite + capacitorjs and should also work with cordova or react native and similar projects.

Limitations: Does not work with enrichStations option enabled or with the dbris profile.

Contributing

If you have a question, found a bug or want to propose a feature, please open an Issue.

This project needs help! Check the list of "help wanted" Issues.

If you're contributing code, please read the contribution guidelines.