256bda9ec9058af5a325164fab4566b465ca67f0
[moodle.git] / mod / assignment / db / upgrade.php
1 <?php
3 // This file keeps track of upgrades to
4 // the assignment module
5 //
6 // Sometimes, changes between versions involve
7 // alterations to database structures and other
8 // major things that may break installations.
9 //
10 // The upgrade function in this file will attempt
11 // to perform all the necessary actions to upgrade
12 // your older installation to the current version.
13 //
14 // If there's something it cannot do itself, it
15 // will tell you what you need to do.
16 //
17 // The commands in here will all be database-neutral,
18 // using the methods of database_manager class
19 //
20 // Please do not forget to use upgrade_set_timeout()
21 // before any action that may take longer time to finish.
23 function xmldb_assignment_upgrade($oldversion) {
24     global $CFG, $DB, $OUTPUT;
26     $dbman = $DB->get_manager();
29     // Moodle v2.2.0 release upgrade line
30     // Put any upgrade step following this
32     // Moodle v2.3.0 release upgrade line
33     // Put any upgrade step following this
35     if ($oldversion < 2012062800) {
36         // Fixed/updated numfiles field in assignment_submissions table to count the actual
37         // number of files has been uploaded.
38         upgrade_set_timeout(600);  // increase excution time for in large sites
39         $fs = get_file_storage();
41         $selectcount = 'SELECT COUNT(s.id), cm.id AS cmid';
42         $select      = 'SELECT s.id, cm.id AS cmid';
43         $query       = "  FROM {assignment_submissions} s
44                     INNER JOIN {course_modules} cm
45                             ON s.assignment = cm.instance
46                           JOIN {assignment} a
47                             ON a.id = s.assignment
48                          WHERE a.assignmenttype in ('upload', 'uploadsingle') AND
49                                cm.module = (SELECT id
50                                               FROM {modules}
51                                              WHERE name = 'assignment')";
53         $countsubmissions = $DB->count_records_sql($selectcount. $query);
54         $submissions = $DB->get_recordset_sql($select. $query);
56         $pbar = new progress_bar('assignmentupgradenumfiles', 500, true);
57         $i = 0;
58         foreach ($submissions as $sub) {
59             $i++;
60             if ($context = context_module::instance($sub->cmid)) {
61                 $sub->numfiles = count($fs->get_area_files($context->id, 'mod_assignment', 'submission', $sub->id, 'sortorder', false));
62                 $DB->update_record('assignment_submissions', $sub);
63             }
64             $pbar->update($i, $countsubmissions, "Counting files of submissions ($i/$countsubmissions)");
65         }
66         $submissions->close();
68         // assignment savepoint reached
69         upgrade_mod_savepoint(true, 2012062800, 'assignment');
70     }
72     return true;
73 }