vEnhance / otis-web

OTIS course management system
https://web.evanchen.cc/otis.html
MIT License
40 stars 74 forks source link
course-management-system django python3

Top languages MIT License Last update

Forks Stars

OTIS-WEB status OTIS-WEB status

djlint style: black types: pyright lint: ruff Coverage status

OTIS-WEB

These are the source files for the internal website that I use to teach my course OTIS. It is pretty standard Django, so you should be able to spin up a local server on a standard Unix environment.

Installation instructions

Video tutorial: https://youtu.be/W27XcqeXp20

Standard Linux environment

If you're just trying to get a local copy of the OTIS-WEB code and don't plan to submit any code back, then skip steps 0 and 4, and replace YOUR_USERNAME in step 2 with vEnhance.

  1. Create an account on GitHub if you haven't already, and fork the repository.

  2. Install the following standard tools: python (version 3.10), pip, git. (For each tool, search "[name of thing to install] [your OS]" on the web.)

  3. Clone this repository using the command git clone https://github.com/YOUR_USERNAME/otis-web.

  4. Run git submodule update --init --recursive in order to pull the evans_django_tools submodule.

  5. Type git checkout -b feature to checkout a new branch named feature; this will make your life a bit easier than working on main. If you already know what feature you're trying to implement, you can use that, e.g. git checkout -b add-bunny-pictures.

  6. Install Poetry. This enables you to use the poetry command; verify this by checking poetry --help produces a help message.

  7. Once you have poetry, hit poetry install. This will automatically create a Python virtual environment and install stuff inside it. (If you are an expert familiar with Python virtual environments and want to use your own rather than Poetry's auto-created one, then activate said environment before running poetry install.)

    On some systems, poetry install could fail when trying to install mysqlclient. You will have to separately install pkg-config mysql in that case; see that link for instructions, under the "Install" section.

  8. If it isn't already activated, activate the Python virtual environment that was created in the previous step. The easiest way to do so is to run poetry shell.

    (Note: you have to do this step every time you start working on the project. That is, always run poetry shell before doing any work, or for experts, activate the virtual environment using your preferred method.)

  9. If everything is working, python manage.py check should run with no errors.

  10. Run python manage.py migrate to create the local database.

  11. Run python manage.py createsuperuser to create an admin user.

  12. Run python manage.py runserver. The command will spin up a continuously running server.

  13. Point your browser to http://127.0.0.1:8000. You should be able to log in with the user you defined in step 9.

  14. The website is functional now, but it is a bit bare-bones. To populate it with some test data, use http://127.0.0.1:8000/admin or run ./fixtures/load-all.sh.

    • To log in with the dummy accounts in the fixtures, it's easiest to log in with the superuser account and then use the hijack feature.

Optional steps:

Using Docker

  1. Follow steps 0 - 3 from the above tutorial.
  2. Make sure to install Docker and make sure you download a version compatible with your computer.
  3. Set up the 3 environment variables at the bottom of env by copying them to .env and uncommenting them. Note that you should not have any spaces (it is fine to leave the values as it is, but if you want to change anything, just make sure there is no whitespace surrounding the =).
  4. Run docker compose build. Wait for it to finish.
  5. To start the server, run docker compose up -d. To execute a command inside the container, run docker exec -it otis-web /bin/bash. To stop the server, run docker compose down.
  6. Follow steps 11 - 12 from above.

Note: You may need to delete db.sqlite3 if you're not getting desired results, as it serves as a cache. At this point, spinning up 2 separate containers with separate data stores is not supported.

Feature requests or bug reports

Submit an issue on GitHub.

Pull requests

For OTIS students: pull requests welcome! If you think the website can be improved in some way, feel free to implement it. See contributing guidelines. It's OK if you don't have much code experience; I'm willing to guide you along.

526561645265616452656164