Skip to main content

A CLI for converting graded Moodle quiz HTMLs to a vik.wiki quiz wikitext

Project description

🎓 moodle-to-vikwikiquiz

Lines of code Build status Code quality Type hinting used Code style: Black

Recent activity Commits since latest release PRs welcome

📖 About

A CLI for converting graded and downloaded Moodle quizzes to a vik.viki quiz wikitext.

📥 Installation

🌍 Global

  1. Install uv

  2. If using Linux: follow these steps.

  3. Run the following command in the terminal:

    uv tool install moodle-to-vikwikiquiz
    

🏠 Local

🛠️ Executable zipapp

  1. Download the .pyz file of the latest release from here.

  2. Run the following commands in the terminal:

    chmod +x moodle-to-vikwikiquiz_x.x.x.pyz
    ./moodle-to-vikwikiquiz_x.x.x.pyz [parameters]
    

🧑‍💻 Usage

moodle-to-vikwikiquiz [--verbose|-v] [--new|-n] [--recursive|-r] source_path

Parameters:

  • --new: Create a new quiz on vik.wiki by automatically opening an edit page for the new article.
  • --recursive: Import HTML files from the current directory recursively.
  • source_path: The absolute or relative path of the file or directory where the Moodle quiz HTML files are located. These HTML files should contain the Review page of the quizzes.

Always check and correct the output before submitting it to the wiki! This includes uploading all images and adding their filenames to the quiz manually.

📋 Features

  • Imports multiple HTML files at once (recursively, if desired)
  • Supports true or false, single and multiple choice questions
  • Opens an existing article or creates a new one on vik.wiki with the edit summary pre-filled
  • Formats LaTeX equations as wikitext
  • Adds the only remaining correct answer automatically if it can be determined from the grade
  • Asks for correct answers if it can't be determined from a graded question
  • Deduplicates questions with the same text
  • Prepares illustrations for batch upload
    • If they are unavailable: creates placeholders for them
  • Copies the generated wikitext to the clipboard

🏫 Compatibility

file format tested can it be imported?
.html
.webarchive yes, except illustrations
.mhtml maybe
all others maybe
Moodle instance tested can it import a quiz from there?
BME VIK
BME VIK HIT
BME GTK
Moodle language is it understood by the app?
Hungarian
English
German

⏫ Updating

Run the following command in the terminal:

uv tool upgrade --all

If you want this to run automatically, create a cron job:

  1. Open the crontab file:

    crontab -e
    
  2. Add this line to the beginning of the file:

    PATH=~/.local/bin
    

    If there is already a line beginning with PATH=, add :~/.local/bin to the end of it.

  3. Add the following line to the end of the file:

    @daily		uv tool upgrade --all
    

    You may replace @daily with @weekly or @monthly.

🧑‍💻 Development

⌨️ Developing

  1. Create a venv:
    uv venv
    
  2. Activate the venv in your IDE
  3. Install the dependencies:
    uv sync --extra dev
    

📤 Release

🛠️ Setup

  1. Install vermin:
    uv tool install vermin
    
  2. Check the minimum Python version:
    vermin --backport argparse --backport enum --backport typing_extensions --eval-annotations .
    
  3. If the result is higher than the one in pyproject.toml, update it.
  4. Bump the version number:
    uv version --bump [major|minor|patch]
    
  5. Commit and push the changes

🏗️ Building

To build a repruducible zipapp (.pyz):

  1. Install shiv:
    uv tool install shiv
    
  2. Create the executable:
    shiv --entry-point moodle_to_vikwikiquiz.main:main --output-file moodle-to-vikwikiquiz.pyz --reproducible .
    
  3. Optional: compare its hash with the one of the latest release.

📜 License

This project is licensed under the GNU General Public License v3.0. See the license file (or the GPL-3.0 license tab on GitHub) for its full text.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

moodle_to_vikwikiquiz-2.1.0.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

moodle_to_vikwikiquiz-2.1.0-py3-none-any.whl (20.5 kB view details)

Uploaded Python 3

File details

Details for the file moodle_to_vikwikiquiz-2.1.0.tar.gz.

File metadata

File hashes

Hashes for moodle_to_vikwikiquiz-2.1.0.tar.gz
Algorithm Hash digest
SHA256 a752ebec2e22201d429f058e2d732adf4c8ee02bd2cd17dac07017584fe009e2
MD5 734a09ae6fdc45a3687916e805bdd55e
BLAKE2b-256 a5da9a8733bfd5d6b70ac03c33eff375bd2ab551aafc8fe9f14e23e5dd3e6bef

See more details on using hashes here.

File details

Details for the file moodle_to_vikwikiquiz-2.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for moodle_to_vikwikiquiz-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 22e4bf5153a06f65302eae723c32dc7ada34b81c4f1794e6e6da3c48ebd2db07
MD5 4399260fdf325d022718faf9fcf44a39
BLAKE2b-256 1c9dc4a386e450361ecbe5984f9b5a011f84232a37802c7d5ec11897b7478f70

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page