Go to file
Steffen Jost 64df38f2a9 fix(build): minor haskell typos/errors
The code was written without having a working compiler, hence some accidental code kinks remained.
2025-03-28 08:58:35 +01:00
.azure-pipelines/templates ci(azure-pipelines): add build-args to release build for network access 2025-02-14 21:32:49 +01:00
.gitlab-ci chore: move version helper script to utils [skip ci] 2025-02-03 18:22:36 +01:00
.gnumake build(Makefile): introduce custom errors for deprecated targets and common mistakes 2024-10-21 00:38:24 +02:00
.reuse chore: reuse lint 2023-12-06 13:04:47 +00:00
assets chore(firm): add company preference for email pin passwords 2025-02-28 17:07:51 +01:00
backend fix(build): minor haskell typos/errors 2025-03-28 08:58:35 +01:00
docker/fradrive Merged PR 18666: Update to docker compose 2025-03-25 15:21:18 +00:00
frontend Merged PR 18666: Update to docker compose 2025-03-25 15:21:18 +00:00
LICENSES chore: reuse lint 2023-12-06 13:04:47 +00:00
resources fix(umlaut): renamee files with german umlaut for ease of use 2025-02-28 18:47:52 +01:00
utils build: move backend-related files into backend dir; implement and connect services via docker-compose 2025-03-23 04:52:49 +01:00
..develop.cmd chore(develop): optionally block shell 2021-09-27 10:56:23 +02:00
..develop.cmd.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
.dir-locals.el feat(course-user): major improvements 2020-04-16 17:19:16 +02:00
.dir-locals.el.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
.envrc chore: switch to direnv-based dev-shell 2021-05-07 11:25:15 +02:00
.envrc.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
.gitignore chore(git): add ghci history to gitignore 2025-03-28 08:52:58 +01:00
.gitignore.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
.gitlab-ci.yml Manual copy from branch 145-build-system-rewrite due to botched-merge 2025-03-03 11:56:07 +01:00
.gitmodules chore: move workflow definitions to submodule 2020-12-18 13:39:55 +01:00
.gitmodules.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
.mailmap chore: update mailmap for s.jost@frapor.de 2023-05-10 15:17:36 +00:00
.mailmap.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
.pre-commit-config.yaml chore: configure pre-commit as git hook 2022-10-14 19:53:15 +02:00
.versionrc.js refactor(frontend): eslint 2025-01-22 10:51:33 +01:00
add-license-to-all.sh chore: add scripts for license+copyright header and file generation 2022-10-11 23:42:03 +02:00
azure-pipelines.yaml ci(azure-pipelines): fix image version check for build 2025-02-12 15:18:44 +01:00
build.sh chore(build): add profiling options 2023-04-19 15:57:02 +00:00
CHANGELOG.md chore(release): 27.4.59-0.0.20+145-build-system-rewrite 2025-03-19 02:19:27 +01:00
CHANGELOG.md.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
commitlint.config.js refactor(frontend): eslint 2025-01-22 10:51:33 +01:00
compose.yaml build(compose.yaml): fix backend binary path bind; add bin path to PATH 2025-03-25 16:52:32 +01:00
CONTRIBUTING chore: add DCO 2022-10-14 19:51:18 +02:00
CONTRIBUTING.license chore: add DCO 2022-10-14 19:51:18 +02:00
Datenschutznotizen.txt Datenschutznotizen & Load -> Rational 2018-03-21 09:59:18 +01:00
Datenschutznotizen.txt.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
db.sh build(backend): remove deprecated code 2024-10-01 09:57:24 +02:00
default.nix chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
enter build(Makefile): fix shell; introduce enter for launching shells in running containers 2024-11-04 15:57:14 +01:00
flake.lock chore: add Makefile, update flake.nix and shell.nix for dependencies 2024-01-21 17:03:16 +01:00
flake.lock.license chore(package.json): reintroduce is-clean check before release 2023-07-14 22:44:52 +00:00
flake.nix chore: add Makefile, update flake.nix and shell.nix for dependencies 2024-01-21 17:03:16 +01:00
ghci.sh chore: fix executables 2022-10-12 09:43:42 +02:00
haddock.sh chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
hlint.sh chore: fix executables 2022-10-12 09:43:42 +02:00
load.sh chore: fix executables 2022-10-12 09:43:42 +02:00
Makefile build(Makefile): add list-projects target 2025-03-27 11:35:01 +01: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 chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
new-file.sh chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
new-file.sh.license chore: add scripts for license+copyright header and file generation 2022-10-11 23:42:03 +02:00
nixpkgs.nix chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
package-lock.json build: start to rewrite containerized-Makefile logic for docker-compose; restructure frontend build 2025-03-23 01:44:38 +01:00
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 chore: remove deprecated config and tests 2024-09-17 01:01:41 +02:00
records.json.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02:00
release.sh chore(npm): use release script for determining version tag prefix 2023-07-16 14:51:19 +00:00
shell.nix Merge branch '145-build-system-rewrite' 2025-02-28 15:37:36 +01:00
test.sh chore: fix executables 2022-10-12 09:43:42 +02:00
TODO.md chore(lms): work on lms send notifications, work-in-progress 2022-04-14 18:13:35 +02:00
TODO.md.license chore: conform to REUSE specification 2022-10-12 09:35:16 +02: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.