404
+ +Page not found
+ + +diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 00000000..e69de29b diff --git a/404.html b/404.html new file mode 100644 index 00000000..5965a5a7 --- /dev/null +++ b/404.html @@ -0,0 +1,113 @@ + + +
+ + + + +Page not found
+ + +Free and open public transport routing.
+A community-run provider-neutral international public transport routing service.
+Using openly available GTFS/GTFS-RT/etc. feeds and FOSS routing engine we want to operate a routing service that:
+Transitous data sources are divided by region, so they can be continuously tested and verified by locals.
+A region file in the feeds directory has a maintainers
attribute, which contains a list of people responsible for keeping the feeds for the region up to date.
{
+ "maintainers": [ ... ],
+ "sources": [ ... ]
+}
+
+A person is represented like this:
+{
+ "name": "< name of the maintainer >",
+ "github": "< github username of the maintainer >"
+}
+
+The main attribute of a region is sources
. It contains a list of feeds that should be fetched.
Each source can either be of type
"transitland-atlas" or "http".
+A transitland-atlas source is a feed from Transitland, identified by its Onestop ID.
{
+ "name": "<name to be used for the output filename>",
+ "type": "transitland-atlas",
+ "transitland-atlas-id": "<onestop id>"
+}
+
+If the feed is not known in Transitland, a http source can be used instead.
+{
+ "name": "<name to be used for the output filename>",
+ "type": "http",
+ "url": "https://<url of GTFS file>",
+ "license": {
+ "spdx-identifier": "<license identifier from https://spdx.org/licenses/ if known>",
+ "url": "< url as source for the license if available >"
+ }
+}
+
+If the feed contains errors, you can try to add the "fix": true
attribute, to try to automatically correct errors.
Once you create a pull request, fetching your feed will automatically be tested.
+You can also test it locally, by running ./src/fetch.py feeds/<region>.json
.
For that you need to have gtfstidy installed. +You can also use the container described below.
+Running a local instance of the transitous setup can be useful for debugging. +The easiest way is to use the same container image that we use for fetching and importing the data on the CI.
+First, build the container:
+podman build ci/container/ -t transitous -f ci/container/Containerfile
+
+Enter the container:
+podman run -it -p 8080:8080 -v $PWD:/transitous -w /transitous transitous
+
+Now inside the container, you can download and post-process all the feeds. This may take a while.
+./ci/fetch-feeds.py timer
+
+The out/
directory should now contain a number of zip files.
In addition to those, you also need a background map. Importing all of europe would take too long, so for now we just use Berlin.
+wget https://download.geofabrik.de/europe/germany/berlin-latest.osm.pbf -P out
+
+In order to start motis, we need a config file listing all the feeds we want to use. +You can generate one using our script:
+./src/generate-motis-config.py full
+
+You can then go to the out
directory, and start motis:
cd out
+motis -c config.ini --server.host 0.0.0.0 --server.static_path /opt/motis/web
+
+The first start will take a while, as it imports all the maps and feeds. +Once it's done, the motis web interface should be reachable on localhost:8080.
+ + +' + escapeHtml(summary) +'
' + noResultsText + '
'); + } +} + +function doSearch () { + var query = document.getElementById('mkdocs-search-query').value; + if (query.length > min_search_length) { + if (!window.Worker) { + displayResults(search(query)); + } else { + searchWorker.postMessage({query: query}); + } + } else { + // Clear results for short queries + displayResults([]); + } +} + +function initSearch () { + var search_input = document.getElementById('mkdocs-search-query'); + if (search_input) { + search_input.addEventListener("keyup", doSearch); + } + var term = getSearchTermFromLocation(); + if (term) { + search_input.value = term; + doSearch(); + } +} + +function onWorkerMessage (e) { + if (e.data.allowSearch) { + initSearch(); + } else if (e.data.results) { + var results = e.data.results; + displayResults(results); + } else if (e.data.config) { + min_search_length = e.data.config.min_search_length-1; + } +} + +if (!window.Worker) { + console.log('Web Worker API not supported'); + // load index in main thread + $.getScript(joinUrl(base_url, "search/worker.js")).done(function () { + console.log('Loaded worker'); + init(); + window.postMessage = function (msg) { + onWorkerMessage({data: msg}); + }; + }).fail(function (jqxhr, settings, exception) { + console.error('Could not load worker.js'); + }); +} else { + // Wrap search in a web worker + var searchWorker = new Worker(joinUrl(base_url, "search/worker.js")); + searchWorker.postMessage({init: true}); + searchWorker.onmessage = onWorkerMessage; +} diff --git a/search/search_index.json b/search/search_index.json new file mode 100644 index 00000000..3f21f681 --- /dev/null +++ b/search/search_index.json @@ -0,0 +1 @@ +{"config":{"indexing":"full","lang":["en"],"min_search_length":3,"prebuild_index":false,"separator":"[\\s\\-]+"},"docs":[{"location":"","text":"Transitous Free and open public transport routing. Goal A community-run provider-neutral international public transport routing service. Using openly available GTFS/GTFS-RT/etc. feeds and FOSS routing engine we want to operate a routing service that: focuses on the interest of the user rather than the public transport operators is free to use values user privacy does not stop at borders aims at crowd-sourced maintenance of data feeds in the spirit of FOSS Contact Matrix channel: #opentransport:matrix.org (for now) Adding a region Transitous data sources are divided by region, so they can be continuously tested and verified by locals. A region file in the feeds directory has a maintainers attribute, which contains a list of people responsible for keeping the feeds for the region up to date. { \"maintainers\": [ ... ], \"sources\": [ ... ] } A person is represented like this: { \"name\": \"< name of the maintainer >\", \"github\": \"< github username of the maintainer >\" } The main attribute of a region is sources . It contains a list of feeds that should be fetched. Each source can either be of type \"transitland-atlas\" or \"http\". A transitland-atlas source is a feed from Transitland , identified by its Onestop ID. { \"name\": \"