2021-12-04 17:33:50 +00:00
# SNCF Binding
The SNCF binding provides real-time data(*) for each train, bus, tramway... station in France.
This is based on live API provided by DIGITALSNCF.
Get your API key on [DIGITALSNCF web site ](https://www.digital.sncf.com/startup/api/token-developpeur )
2022-12-14 15:52:43 +00:00
Note : SNCF Api is based on the open [API Navitia ](https://doc.navitia.io/#getting-started ).
2021-12-04 17:33:50 +00:00
This binding uses a very small subset of it, restricted to its primary purpose.
(*) According to DIGITALSNCF Transilien may only be available for schedule, maybe not real-time.
## Supported Things
2022-12-14 15:52:43 +00:00
Bridge: The binding supports a bridge to connect to the [DIGITALSNCF service ](<https://www.digital.sncf.com/startup/api/token> developpeur ).
2021-12-04 17:33:50 +00:00
A bridge uses the thing ID "api".
Station: Represents a given bus, train station.
Of course, you can add as many stations as needed.
## Discovery
This binding takes care of auto discovery. This method is strongly recommended as it is the only way to get proper station ID depending upon transportation type.
2022-12-14 15:52:43 +00:00
To enable auto-discovery, your location system setting must be defined.
2021-12-04 17:33:50 +00:00
Once done, at first launch, discovery will search every station in a radius of 2000 m around the system, extending it by step of 500 m until it finds a first set of results.
Every following manual successive launch will extend this radius by 500 m, increasing the number of stations discovered.
## Binding Configuration
The binding has no configuration options, all configuration is done at Thing level.
## Bridge Configuration
2022-12-14 15:52:43 +00:00
The bridge configuration only holds the api key :
2021-12-04 17:33:50 +00:00
2022-12-14 15:52:43 +00:00
| Parameter | Description |
| --------- | ------------------------------------------------------ |
| apiID | API ID provided by the DIGITALSNCF service. Mandatory. |
2021-12-04 17:33:50 +00:00
## Thing Configuration
The 'Station' thing has only one configuration parameter:
2022-12-14 15:52:43 +00:00
| Parameter | Description |
| ----------- | ----------------------------------------------------- |
| stopPointId | Identifier of the station in the DIGITALSNCF network. |
2021-12-04 17:33:50 +00:00
The thing will auto-update depending on the timestamp of the earliest event detected to trigger (arrival or departure).
## Channels
The Station thing holds two groups of channels (arrivals and departures) containing these channels:
2022-12-14 15:52:43 +00:00
| Channel ID | Item Type | Description |
| ---------- | --------- | ------------------------------------------- |
| direction | String | The direction of the route |
| lineName | String | Commercial name of the line |
| name | String | Name of the line |
| network | String | Name of the network ruling the line |
| timestamp | DateTime | Timestamp of the event (departure, arrival) |
2021-12-04 17:33:50 +00:00
## Full Example
sncf.things:
2022-12-14 15:52:43 +00:00
```java
2021-12-04 17:33:50 +00:00
Bridge sncf:api:8901d44a68 "Bridge" [apiID="xxx-yyy-zzz"] {
station MyHouse "Krakow"[stopPointId="stop_point:SNCF:87561951:Bus"]
}
```
sncf.items:
2022-12-14 15:52:43 +00:00
```java
2021-12-04 17:33:50 +00:00
String Arrival_Direction { channel="sncf:station:8901d44a68:87381475_RapidTransit:arrivals#direction" }
String Arrival_Line { channel="sncf:station:8901d44a68:87381475_RapidTransit:arrivals#lineName" }
DateTime Arrival_Time { channel="sncf:station:8901d44a68:87381475_RapidTransit:arrivals#timestamp" }
String Departure_Direction { channel="sncf:station:8901d44a68:87381475_RapidTransit:departures#direction" }
String Departure_Line { channel="sncf:station:8901d44a68:87381475_RapidTransit:departures#lineName" }
DateTime Departure_Time { channel="sncf:station:8901d44a68:87381475_RapidTransit:departures#timestamp" }
```