Old quiz and question attempts deletion

Local plugins ::: local_deleteoldquizattempts
Maintained by Vadim Dvorovenko
Deletes old quiz and question attempts by scheduler task or by CLI command.
Latest release:
273 sites
61 downloads
18 fans
Moodle 2.7, 2.8, 2.9, 3.0, 3.1, 3.2, 3.3, 3.4, 3.5, 3.6, 3.7, 3.8, 3.9, 3.10, 3.11

Installation

Copy the deleteoldquizattempts folder into your Moodle /local directory and visit your Admin Notification page to complete the installation.

Usage

Navigate to plugin settings and specify maximum lifetime of quiz attempts. Older attempts will be automatically deleted with scheduler task.

You can also specify to delete unused hidden questions. Hidden questions are questions, that were logically deleted, but were not deleted physically, because they were referenced in some quiz attempts. After quiz attempts deletion, such questions are probably no longer required.

You can also delete quiz attempts and unused hidden questions with command line job.

Deleting quiz attempts with CLI

Dispay help.

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_attempts.php --help

Delete attempts that are older than 90 days and shows progress.

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_attempts.php --days=90 --verbose

Delete attempts that are created before specified timestamp.

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_attempts.php --timestamp=1514764800 --timelimit=300

Delete attempts that are created before 2018-01-01 00:00:00 (UTC).

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_attempts.php --date="2018-01-01 00:00:00"

Delete attempts for specified quiz (check id in *_quiz table).

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_attempts.php --days=90 --quizid=99

Delete attempts for all quizzes in specified course.

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_attempts.php --days=90 --courseid=99

Deleting unused hidden questions with CLI

Dispay help.

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_unused_questions.php --help

Delete unused hidden questions.

sudo -u www-data /usr/bin/php local/deleteoldquizattempts/cli/delete_unused_questions.php --timelimit=300 --verbose

Screenshots

Screenshot #0

Contributors

Vadim Dvorovenko (Lead maintainer)
Please login to view contributors details and/or to contact them

Comments RSS

