Transport NSW


The transport_nsw sensor will give you the time until the next departure from a Transport NSW stop for bus, train, light rail or ferry.

Setup

Prerequisite is a free API key from Transport NSW. You will need to register an account and then create a new application. You will need to add the ‘Trip Planner APIs’ to your application.

In order to find your stop id, use the Transport NSW stop finder and search for your stop. The URL will contain the stop id as a number.

You may also try going to Google maps and clicking on any bus/train/ferry stop. The pop up window shows the stop ID underneath the station name. For train stations the easiest way to get a stop id for a platform is through Transport NSW Info.

As a default the sensor picks up the next mode of transport leaving from a stop id.

Configuration

To enable the sensor, add the following lines to your configuration.yaml file:

# Example configuration.yaml entry
sensor:
  - platform: transport_nsw
    stop_id: "200024"
    api_key: "YOUR API KEY"

Configuration Variables

api_key string Required

Your API key for Open Data Transport NSW.

stop_id string Required

The ID of the stop to get the information for.

route string (Optional)

Filter on bus route at the stop. This is the same as the bus number, e.g., 83.

destination string (Optional)

Useful for ferry or train stops to filter the destination of the sensor, e.g., Circular Quay.

name string (Optional)

A friendly name for this sensor.

The public information is provided from Transport NSW.

Examples

More example configurations for bus or ferry.

# Example bus route configuration.yaml entry
sensor:
  - platform: transport_nsw
    name: "Bus"
    stop_id: "209516"
    route:  '199'
    api_key: "YOUR API KEY"
# Example ferry configuration.yaml entry
sensor:
  - platform: transport_nsw
    name: "Ferry"
    stop_id: "10102008"
    destination: "Circular Quay"
    api_key: "YOUR API KEY"

The sensor returns n/a if no stop event is found within the next 24h. A template sensor can help building a more meaningful string.

# Sample template sensor
template:
  - sensor:
    - name: "Bus monitor 199"
      state: >-
        {% if is_state_attr('sensor.bus', 'due', 'n/a') %}
          No schedule found
        {% else %}
          {{ state_attr('sensor.bus', 'route') }} in {{ state_attr('sensor.bus', 'due') }}m ({{ state_attr('sensor.bus', 'delay') }})
        {% endif %}