mirror of
https://github.com/simon987/task_tracker.git
synced 2025-04-10 14:06:43 +00:00
2.6 KiB
2.6 KiB
Documentation
Installation (Docker)
Prerequisites:
- You have a postgres container using the network
tt
, listening for connections on172.26.0.2:5432
. Example:docker run -d --name tt_pg --network tt postgres:alpine
-
Initialize the database
psql -h 172.26.0.2 -U postgres > CREATE USER task_tracker; > CREATE database task_tracker;
-
Write configuration file
vim config.yml
server: address: "localhost:3010" database: conn_str: "postgres://task_tracker:task_tracker@172.26.0.2/task_tracker?sslmode=disable" log_levels: ["error", "info", "warn"] git: webhook_hash: "sha256" webhook_sig_header: "X-Gogs-Signature" log: level: "trace" session: cookie_name: "tt" expiration: "8h" monitoring: snapshot_interval: "120s" history_length: "400h" maintenance: reset_timed_out_tasks_interval: "5m"
-
Create task_tracker container:
docker run --rm\ -v $PWD/config.yml:/root/config.yml\ --network tt\ -p 0.0.0.0:12345:80\ simon987/task_tracker
Installation (Linux)
- You have a postgres daemon listening for connections on
localhost:5432
. - You have a working installation of go, nodejs and nginx
-
Initialize the database
sudo su postgres createuser task_tracker createdb task_tracker psql task_tracker > ALTER USER "task_tracker" WITH PASSWORD 'task_tracker';
-
Acquire binaries
API
go get -d github.com/simon987/task_tracker/... cd $GOPATH/src/github.com/simon987/task_tracker/main go build -o tt_api .
UI
git clone https://github.com/simon987/task_tracker cd task_tracker/web/angular npm install ./node_modules/\@angular/cli/bin/ng build --prod --optimization
-
Setup web server
Move ./dist/ to /path/to/webroot/, start ./tt_api
index index.html; root /path/to/webroot; location / { try_files $uri $uri/ /index.html; } location ~ /api(.*)$ { proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection 'upgrade'; proxy_set_header Host $host; proxy_pass http://127.0.0.1:3010$1?$args; }
Getting started
Register a Manager account from the /login page. The first account will automatically be given tracker admin permissions.
Follow the instructions in the index page to create a project.
API documentation
See API_DOCS.md