Show comments
  • Phineas Gomez
    Sat, Mar 6, 2021, 2:32 PM
    I think it would be a good update to be able to choose the deletion time for each of the courses, because in my case I have paid courses that I want to be deleted in a period of 1 year, but in the free courses I wanted to reduce it to just 1 month.

    Thanks!!
  • Vadim Dvorovenko
    Sat, Mar 6, 2021, 6:46 PM
    Phineas Gomez. CLI script has option to specify course id and other params. You can specify 1 year in settings, and create additional cron task running CLI script to cleanup for courses with 1 month period.
  • Phineas Gomez
    Sun, Mar 7, 2021, 2:01 AM
    Many thanks Vadim!


    I am using the following code but it doesn't seem to work:
    /usr/bin/php /home/xxxx/mysite.com/moodle/local/deleteoldquizattempts/cli/delete_attempts.php --days=10 --quizid=26


    However I receive this mail from cron, what can be the error?

    X-Powered-By: PHP/7.4.14
    Content-type: text/html; charset=UTF-8

    Delete old quiz and question attempts

    Options:
    --days= Delete attempts that are older than specified number of days
    --timestamp= Delete attempts that are created before specified UTC timestamp
    --date= Delete attempts that are created before specified date.
    Use "YYYY-MM-DD HH:MM:SS" format in UTC
    --courseid= Delete only attempts for quizzes in course with specified id.
    --quizid= Delete only attempts for quiz with specified id.
    --timelimit= Stop execution after specified number of seconds
    -v, --verbose Show progress
    -h, --help Print out this help

    Only one of --days, --timestamp and --date options should be specified.

    Examples:
    php local/deleteoldquizattempts/cli/delete_attempts.php --days=90 --verbose
    php local/deleteoldquizattempts/cli/delete_attempts.php --timestamp=1514764800 --timelimit=300
    php local/deleteoldquizattempts/cli/delete_attempts.php --date="2018-01-01 00:00:00"

  • Vadim Dvorovenko
    Thu, Mar 11, 2021, 1:49 AM
    i've checked, your command and it goes no errors for me.

    first, run from command line to be sure everything works
    /usr/bin/php /home/xxxx/mysite.com/moodle/local/deleteoldquizattempts/cli/delete_attempts.php --days=10 --quizid=26 --verbose

    check that you specified right quizeid by visiting mysite.com/moodle/mod/quiz/view.php?q=26 - quizid is not the same as coursemodule id. Sometimes it's better to look into DB id mdl_quiz table.

    Check your cron syntax, maybe some misprint, command must be the same, that you test in command line. Maybe your cron requires some escaping of params
    When oll is ok, you can add " >/dev/null" to the end of the command to supress output and mails from cron.
  • Phineas Gomez
    Thu, Mar 11, 2021, 8:52 PM
    Thanks Vadim.

    I have tried different configurations: the courseid, quizid option, different types of quizzes and courses ... and none of them work

    I can't use the cPanel terminal because my hosting does not give that option.

    sad
  • Dante Pereyra
    Mon, Nov 29, 2021, 10:20 PM
    Hey Vadim! This is a great idea, exactly what I need to cleanup our moodle database. Now, we have Moodle 2.5+ version and we're not able to upgrade to 2.7
    Do you think this plugin can work for this 2.5+ version?
  • Vadim Dvorovenko
    Sun, Dec 12, 2021, 1:41 AM
    Dante Pereyra, I was newer tested this plugin with 2.5, but you may try. Change 2014051200 in version.php to 2013051400 and try to install it
  • Daninet Bilbao
    Sat, Jan 1, 2022, 7:31 PM
    Dear Vadim. Your plugin just saved my life. (I mantain a single course with 4.800 users, hundreds of attempts everyday, so before I discovered your plugin I had to clean all this just by hand). Thanks A LOT!
    Just a question: is there an way to configure a shorter period than a month? (For example, automatic deletion every 15 days?). Sorry, I'm not an IT expert, I hope it is easy to configure.

    Thanks again
    Daniel
  • Vadim Dvorovenko
    Sun, Jan 2, 2022, 3:37 PM
    Daninet Bilbao, fixed in latest release
  • Daninet Bilbao
    Sun, Jan 2, 2022, 5:28 PM
    Installed! Thanks a lot!

    The (15 / 7 / 3 days) options are simply great. Thanks for your great work, Vadim.
  • Davide Rossi
    Sat, Sep 3, 2022, 5:12 PM
    Hello Vadim. Your plugin is really great and useful. With Moodle 4 it doesn't seem to work anymore. Correct?
  • Matej Konobelj
    Tue, Dec 12, 2023, 12:06 AM
    Has anybody tested on moodle 4.1?
  • avo user
    Fri, Mar 7, 2025, 7:19 PM
    I tested it with moodle 4.5.2 and it worked fine. Thank you
  • Karsinora Fenriz
    Tue, Jul 8, 2025, 6:01 PM
    Good day! Your plugin is a real find. It helped to solve many problems that were provoked by abandoned and old attempts. I wonder, why Moodle developers don't provide something like that in standart Moodle. Such a function is especially important for long functioning systems and with a large number of users.
    Taking into account my experience, I would like to suggest some additions:
    1. Ability to set a date, not a period. Periods don't provide sufficient flexibility in all cases. For example, I could delete attempts in the fall semester (before January 1, 25), but this means that the period of 180 days is too short - deletion will affect attempts for January, February, and 1 year is too much - the process will not even reach attempts of the fall semester.
    2. Ability to configure completion of abandoned attempts independently of deletion process, so that attempts older than, for example, 2 months can be automatically completed so that they do not "hang" waiting for the deletion process, which may reach them much later.
  • Vadim Dvorovenko
    Mon, Jul 14, 2025, 1:51 PM
    Karsinora Fenriz
    1. If you want to specify dates instead of days, you can set Do not delete old-attempts in interface and use command line interface to specify date.
    2. This plugin deletes attempts based on time when atempt was started, so abandoned attempts will not hang longer then completed attempt. This plugin is only for deletion. If you wand abandoned quiz to complete, use core quiz settings and setup timing https://docs.moodle.org/500/en/Quiz_settings#Timing
1 2
Please login to post comments