No description
Find a file
2025-10-10 12:49:38 +02:00
.github fix: run npm ci instead of npm install 2025-10-09 20:05:57 +02:00
.idea style: Arrange all fields and methods 2022-04-06 10:34:19 +02:00
application Upgrade debug client to version 2025/10/2025-10-10T10:30 2025-10-10 10:31:41 +00:00
client fix: remove undesired useEffect 2025-10-09 22:42:58 +02:00
doc Remove un-necessary header [ci skip] 2025-10-10 12:49:38 +02:00
gtfs-realtime-protobuf Prepare next development iteration 2.9.0-SNAPSHOT 2025-09-10 11:34:08 +02:00
otp-shaded Prepare next development iteration 2.9.0-SNAPSHOT 2025-09-10 11:34:08 +02:00
raptor refactor: use withX not setX in DebugRequestBuilder 2025-10-01 14:31:59 +02:00
script fix: Check PR bump.ser.ver.id label in custom-release.py 2025-10-06 17:54:09 +02:00
test Use snapshot version 2025-09-22 10:29:19 +02:00
utils Remove color fallback 2025-10-03 14:35:26 +02:00
.git-blame-ignore-revs Add commit to .git-blame-ignore-revs 2025-06-23 11:37:40 +02:00
.gitignore Update diagram 2025-01-07 18:06:14 +01:00
.prettierrc.yml Fix compatibility issues with nordic profile from #4863 2023-03-02 17:07:39 +01:00
ARCHITECTURE.md Change titles to title case. 2025-10-08 10:38:03 +03:00
codecov.yml Fix codecov syntax [ci skip] 2022-12-21 21:56:21 +01:00
CONTRIBUTING.md Change titles to title case. 2025-10-08 10:38:03 +03:00
DEVELOPMENT_DECISION_RECORDS.md Merge remote-tracking branch 'upstream/dev-2.x' into ddr_connecti_realay 2024-12-09 12:06:24 +02:00
lgpl-3.0.txt add LGPL 2009-12-03 02:02:39 +00:00
LICENSE Add a single License file and remove all OTP and OBA file license headers. 2018-08-14 13:27:53 +02:00
magidoc.mjs refactor: Fix paths in CI scripts 2024-10-11 16:12:59 +02:00
maven-settings.xml replace TravisCI with GH actions and packages 2021-01-06 15:10:36 +08:00
mkdocs.yml Improve feed info documentation 2025-07-17 15:37:08 +02:00
pom.xml Bump serialization version id for #6920 2025-10-07 14:28:36 +00:00
README.md Change titles to title case. 2025-10-08 10:38:03 +03:00
renovate.json5 Apply renovate hack to avoid invalid lockfile 2025-10-09 20:45:19 +02:00

Overview

Join the chat at https://gitter.im/opentripplanner/OpenTripPLanner Matrix codecov Commit activity Docker Pulls

OpenTripPlanner (OTP) is an open source multi-modal trip planner, focusing on travel by scheduled public transportation in combination with bicycling, walking, and mobility services including bike share and ride hailing. Its server component runs on any platform with a Java virtual machine ( including Linux, Mac, and Windows). It exposes GraphQL APIs that can be accessed by various clients including open source Javascript components and native mobile applications. It builds its representation of the transportation network from open data in open standard file formats (primarily GTFS and OpenStreetMap). It applies real-time updates and alerts with immediate visibility to clients, finding itineraries that account for disruptions and service changes.

Note that this branch contains OpenTripPlanner 2, the second major version of OTP, which has been under development since 2018 and is now the dominant one and the only one being supported.

Development

OpenTripPlanner is a collaborative project incorporating code, translation, and documentation from contributors around the world. We welcome new contributions. Further development guidelines can be found in the documentation.

Contributing Guidelines

See CONTRIBUTING.md

Development History

The OpenTripPlanner project was launched by Portland, Oregon's transport agency TriMet (http://trimet.org/) in July of 2009. As of this writing in September 2025, it has been in development for over 16 years. See the main documentation for an overview of OTP history and a list of cities and regions using OTP around the world.

Measuring OTP Performance

📊 Dashboard

We run a speed test (included in the code) to measure the performance for every PR merged into OTP.

More information about how to set up and run it.

Repository Layout

The main Java server code is in application/src/main/. OTP also includes a Javascript client based on the MapLibre mapping library in client/src/. This client is now used for testing, with most major deployments building custom clients from reusable components. The Maven build produces a unified ("shaded") JAR file at otp-shaded/target/otp-shaded-VERSION.jar containing all necessary code and dependencies to run OpenTripPlanner.

Additional information and instructions are available in the main documentation, including a quick introduction.

Getting in Touch

The fastest way to get help is to use our Gitter chat room where most of the core developers are. Bug reports may be filed via the Github issue tracker. The OpenTripPlanner mailing list is used almost exclusively for project announcements. The mailing list and issue tracker are not intended for support questions or discussions. Please use the chat for this purpose. Other details of project governance can be found in the main documentation.

OTP Ecosystem

  • awesome-transit Community list of transit APIs, apps, datasets, research, and software.