An easy system to organize yours and your coworkers lunch orders.
git clone https://github.com/robjuz/futtertrog.git
composer install
cp .env.example .env
- edit
.env
- setup webserver
docker run --rm robjuz/futtertrog php artisan key:gen --show
Remember to set APP_KEY generated in previous step
Please also set you APP_URL and SMTP credentials
services:
app:
image: robjuz/futtertrog
depends_on:
db:
condition: service_healthy
environment:
APP_NAME: Futtertrog
APP_KEY: <APP_KEY>
APP_URL: <APP_URL>
DB_CONNECTION: mysql
DB_HOST: db
DB_DATABASE: futtertrog
DB_USERNAME: futtertrog
DB_PASSWORD: futtertrog
MAIL_MAILER: smtp
MAIL_HOST: <MAIL_HOST>
MAIL_PORT: 2525
MAIL_USERNAME: <MAIL_USER>
MAIL_PASSWORD: <MAIL_PASSWORD>
MAIL_ENCRYPTION: null
HOLZKE_ENABLED: "true"
HOLZKE_LOGIN:
HOLZKE_PASSWORD:
HOLZKE_SCHEDULE: "false"
cron:
image: robjuz/futtertrog
extends:
service: app
command: php artisan schedule:work
db:
image: docker.io/bitnami/mariadb:11.5
environment:
MARIADB_ROOT_PASSWORD: futtertrog
MARIADB_DATABASE: futtertrog
MARIADB_USER: futtertrog
MARIADB_PASSWORD: futtertrog
volumes:
- db:/bitnami/mariadb
healthcheck:
test: [ 'CMD', '/opt/bitnami/scripts/mariadb/healthcheck.sh' ]
interval: 15s
timeout: 5s
retries: 6
volumes:
db:
You could use nginx as reverse proxy and certbot to manage you certificate
The system currently support 3 providers
Provider | Prices | Auto ordering |
---|---|---|
Holzke | yes | yes |
Groumetta | yes | yes |
Call A Pizza | no | no |
Manuall | no | no |
If you with to also import prices please set you Holzke credentials in .env
file
HOLZKE_ENABLED: "true"
HOLZKE_LOGIN:
HOLZKE_PASSWORD:
If you with to automatically get available menus, set in .env
file
HOLZKE_SCHEDULE: "true"
If you with to also import prices please set you Holzke credentials in .env
file
GOURMETTA_ENABLED: "true"
GOURMETTA_LOGIN:
GOURMETTA_PASSWORD:
If you with to automatically get available menus, set in .env
file
GOURMETTA_SCHEDULE: "true"
CALL_A_PIZZA_ENABLED: "true"
Set you location using the CALL_A_PIZZA_LOCATION
variable in .env
file
To obtain the location key
- Visit https://www.call-a-pizza.de
- Enter you postcode
- Get the location key from the url. ex.
dresden_loebtau_sued
FLASCHENPOST_ENABLED: "true"
- go to GitLab -> Applications and create a new App
- set Callback URL to
https://<your_domain>/login/gitlab/callback
- set Callback URL to
.env
GITLAB_CLIENT_ID=
GITLAB_CLIENT_SECRET=
GITLAB_URL=
- go to Authentik -> Providers and create a new Provider
- set Redirect URIs to
https://<your_domain>/login/authentic/callback
- set Redirect URIs to
- go to Authentik -> Applicaations and create a new Application
- use the provider from previous step
.env
AUTHENTIK_BASE_URL=
AUTHENTIK_CLIENT_ID=
AUTHENTIK_CLIENT_SECRET=
to enable general debugging logs, set the APP_DEBUG=true
in the .env
file
composer install
cp .env.example .env
- set you DATABASE credentials in the
.env
file
After first install you need to generate the APP_KEY
php artisan key:gen
php artisan serve
Visit http://localhost:8000 in your browser
To expose the app container port you can use this:
docker-compose.override.yml
services:
app:
ports:
- 8080:80
docker-compose pull
docker-compose up -d
After first install you need to generate the APP_KEY
docker-compose exec app php artisan key:gen
Visit http://localhost:8080 in your browser
docker-compose.override.yml
services:
mailhog:
ports:
- 8025:8025
You can see your mails using MailHog under localhost:8025
vendor/bin/phpunit
or
php artisan test
- Go to PHP settings and set default interpreter to the app service.
- In the Lifecycle option select "Connect to existing container"
docker-compose up -d
Now you can run phpunit with the ide
php artisan db:seed
or
docker-compose exec app php artisan db:seed
Will create a admin@example.com
user with 123456
password. You can change this password in the app.