fixes ~ expansion when loading config to enable reading config from ~/.config/vikunja/config.yml
Go to file
konrad 784b890f70 Start end end dates for tasks (#40) 2018-12-22 15:45:16 +00:00
REST-Tests Various user fixes (#38) 2018-12-19 21:05:25 +00:00
docker/etc/services.d Added swaggerfiles do dockerfile 2018-09-08 16:54:21 +02:00
docs Start end end dates for tasks (#40) 2018-12-22 15:45:16 +00:00
pkg Start end end dates for tasks (#40) 2018-12-22 15:45:16 +00:00
templates/mail Add user email verification when registering (#5) 2018-10-27 13:14:55 +00:00
vendor Fix swaggerdocs generation to produce actually valid output (#39) 2018-12-21 21:30:43 +00:00
.drone.yml Tests can now use config files (#36) 2018-12-18 16:01:46 +00:00
.gitignore cleanup 2018-12-12 23:53:20 +01:00
Dockerfile Fixed build 2018-12-13 16:09:00 +01:00
Featurecreep.md Start end end dates for tasks (#40) 2018-12-22 15:45:16 +00:00
LICENSE Change License to GPLv3 (#26) 2018-11-26 20:17:33 +00:00
Makefile Fix swaggerdocs generation to produce actually valid output (#39) 2018-12-21 21:30:43 +00:00
README.md More unit tests (#34) 2018-12-16 13:21:32 +00:00
config.yml.sample Various user fixes (#38) 2018-12-19 21:05:25 +00:00
go.mod Fix swaggerdocs generation to produce actually valid output (#39) 2018-12-21 21:30:43 +00:00
go.sum Fix swaggerdocs generation to produce actually valid output (#39) 2018-12-21 21:30:43 +00:00
main.go Add prometheus endpoint for getting metrics (#33) 2018-12-12 22:50:35 +00:00
tools.go More unit tests (#34) 2018-12-16 13:21:32 +00:00

README.md

Vikunja API

The Todo-app to organize your life.

Build Status License: GPL v3 Download Docker Pulls Swagger Docs Go Report Card cover.run

Features

  • Create TODO lists with tasks
    • Reminder for tasks
  • Namespaces: A "group" which bundels multiple lists
  • Share lists and namespaces with teams and users with granular permissions

Try it under try.vikunja.io!

Roadmap

I know, it's still a long way to go. I'm currently working on a lot of "basic" features, the exiting things will come later. Don't worry, they'll come.

  • Prioritize tasks

  • Subtasks

  • Repeating tasks

  • Get tasks via caldav

  • Labels for todo lists and tasks

  • Assign users to tasks

  • Attachments on tasks

  • Get all your tasks for an interval (day/month/period)

  • More sharing features

    • Share with individual users
    • Share via a world-readable link with or without password, like Nextcloud
  • Mobile apps (seperate repo)

  • Webapp (seperate repo)

Development

We use go modules to vendor libraries for Vikunja, so you'll need at least go 1.11.

To contribute to Vikunja, fork the project and work on the master branch.

Some internal packages are referenced using their respective package URL. This can become problematic. To “trick” the Go tool into thinking this is a clone from the official repository, download the source code into $GOPATH/code.vikunja.io/api. Fork the Vikunja repository, it should then be possible to switch the source directory on the command line.

cd $GOPATH/src/code.vikunja.io/api

To be able to create pull requests, the forked repository should be added as a remote to the Vikunja sources, otherwise changes cant be pushed.

git remote rename origin upstream
git remote add origin git@git.kolaente.de:<USERNAME>/api.git
git fetch --all --prune

This should provide a working development environment for Vikunja. Take a look at the Makefile to get an overview about the available tasks. The most common tasks should be make test which will start our test environment and make build which will build a vikunja binary into the working directory. Writing test cases is not mandatory to contribute, but it is highly encouraged and helps developers sleep at night.

Thats it! You are ready to hack on Vikunja. Test changes, push them to the repository, and open a pull request.