This repository has been archived on 2024-10-24. You can view files and clone it, but cannot push or open issues or pull requests.
Go to file
2024-08-19 02:10:02 +02:00
.gitlab-ci
.reuse chore: reuse lint 2023-12-06 13:04:47 +00:00
app chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
assets chore(assets): remove icons from repository, to be generated locally 2024-07-29 15:33:15 +02:00
config chore(lms): deactivate lms synch by default 2023-12-01 17:04:42 +01:00
docker chore(docker/frontend): change default entrypoint to watcher 2024-08-19 02:10:02 +02:00
frontend/src chore(frontend): adjusted colour of icons inside of buttons 2024-06-21 17:20:17 +00:00
gup
hlint
LICENSES chore: reuse lint 2023-12-06 13:04:47 +00:00
load
messages chore(faq): update to fit Fraport AG 2024-03-15 17:06:08 +01:00
models fix(health): fix #151 by offering route /health/interface/* 2024-02-02 18:43:57 +01:00
resources
src chore(icons): removed old iconText function 2024-05-23 01:57:12 +00:00
templates style(frontend): adjusted styling to svg icons 2024-05-23 01:24:44 +00:00
test chore(db): ass comments on upsertManyWhere usage 2024-03-08 13:26:34 +01:00
testdata chore(letter): generalizing letter sending (WIP) 2022-11-09 17:05:57 +01:00
utils chore(utils): New utils tool for listing debian packages from Dockerfiles. 2024-08-18 23:16:16 +02:00
..develop.cmd
..develop.cmd.license
.babelrc
.babelrc.license
.dir-locals.el feat(course-user): major improvements 2020-04-16 17:19:16 +02:00
.dir-locals.el.license
.envrc
.envrc.license
.eslintrc.json
.eslintrc.json.license
.gitattributes chore(git): add .gitattributes for prohibiting crlf as eol 2024-08-04 15:21:26 +02:00
.gitignore chore(docker/backend): set HOME env var to /fradrive for stack root 2024-08-18 04:40:52 +02:00
.gitignore.license
.gitlab-ci.yml chore(gitlab-ci): first stub of major ci update 2024-08-19 01:00:50 +02:00
.gitmodules
.gitmodules.license
.hlint.yaml
.mailmap
.mailmap.license
.npmrc.gup.license
.pre-commit-config.yaml chore: configure pre-commit as git hook 2022-10-14 19:53:15 +02:00
.versionrc.js chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
add-license-to-all.sh
build.sh
cbt.sh
CHANGELOG.md chore(release): 27.4.59 2024-02-13 21:15:49 +00:00
CHANGELOG.md.license
clean.sh
commitlint.config.js
compose.yaml chore(docker): add image refs to compose.yaml 2024-08-19 02:09:27 +02:00
CONTRIBUTING chore: add DCO 2022-10-14 19:51:18 +02:00
CONTRIBUTING.license
Datenschutznotizen.txt
Datenschutznotizen.txt.license
db.sh
default.nix
flake.lock chore: add Makefile, update flake.nix and shell.nix for dependencies 2024-01-21 17:03:16 +01:00
flake.lock.license
flake.nix chore: add Makefile, update flake.nix and shell.nix for dependencies 2024-01-21 17:03:16 +01:00
ghci.sh
haddock.sh
hlint.sh
hoogle.sh chore: fix executables 2022-10-12 09:43:42 +02:00
is-clean.sh chore(is-clean.sh): fix branch check 2023-07-14 23:38:22 +00:00
jsconfig.json
jsconfig.json.license
karma.conf.js
load.sh
lpr
Makefile chore(Makefile): use docker compose in dockerized targets 2024-08-19 01:20:01 +02:00
minio-file-uploads.md refactor(files): store content separately from metadata 2020-07-17 15:54:28 +02:00
minio-file-uploads.md.license
missing-translations.sh
new-file.sh
new-file.sh.license
nixpkgs.nix
package-lock.json chore(frontend): replaced fontawesome-pro node module with fontawesome-free 2024-07-26 01:05:55 +00:00
package-lock.json.license
package.json chore(frontend): replaced fontawesome-pro node module with fontawesome-free 2024-07-26 01:05:55 +00:00
package.json.license
package.yaml chore(stack): introduce uniworxdev binary for always retaining binaries in bin/ 2024-08-15 05:17:27 +02:00
postcss.config.js
README.md Update README.md 2019-09-25 12:16:55 +02:00
README.md.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
records.json
records.json.license
release.sh
routes chore(lpr): add manual print-ack csv upload 2024-02-02 13:06:39 +01:00
shell.nix Merge branch '145-build-system-rewrite' into fraport-corporate-design-icons 2024-07-29 14:49:41 +02:00
stack-flake.yaml chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
stack.nix
stack.yaml fix(stack.yaml): move to uniworx.de gitlab 2024-07-29 17:14:18 +02:00
stack.yaml.lock fix(stack.yaml): move to uniworx.de gitlab 2024-07-29 17:14:18 +02:00
stack.yaml.lock.license
stackage.nix
start.sh
test.sh
TODO.md chore(lms): work on lms send notifications, work-in-progress 2022-04-14 18:13:35 +02:00
TODO.md.license
translate.hs
webpack.config.js chore(fonts): reverted new font 2024-06-03 01:37:17 +00:00

"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.

Install german locale

You will need to install the german locale at compile time.

Install:

  • Edit /etc/locale.gen as root and uncomment/add the line de_DE.UTF-8 UTF-8
  • Save the file and run sudo locale-gen

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) y  [user must be superuser to create extensions]
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

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

Build the app:

$ npm run build

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

install yesod:

$ stack install yesod-bin --install-ghc

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 run 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.