HerrLevin / traewelling

Free check-in service to log your public transit journeys

Home Page:https://traewelling.de

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Träwelling

Träwelling is a free check-in service that lets you tell your friends where you are and where you can log your public transit journeys. In short, you can check into trains and get points for it. Check it out at traewelling.de.

Resources build with prod Resources build with dev Composer install and test Laravel Gitmoji Codacy Badge Codacy Coverage Badge Translation status License Träwelling Screenshot

Features

  • Check into trains and other public transport options in most of Europe
  • Track your work trips, e.g. for tax returns and travel expenses
  • Follow other people and see where they're going
  • Meet new friends who are on the same train
  • Find who's going to an event and is in your train
  • Automatic sharing to Twitter and Mastodon
  • Available in German, English, Polish, French and Dutch

Set up an instance

We're using the Laravel framework which depends on:

  • PHP 8.0 (or higher)
    • PHP GD library
  • Composer
  • NodeJS
  • A database of choice, e.g. MariaDB or SQLite (preferably MariaDB)
    • If you're using SQLite, make sure you have php-sqlite installed
  • A local instance of db-rest v5

After setting up those things, you can clone the repository and get the dependencies:

composer install
npm install

Now, you can create your own environment configuration:

cp .env.example .env
vi .env

Please change whatever sounds wrong to you. This is also the place to add API keys (e.g. for Twitter). While you will not need all of those, you can stumble into weird bugs.

Then, generate some application keys and migrate the database to the latest level:

php artisan key:generate
php artisan migrate 
#for example data use 
#php artisan migrate --seed
php artisan passport:install

Last, but not least, you can run npm run dev to build the frontend and watch for changes in the resources/ folder.

Use your webserver of choice or artisan (php artisan serve) to boot the application. You should see the Träwelling homepage.

Contributing

Contributions are more than welcome. Please open an issue for bugs or feature requests. If you want to implement the feature - great; if you don't want to, that's fine, too.

If you add code:

  • If you edit the language files, please check if your change is applicable at least in german.

  • If you work on the front page (see screenshot above), please consider updating the screenshot.

  • Unless you really want to work on Träwelling for a long time, we cannot support more languages. It would be sad to have half-baked languages that have missing strings after a while.

  • Please consider adding unit and integration tests, especially if you're adding new features.

Translations

We currently support the languages German, English, Polish, French and Dutch. We would like to become even more international and for this we need you and your language skills.

We use a Weblate instance to manage the translations. There you can add new translations and correct mistakes.

License

We are using the Affero General Public License (why?) - you are required to publish changes that you make to this software. Please refrain from creating your own public instance of Träwelling, instead try to create a better version for everyone.

About

Free check-in service to log your public transit journeys

https://traewelling.de

License:GNU Affero General Public License v3.0


Languages

Language:PHP 63.7%Language:Blade 27.6%Language:Vue 8.6%Language:Shell 0.1%