LibreTaxi is open-source Uber proof-of-concept that works through Telegram.
See it in action: https://t.me/libretaxi_bot
Public feed: https://t.me/libretaxi_all
It is closer to Craigslist rideshare rather than Uber, but it works, and works great! The app that is easy to use, supports multiple languages, fast and cool. There are tens of thousands users worldwide, and we're on the way to 1M users. So please spread the word!
- Install Go
- Install Go dep
- Download the repo to
~/go/src/libretaxi
- Install Docker with docker-compose
- Run PostgreSQL and RabbitMQ with default credentials (see connection strings below)
docker-compose up -d
rabbitmq:3-management
contains UI plugin for queue management. Plugin port is 8080 (15672 in container).
Login guest/guest.
Login to RabbitUI here: http://localhost:8080
There is only one queue at the moment:
messages
queue, http://localhost:8080/#/queues/%2F/messages - picked up by message handler, enqueued by libretaxi
Note that there is one message producer, and one message consumer threads (goroutines) in application.
Port 5672 is RabbitMQ itself.
Init settings for ./libretaxi.yml
:
telegram_token: YOUR_TOKEN
db_conn_str: postgres://libretaxi:libretaxi@localhost:15432/libretaxi
rabbit_url: amqp://127.0.0.1:8079/
admin_channel_chat_id: -1001324105405
public_channel_chat_id: -1001470847849
Admin channel is the place where you shadow ban spamers.
See https://stackoverflow.com/a/41779623/337085 for how to get id for you private channel.
You'll need to invite @get_id_bot
and type /my_id@get_id_bot
. You'll see chat id.
When all services are running, run libretaxi:
dep ensure # or ~/go/bin/dep ensure
go build
./libretaxi
Shown below are our bronze, silver and gold project sponsors. Big thanks to these companies for supporting the project. Note: Listed services are not tested, vetted nor supported by the author(s) in any manner.
Prevent workplace conflicts with this Slack app: