Go to file
2019-08-06 16:11:20 +02:00
.vscode Abgaben Zuteilung überarbeitet 2019-06-26 12:12:19 +02:00
app Fix build 2018-10-13 16:48:11 +02:00
assets
config feat(audit): automatic transaction log truncation 2019-08-06 14:22:16 +02:00
frontend feat(allocations): add courses to allocations 2019-08-05 11:34:00 +02:00
gup Nix build harness 2017-10-02 20:17:33 +02:00
hlint
messages Merge branch 'master' of gitlab.cip.ifi.lmu.de:jost/UniWorX 2019-08-06 16:11:20 +02:00
models feat(audit): introduce id-based format 2019-08-06 09:51:05 +02:00
src Merge branch 'master' of gitlab.cip.ifi.lmu.de:jost/UniWorX 2019-08-06 16:11:20 +02:00
static chore(fontawesome): update fontawesome to 5.9.0 2019-07-10 19:24:25 +02:00
templates feat(exams): show occurrenceRule in exam overview 2019-08-06 15:21:57 +02:00
test refactor: minor csv cleanups 2019-08-05 17:23:11 +02:00
testdata
.babelrc
.dir-locals.el
.directory fix(Help Widget, Corrector Assignment): Modal Form closes in place; assign alerts 2019-06-26 19:35:49 +02:00
.dockerignore
.eslintrc.json
.gitignore chore(build): lock .stack-work during builds 2019-07-10 19:41:29 +02:00
.hlint.yaml
build.sh
CHANGELOG.md chore(release): 4.10.0 2019-08-05 19:25:31 +02:00
clean.sh chore(build): lock .stack-work during builds 2019-07-10 19:41:29 +02:00
commitlint.config.js feat(development): add commitlint to ensure proper commit msgs 2019-06-17 22:42:00 +02:00
Datenschutznotizen.txt
db.sh chore(build): lock .stack-work during builds 2019-07-10 19:41:29 +02:00
default.nix
ghci.sh chore(build): lock .stack-work during builds 2019-07-10 19:41:29 +02:00
haddock.sh
hlint.sh
is-clean.sh
karma.conf.js
nixpkgs.nix chore(nix): fix nixpkgs hash 2019-07-31 10:58:52 +02:00
package-lock.json chore(release): 4.10.0 2019-08-05 19:25:31 +02:00
package.json chore(release): 4.10.0 2019-08-05 19:25:31 +02:00
package.yaml chore(release): 4.10.0 2019-08-05 19:25:31 +02:00
PageActionPrime.txt users cannot delete themselves anymore 2019-03-22 11:39:59 +01:00
postcss.config.js
README.md
RoleDescriptions.txt Further comments on database-model 2019-03-15 13:05:46 +01:00
routes fix(course-edit): additional permission checks wrt allocations 2019-08-06 16:10:58 +02:00
run.sh Favourites working now (without PageActions). 2018-04-10 10:38:21 +02:00
shell.nix
stack.nix chore(nix): fix build 2019-07-31 13:23:58 +02:00
stack.yaml
stack.yaml.lock
stackage.nix
start.sh
sync-versions.hs chore(release): fix sync-versions 2019-07-03 14:14:29 +02:00
test.sh
uniworx.sublime-project
uniworx.sublime-workspace
webpack.config.js

"Quick Start" Guide

The following description applies to Ubuntu and similar debian based Linux distributions.

Prerequisites

These are the things you need to do/install before you can get started working on Uni2work.

Clone repository

Clone this repository and navigate into it

$ git clone https://gitlab.cip.ifi.lmu.de/jost/UniWorX.git && cd UniWorX

LDAP

LDAP is needed to handle logins.

Install:

sudo apt-get install slapd ldap-utils

PostgreSQL

PostgreSQL will serve as database for Uni2work.

Install:

$ sudo apt-get install postgresql

Switch to user postgres (got created during installation):

$ sudo -i -u postgres

Add new database user uniworx:

$ createuser --interactive

You'll get a prompt:

Enter name of role to add: uniworx
Shall the new role be a superuser? (y/n)  [not exactly sure. Guess not?]
Password: uniworx
...

Create database uniworx:

$ psql -c 'create database uniworx owner uniworx'
$ psql -c 'create database uniworx_test owner uniworx'

After you added the database switch back to your own user with Ctrl + D.

To properly access the database you now need to add a new linux user called uniworx. Enter "uniworx" as the password.

$ sudo adduser uniworx

Stack

Stack is a toolbox for "Haskellers" to aid in developing Haskell projects.

Install:

$ curl -sSL https://get.haskellstack.org/ | sh

Setup stack and install dependencies. This needs to be run from inside the directory you cloned this repository to:

$ stack setup

During this step or the next you might get an error that says something about missing C libraries for ldap and lber. You can install these using

$ sudo apt-get install libsasl2-dev libldap2-dev

If you get an error that says You need to install postgresql-server-dev-X.Y for building a server-side extension or libpq-dev for building a client-side application. Go ahead and install libpq-dev with

$ sudo apt-get install libpq-dev

Other packages you might need to install during this process:

$ sudo apt-get install pkg-config
$ sudo apt-get install libsodium-dev

Build the app:

$ stack build

This might take a few minutes... if not hours... be prepared.

install yesod:

$ stack install yesod-bin --install-ghc

Node & npm

Node and Npm are needed to compile the frontend.

Install:

$ curl -sL https://deb.nodesource.com/setup_12.x | sudo -E bash -
$ sudo apt-get install -y nodejs

Add dummy data to the database

After building the app you can prepare the database and add some dummy data:

$ ./db.sh -f

Run Uni2work

$ npm start

This will compile both frontend and backend and will start Uni2work in development mode (might take a few minutes the first time). It will keep running and will watch any file changes to automatically re-compile the application if necessary.

If you followed the steps above you should now be able to visit http://localhost:3000 and login as one of the accounts from the Development-Logins dropdown.

Troubleshooting

Please see the wiki for more infos.