# Deutsche Bahn Binding The Deutsche Bahn Binding provides the latest timetable information for all trains that arrive or depart at a specific train station, including live information for delays and changes in timetable. The information are requested from the timetable api of Deutsche Bahn developer portal, so you'll need a (free) developer account to use this binding. ## Supported Things - **timetable** The timetable bridge connects to the timetable api and provides information for the next trains that will arrive or depart at the configured station. - **train** The train thing represents one trains within the configured timetable. This may be an arrival or a departure. ## Thing Configuration ### Generate Access-Key for timetable API To configure a timetable you first need to register at Deutsche Bahn developer portal and register for timetable API to get an access key. 1. Go to [Deutsche Bahn Developer](https://developer.deutschebahn.com) 2. Register new account or login with an existing one 3. If no application is configured yet (check Tab "Meine Anwendungen") create a new application. Only the name is required, any other fields can be left blank. 4. Go to APIs - Timetables v1 (may be displayed on second page) 5. Choose your previously created application and hit "Abonnieren" 6. In confirmation-dialog choose "Wechsel zu meine Abonnements" 7. Create an access key for the production environment by hitting "Schlüssel Erstellen" 8. Copy the "Zugangstoken". This is required to access the api from openHAB. ### Determine the EVA-No of your station For the selection of the station within openHAB you need the eva no. of the station. You can look up the number within the csv file available at [Haltestellendaten](https://data.deutschebahn.com/dataset.tags.EVA-Nr..html). ### Configure timetable bridge With access key for developer portal and eva no. of your station you're ready to configure a timetable (bridge) for this station. In addition you can configure if only arrivals, only departures or all trains should be contained within the timetable. **timetable** parameters: | Property | Default | Required | Description | |-|-|-|-| | `accessToken` | | Yes | The access token for the timetable api within the developer portal of Deutsche Bahn. | | `evaNo` | | Yes | The eva nr. of the train station for which the timetable will be requested.| | `trainFilter` | | Yes | Selects the trains that will be displayed in the timetable. Either only arrivals, only departures or all trains can be displayed. | ### Configuring the trains Once you've created the timetable you can add train-things that represent the trains within this timetable. Each train represents one position within the timetable. For example: If you configure a train with position 1 this will be the next train that arrives / departs at the given station. Position 2 will be the second one, and so on. If you want to show the next 4 trains for a station, create 4 things with positions 1 to 4. **Attention:** The timetable api only provides data for the next 18 hours. If the timetable contains less train entries than you've created train things, the channels of these trains will be undefined. **train** parameters: | Property | Default | Required | Description | |-|-|-|-| | `position` | | Yes | The position of the train within the timetable. | ## Channels Each train has a set of channels, that provides access to any information served by the timetable API. A detailed description of the values and their meaning can be found within the [Timetables V1 API Description](https://developer.deutschebahn.com/store/apis/info?name=Timetables&version=v1&provider=DBOpenData&). The information are grouped into three channel-groups: The first channel group (trip) contains all information for the trip of the train, for example the category (like ICE, RE, S). The second and third channel group contains information about the the arrival and the departure of the train at the given station. Both of the groups may provide an 'UNDEF' channel value, when the train does not arrive / depart at this station (due it starts or ends at the given station). If you have configured your timetable to contain only departures (with property trainFilter) the departure channel values will always be defined and if you have selected only arrivals the arrival channel values will always be defined. Channels will have a 'NULL' channel value, when the corresponding attribute is not set. Basically most information are available as planned and changed value. This allows to easy display changed values (for example the delay or changed platform). **Channels for trip information** | channel | type | description | |----------|--------|------------------------------| | category | String | Provides the category of the trip, e.g. "ICE" or "RE". | | number | String | Provides the trip/train number, e.g. "4523". | | filter-flags | String | Provides the filter flags. | | trip-type | String | Provides the type of the trip. | | owner | String | Provides the owner of the train. A unique short-form and only intended to map a trip to specific evu (EisenbahnVerkehrsUnternehmen). | **Channels for arrival / departure** | channel | type | description | |----------|--------|------------------------------| | planned-path | String | Provides the planned path of a train. | | changed-path | String | Provides the changed path of a train. | | planned-platform | String | Provides the planned platform of a train. | | changed-platform | String | Provides the changed platform of a train. | | planned-time | DateTime | Provides the planned time of a train. | | changed-time | DateTime | Provides the changed time of a train. | | planned-status | String | Provides the planned status (planned, added, cancelled) of a train. | | changed-status | String | Provides the changed status (planned, added, cancelled) of a train. | | cancellation-time | DateTime | Time when the cancellation of this stop was created. | | line | String | The line of the train. | | messages | String | Messages for this train. Contains all translated codes from the messages of the selected train stop. Multiple messages will be separated with a single dash. | | hidden | Switch | On if the event should not be shown because travellers are not supposed to enter or exit the train at this stop. | | wings | String | A sequence of trip id separated by pipe symbols. | | transition | String | Trip id of the next or previous train of a shared train. At the start stop this references the previous trip, at the last stop it references the next trip. | | planned-distant-endpoint | String | Planned distant endpoint of a train. | | changed-distant-endpoint | String | Changed distant endpoint of a train. | | distant-change | Number | Distant change | | planned-final-station | String | Planned final station of the train. For arrivals the starting station is returned, for departures the target station is returned. | | planned-intermediate-stations | String | Returns the planned stations this train came from (for arrivals) or the stations this train will go to (for departures). Stations will be separated by single dash. | | changed-final-station | String | Changed final station of the train. For arrivals the starting station is returned, for departures the target station is returned. | | changed-intermediate-stations | String | Returns the changed stations this train came from (for arrivals) or the stations this train will go to (for departures). Stations will be separated by single dash. | ## Full Example timetable.things ``` Bridge deutschebahn:timetable:timetableLehrte "Fahrplan Lehrte" [ accessToken="XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX", trainFilter="departures", evaNo="8000226" ] { Thing deutschebahn:train:timetableLehrte:lehrteZug1 "Zug 1" [ position="1" ] Thing deutschebahn:train:timetableLehrte:lehrteZug2 "Zug 2" [ position="2" ] } ``` timetable.items ``` // Groups Group zug1 "Zug 1" Group zug1Fahrt "Zug 1 Fahrt" (zug1) Group zug1Ankunft "Zug 1 Ankunft" (zug1) Group zug1Abfahrt "Zug 1 Abfahrt" (zug1) // Trip Information String Zug1_Trip_Category "Kategorie" (zug1Fahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:trip#category"} String Zug1_Trip_Number "Nummer" (zug1Fahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:trip#number"} String Zug1_Trip_FilterFlags "Filter" (zug1Fahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:trip#filter-flags"} String Zug1_Trip_TripType "Fahrttyp" (zug1Fahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:trip#trip-type"} String Zug1_Trip_Owner "Unternehmen" (zug1Fahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:trip#owner"} // Arrival Information DateTime Zug1_Arrival_Plannedtime "Geplante Zeit" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-time"} DateTime Zug1_Arrival_Changedtime "Geänderte Zeit" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-time"} String Zug1_Arrival_Plannedplatform "Geplantes Gleis" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-platform"} String Zug1_Arrival_Changedplatform "Geändertes Gleis" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-platform"} String Zug1_Arrival_Line "Linie" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#line"} String Zug1_Arrival_Plannedintermediatestations "Geplante Halte" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-intermediate-stations"} String Zug1_Arrival_Changedintermediatestations "Geänderte Halte" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-intermediate-stations"} String Zug1_Arrival_Plannedfinalstation "Geplanter Start-/Zielbahnhof" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-final-station"} String Zug1_Arrival_Changedfinalstation "Geänderter Start-/Zielbahnhof" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-final-station"} String Zug1_Arrival_Messages "Meldungen" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#messages"} String Zug1_Arrival_Plannedstatus "Geplanter Status" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-status"} String Zug1_Arrival_Changedstatus "Geänderter Status" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-status"} DateTime Zug1_Arrival_Cancellationtime "Stornierungs-Zeitpunkt" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#cancellation-time"} // Arrival advanced information String Zug1_Arrival_Planneddistantendpoint "Geplanter entfernter Endpunkt" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-distant-endpoint"} String Zug1_Arrival_Changeddistantendpoint "Geänderter entfernter Endpunkt" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-distant-endpoint"} String Zug1_Arrival_Plannedpath "Geplante Route" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#planned-path"} String Zug1_Arrival_Changedpath "Geändert Route" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#changed-path"} Number Zug1_Arrival_Distantchange "Geänderter Zielbahnhof" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#distant-change"} Switch Zug1_Arrival_Hidden "Versteckt" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#hidden"} String Zug1_Arrival_Transition "Übergang" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#transition"} String Zug1_Arrival_Wings "Wings" (zug1Ankunft) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:arrival#wings"} // Departure Information DateTime Zug1_Departure_Plannedtime "Geplante Zeit" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-time"} DateTime Zug1_Departure_Changedtime "Geänderte Zeit" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-time"} String Zug1_Departure_Plannedplatform "Geplantes Gleis" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-platform"} String Zug1_Departure_Changedplatform "Geändertes Gleis" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-platform"} String Zug1_Departure_Line "Linie" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#line"} String Zug1_Departure_Plannedintermediatestations "Geplante Halte" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-intermediate-stations"} String Zug1_Departure_Changedintermediatestations "Geänderte Halte" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-intermediate-stations"} String Zug1_Departure_Plannedfinalstation "Geplanter Start-/Zielbahnhof" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-final-station"} String Zug1_Departure_Changedfinalstation "Geänderter Start-/Zielbahnhof" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-final-station"} String Zug1_Departure_Messages "Meldungen" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#messages"} String Zug1_Departure_Plannedstatus "Geplanter Status" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-status"} String Zug1_Departure_Changedstatus "Geänderter Status" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-status"} DateTime Zug1_Departure_Cancellationtime "Stornierungs-Zeitpunkt" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#cancellation-time"} // Departure advanced information String Zug1_Departure_Planneddistantendpoint "Geplanter entfernter Endpunkt" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-distant-endpoint"} String Zug1_Departure_Changeddistantendpoint "Geänderter entfernter Endpunkt" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-distant-endpoint"} String Zug1_Departure_Plannedpath "Geplante Route" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#planned-path"} String Zug1_Departure_Changedpath "Geändert Route" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#changed-path"} Number Zug1_Departure_Distantchange "Geänderter Zielbahnhof" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#distant-change"} Switch Zug1_Departure_Hidden "Versteckt" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#hidden"} String Zug1_Departure_Transition "Übergang" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#transition"} String Zug1_Departure_Wings "Wings" (zug1Abfahrt) {channel="deutschebahn:train:timetableLehrte:lehrteZug1:departure#wings"} ``` Example widget for displaying train details ``` uid: timetable_train_details tags: - card props: parameters: - context: item label: Geplante Zeit name: planned_time required: true type: TEXT - context: item label: Geänderte Zeit name: changed_time required: true type: TEXT - context: item label: Geplantes Gleis name: planned_platform required: true type: TEXT - context: item label: Geändertes Gleis name: changed_platform required: true type: TEXT - context: item label: Linie name: line required: true type: TEXT - context: item label: Meldungen name: messages required: true type: TEXT - context: item label: Geplanter Start-/Zielbahnhof name: planned_final_station required: true type: TEXT - context: item label: Geplante Halte name: planned_intermediate_stations required: true type: TEXT - context: item label: Geändeter Start-/Zielbahnhof name: changed_final_station required: true type: TEXT - context: item label: Geänderte Halte name: changed_intermediate_stations required: true type: TEXT - context: item label: Geänderter Status name: changed_state required: true type: TEXT - context: item label: Kategorie name: category required: true type: TEXT - context: item label: Nummer name: number required: true type: TEXT parameterGroups: [] timestamp: Oct 14, 2021, 11:24:45 AM component: f7-card config: style: padding: 10px slots: default: - component: f7-row slots: default: - component: f7-col config: width: 15 slots: default: - component: Label config: text: "=items[props.planned_time].displayState + (items[props.changed_time].state != 'NULL' && items[props.changed_time].state != items[props.planned_time].state ? ' (' + items[props.changed_time].displayState + ')' : '')" style: color: "=items[props.changed_time].state != 'NULL' && items[props.changed_time].state != items[props.planned_time].state ? 'red' : ''" - component: f7-col config: width: 75 slots: default: - component: Label config: text: "=(items[props.changed_state].state == 'c' ? 'Zug fällt aus - ' : '') + (items[props.messages].state != 'NULL' ? items[props.messages].state : '')" style: color: red - component: f7-col config: width: 10 slots: default: - component: Label config: text: "=items[props.changed_platform].state != 'NULL' ? items[props.changed_platform].state : items[props.planned_platform].state" style: color: "=items[props.changed_platform].state != 'NULL' ? 'red' : ''" text-align: right - component: f7-row slots: default: - component: f7-col config: width: 15 slots: default: - component: Label config: text: "=items[props.line].state != 'NULL' ? (items[props.category].state + ' ' + items[props.line].state) : (items[props.category].state + ' ' + items[props.number].state)" - component: f7-col config: width: 50 slots: default: - component: Label config: text: "=items[props.changed_intermediate_stations].state != 'NULL' ? items[props.changed_intermediate_stations].state : items[props.planned_intermediate_stations].state" style: color: "=items[props.changed_intermediate_stations].state != 'NULL' ? 'red' : ''" - component: f7-col config: width: 35 slots: default: - component: Label config: text: "=items[props.changed_final_station].state != 'NULL' ? items[props.changed_final_station].state : items[props.planned_final_station].state" style: color: "=items[props.changed_final_station].state != 'NULL' ? 'red' : ''" font-weight: bold text-align: right ``` Using the widget for displaying the next four departures: ![Departures Hannover HBF](doc/Abfahrten_HannoverHBF.png "openHAB page with four widgets displaying the next departures at Hannover HBF")