No description
Find a file
2026-03-05 17:11:55 +01:00
.github Use Java 25 for everything 2026-01-27 23:16:07 +02:00
.idea style: Arrange all fields and methods 2022-04-06 10:34:19 +02:00
application Remove test for feature that never made it into the spec [ci skip] 2026-03-05 17:11:55 +01:00
astar Apply review feedback, remove more unused code 2026-02-25 14:06:51 +01:00
client fix(deps): update debug ui dependencies (non-major) 2026-02-19 10:48:55 +00:00
doc Add changelog entry for #7255 [ci skip] 2026-03-04 09:20:43 +00:00
domain-core Fix all package names and imports 2026-02-16 10:58:51 +01:00
gtfs-realtime-protobuf Prepare next development iteration 2.9.0-SNAPSHOT 2025-09-10 11:34:08 +02:00
otp-shaded Change transformation to take registryFile.imagen into account 2025-12-02 15:02:32 +01:00
raptor Merge pull request #7276 from entur/clreanup_RangeRaptorWorker 2026-02-17 09:11:51 +00:00
script Update description_link method format in release script 2025-11-20 15:45:11 +01:00
street Remove test without assertions 2026-03-04 08:20:06 +01:00
test Update performance test docs [ci skip] 2026-02-26 11:05:45 +01:00
utils Use optimal initial capacity for HashMap, HashSet, and ArrayList 2026-03-04 08:16:38 +01:00
.git-blame-ignore-revs Update .git-blame-ignore-revs 2026-02-09 16:38:26 +02:00
.gitignore Ignore EPSG directory that sometimes gets generated during tests 2026-01-30 15:17:15 +02: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
checkstyle.xml Add ConstantName rule to Checkstyle 2026-02-09 16:20:36 +02:00
CLAUDE.md Use Java 25 for everything 2026-01-27 23:16:07 +02:00
codecov.yml Fix codecov syntax [ci skip] 2022-12-21 21:56:21 +01:00
CONTRIBUTING.md Add text about AI tool usage to CONTRIBUTING.md. 2026-02-19 17:19:22 +02:00
DEVELOPMENT_DECISION_RECORDS.md Add docs 2025-10-23 14:18:58 +03: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 Add separate config, docs 2026-01-26 10:53:15 +01:00
openrewrite.yml Add some openrewrite recipes that somewhat match the new checkstyle rules 2026-01-27 18:54:59 +02:00
pom.xml Update dependency ch.qos.logback:logback-classic to v1.5.32 2026-03-04 00:53:09 +00:00
publiccode.yml Run publiccode.yml fields through editor to validate the correctness of the file. 2026-02-20 11:20:15 +02:00
README.md Change titles to title case. 2025-10-08 10:38:03 +03:00
renovate.json5 Don't auto-update ojp-java-model [ci skip] 2026-01-03 23:07:02 +01: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.