EvaP
Project description
EvaP - Evaluation Platform
What is EvaP?
EvaP is the course evaluation system used internally at Hasso Plattner Institute at the University of Potsdam.
For the documentation, please see our wiki.
Development Setup
We use nix to manage the development environment.
- Windows only: Install the Windows Subsystem for Linux (WSL) using
wsl --install -d Ubuntu-24.04(you may have to restart your computer and run this command again). Enter the WSL environment using thewslcommand. On your first entry, you need to choose a username and password - anything works (for example: username "evap", password "evap"). Perform the next step outside of/mnt, for example by going to your home directory (cd ~). - Install git. Run the following commands to clone and enter the EvaP repository:
git clone --recurse-submodules https://github.com/e-valuation/EvaP.git cd EvaP - On Linux and WSL, install nix by running
./nix/setup-nix. On MacOS, install nix using the Determinate Nix Installer. Afterwards, if you get a permission error when running nix, restart your computer. - Start the needed background services for EvaP:
nix run .#services-full - Open a new terminal. Enter the development shell and start EvaP:
cd EvaP nix develop ./manage.py run - Open your web browser at http://localhost:8000/ and login with email
evap@institution.example.comand passwordevap.
To stop EvaP or the background services, press Ctrl-C.
To exit the development shell, press Ctrl-D or type exit.
Inside the development shell, after quitting the background services, you can run the command clean-setup to remove persistent state (database, node modules, localsettings).
Afterwards, nix run .#services-full will recreate a default development environment on startup.
Contributing
We'd love to see contributions! PRs solving existing issues are most helpful to us. It's best if you ask to be assigned for the issue so we won't have multiple people working on the same issue. Feel free to open issues for bugs, setup problems, or feature requests. If you have other questions, feel free to contact the organization members. You should probably branch off main, the branch release is used for stable revisions.
Before committing, run the following commands:
./manage.py test(runs the test suite)./manage.py lint(runs linting)./manage.py format(applies automatic code formatting)
or, to combine all three, simply run ./manage.py precommit.
You can also set up pylint, isort, black and prettier in your IDE to avoid doing this manually all the time.
Creating a Pull Request (Workflow Suggestion)
-
(once) Fork the repository so you have a GitHub repo that you have write access to.
-
(once) Set up some authentication for GitHub that allows push access. A common option is using SSH keys, the remaining instructions assume an SSH key setup. An alternative is using the GitHub CLI tool.
-
(once) Ensure your git remotes are setup to use SSH. To fetch the up-to-date state of the official repo, it's useful to have an "upstream" remote configured:
git remote set-url origin git@github.com:<your-username>/EvaP.git git remote add upstream git@github.com:e-valuation/EvaP.git
-
Create a branch (
git switch -c <your-branch-name>), commit your changes (git addandgit commit), and push them (git push). "Push" will ask you to specify an upstream branch (git push -u origin <your-branch-name>). -
GitHub should now ask you whether you want to open a pull request ("PR"). If the PR solves an issue, use one of GitHub's magic keywords (like "fixes") in the pull request description to create a link between your PR and the issue. If necessary, please also provide a short summary of your changes in the description.
License
MIT, see LICENSE.md.
Supported Browsers
The platform is only tested in Mozilla Firefox and Google Chrome. Other browsers might not render all pages correctly.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file evap-2026.1.2.tar.gz.
File metadata
- Download URL: evap-2026.1.2.tar.gz
- Upload date:
- Size: 1.7 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ca2a7eeda93ddf09d009e64caa05ef05ef10d90f198a47337a0e8ac139f28511
|
|
| MD5 |
74b49858388dc8fd866bd6323e38f6a9
|
|
| BLAKE2b-256 |
62bed2a79b30507b42fd3fb304bfb17498cd4ce8eb798467c8b69bf7ac8fe100
|
Provenance
The following attestation bundles were made for evap-2026.1.2.tar.gz:
Publisher:
release.yml on e-valuation/EvaP
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
evap-2026.1.2.tar.gz -
Subject digest:
ca2a7eeda93ddf09d009e64caa05ef05ef10d90f198a47337a0e8ac139f28511 - Sigstore transparency entry: 869964392
- Sigstore integration time:
-
Permalink:
e-valuation/EvaP@f80789492d54122f552cee27c2ebe41dcc60b06b -
Branch / Tag:
refs/tags/2026.1.2 - Owner: https://github.com/e-valuation
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@f80789492d54122f552cee27c2ebe41dcc60b06b -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file evap-2026.1.2-py3-none-any.whl.
File metadata
- Download URL: evap-2026.1.2-py3-none-any.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9ea3788d28435bf6c7f2f97bff272b34dca3d4d3c62f95dcad2094d056485433
|
|
| MD5 |
0cb1efefc01a6fa92eec611d60cbeea7
|
|
| BLAKE2b-256 |
e16cd6ecd50bbefe433bc69282eeb1832a55fd39d5bb35d3a795ee217162db73
|
Provenance
The following attestation bundles were made for evap-2026.1.2-py3-none-any.whl:
Publisher:
release.yml on e-valuation/EvaP
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
evap-2026.1.2-py3-none-any.whl -
Subject digest:
9ea3788d28435bf6c7f2f97bff272b34dca3d4d3c62f95dcad2094d056485433 - Sigstore transparency entry: 869964395
- Sigstore integration time:
-
Permalink:
e-valuation/EvaP@f80789492d54122f552cee27c2ebe41dcc60b06b -
Branch / Tag:
refs/tags/2026.1.2 - Owner: https://github.com/e-valuation
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@f80789492d54122f552cee27c2ebe41dcc60b06b -
Trigger Event:
workflow_dispatch
-
Statement type: