2 // This file is part of Moodle - http://moodle.org/
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
18 * Library of functions and constants for module attendance
20 * @package mod_attendance
21 * @copyright 2011 Artem Andreev <andreev.artem@gmail.com>
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 defined('MOODLE_INTERNAL') ||
die();
26 require_once(dirname(__FILE__
) . '/classes/calendar_helpers.php');
29 * Returns the information if the module supports a feature
31 * @see plugin_supports() in lib/moodlelib.php
32 * @param string $feature FEATURE_xx constant for requested feature
33 * @return mixed true if the feature is supported, null if unknown
35 function attendance_supports($feature) {
37 case FEATURE_GRADE_HAS_GRADE
:
41 case FEATURE_GROUPINGS
:
43 case FEATURE_MOD_INTRO
:
45 case FEATURE_BACKUP_MOODLE2
:
47 // Artem Andreev: AFAIK it's not tested.
48 case FEATURE_COMPLETION_TRACKS_VIEWS
:
56 * Add default set of statuses to the new attendance.
58 * @param int $attid - id of attendance instance.
60 function att_add_default_statuses($attid) {
63 $statuses = $DB->get_recordset('attendance_statuses', array('attendanceid' => 0), 'id');
64 foreach ($statuses as $st) {
66 $rec->attendanceid
= $attid;
67 $DB->insert_record('attendance_statuses', $rec);
73 * Add default set of warnings to the new attendance.
75 * @param int $id - id of attendance instance.
77 function attendance_add_default_warnings($id) {
79 require_once($CFG->dirroot
.'/mod/attendance/locallib.php');
81 $warnings = $DB->get_recordset('attendance_warning',
82 array('idnumber' => 0), 'id');
83 foreach ($warnings as $n) {
86 $DB->insert_record('attendance_warning', $rec);
92 * Add new attendance instance.
94 * @param stdClass $attendance
97 function attendance_add_instance($attendance) {
100 $attendance->timemodified
= time();
102 $attendance->id
= $DB->insert_record('attendance', $attendance);
104 att_add_default_statuses($attendance->id
);
106 attendance_add_default_warnings($attendance->id
);
108 attendance_grade_item_update($attendance);
110 return $attendance->id
;
114 * Update existing attendance instance.
116 * @param stdClass $attendance
119 function attendance_update_instance($attendance) {
122 $attendance->timemodified
= time();
123 $attendance->id
= $attendance->instance
;
125 if (! $DB->update_record('attendance', $attendance)) {
129 attendance_grade_item_update($attendance);
135 * Delete existing attendance
140 function attendance_delete_instance($id) {
142 require_once($CFG->dirroot
.'/mod/attendance/locallib.php');
144 if (! $attendance = $DB->get_record('attendance', array('id' => $id))) {
148 if ($sessids = array_keys($DB->get_records('attendance_sessions', array('attendanceid' => $id), '', 'id'))) {
149 if (attendance_existing_calendar_events_ids($sessids)) {
150 attendance_delete_calendar_events($sessids);
152 $DB->delete_records_list('attendance_log', 'sessionid', $sessids);
153 $DB->delete_records('attendance_sessions', array('attendanceid' => $id));
155 $DB->delete_records('attendance_statuses', array('attendanceid' => $id));
157 $DB->delete_records('attendance_warning', array('idnumber' => $id));
159 $DB->delete_records('attendance', array('id' => $id));
161 attendance_grade_item_delete($attendance);
167 * Called by course/reset.php
168 * @param moodleform $mform form passed by reference
170 function attendance_reset_course_form_definition(&$mform) {
171 $mform->addElement('header', 'attendanceheader', get_string('modulename', 'attendance'));
173 $mform->addElement('static', 'description', get_string('description', 'attendance'),
174 get_string('resetdescription', 'attendance'));
175 $mform->addElement('checkbox', 'reset_attendance_log', get_string('deletelogs', 'attendance'));
177 $mform->addElement('checkbox', 'reset_attendance_sessions', get_string('deletesessions', 'attendance'));
178 $mform->disabledIf('reset_attendance_sessions', 'reset_attendance_log', 'notchecked');
180 $mform->addElement('checkbox', 'reset_attendance_statuses', get_string('resetstatuses', 'attendance'));
181 $mform->setAdvanced('reset_attendance_statuses');
182 $mform->disabledIf('reset_attendance_statuses', 'reset_attendance_log', 'notchecked');
186 * Course reset form defaults.
188 * @param stdClass $course
191 function attendance_reset_course_form_defaults($course) {
192 return array('reset_attendance_log' => 0, 'reset_attendance_statuses' => 0, 'reset_attendance_sessions' => 0);
196 * Reset user data within attendance.
198 * @param stdClass $data
201 function attendance_reset_userdata($data) {
206 $attids = array_keys($DB->get_records('attendance', array('course' => $data->courseid
), '', 'id'));
208 if (!empty($data->reset_attendance_log
)) {
209 $sess = $DB->get_records_list('attendance_sessions', 'attendanceid', $attids, '', 'id');
211 list($sql, $params) = $DB->get_in_or_equal(array_keys($sess));
212 $DB->delete_records_select('attendance_log', "sessionid $sql", $params);
213 list($sql, $params) = $DB->get_in_or_equal($attids);
214 $DB->set_field_select('attendance_sessions', 'lasttaken', 0, "attendanceid $sql", $params);
215 if (empty($data->reset_attendance_sessions
)) {
216 // If sessions are being retained, clear automarkcompleted value.
217 $DB->set_field_select('attendance_sessions', 'automarkcompleted', 0, "attendanceid $sql", $params);
221 'component' => get_string('modulenameplural', 'attendance'),
222 'item' => get_string('attendancedata', 'attendance'),
228 if (!empty($data->reset_attendance_statuses
)) {
229 $DB->delete_records_list('attendance_statuses', 'attendanceid', $attids);
230 foreach ($attids as $attid) {
231 att_add_default_statuses($attid);
235 'component' => get_string('modulenameplural', 'attendance'),
236 'item' => get_string('sessions', 'attendance'),
241 if (!empty($data->reset_attendance_sessions
)) {
242 $sessionsids = array_keys($DB->get_records_list('attendance_sessions', 'attendanceid', $attids, '', 'id'));
243 if (attendance_existing_calendar_events_ids($sessionsids)) {
244 attendance_delete_calendar_events($sessionsids);
246 $DB->delete_records_list('attendance_sessions', 'attendanceid', $attids);
249 'component' => get_string('modulenameplural', 'attendance'),
250 'item' => get_string('statuses', 'attendance'),
258 * Return a small object with summary information about what a
259 * user has done with a given particular instance of this module
260 * Used for user activity reports.
261 * $return->time = the time they did it
262 * $return->info = a short text description
264 * @param stdClass $course - full course record.
265 * @param stdClass $user - full user record
266 * @param stdClass $mod
267 * @param stdClass $attendance
270 function attendance_user_outline($course, $user, $mod, $attendance) {
272 require_once(dirname(__FILE__
).'/locallib.php');
273 require_once($CFG->libdir
.'/gradelib.php');
275 $grades = grade_get_grades($course->id
, 'mod', 'attendance', $attendance->id
, $user->id
);
277 $result = new stdClass();
278 if (!empty($grades->items
[0]->grades
)) {
279 $grade = reset($grades->items
[0]->grades
);
280 $result->time
= $grade->dategraded
;
284 if (has_capability('mod/attendance:canbelisted', $mod->context
, $user->id
)) {
285 $summary = new mod_attendance_summary($attendance->id
, $user->id
);
286 $usersummary = $summary->get_all_sessions_summary_for($user->id
);
288 $result->info
= format_float($usersummary->takensessionspoints
, 1, true
, true
) . ' / ' .
289 format_float($usersummary->allsessionsmaxpoints
, 1, true
, true
);
295 * Print a detailed representation of what a user has done with
296 * a given particular instance of this module, for user activity reports.
298 * @param stdClass $course
299 * @param stdClass $user
300 * @param stdClass $mod
301 * @param stdClass $attendance
303 function attendance_user_complete($course, $user, $mod, $attendance) {
306 require_once(dirname(__FILE__
).'/renderhelpers.php');
307 require_once($CFG->libdir
.'/gradelib.php');
309 if (has_capability('mod/attendance:canbelisted', $mod->context
, $user->id
)) {
310 echo construct_full_user_stat_html_table($attendance, $user);
315 * Dummy function - must exist to allow quick editing of module name.
317 * @param stdClass $attendance
319 * @param bool $nullifnone
321 function attendance_update_grades($attendance, $userid=0, $nullifnone=true
) {
322 // We need this function to exist so that quick editing of module name is passed to gradebook.
325 * Create grade item for given attendance
327 * @param stdClass $attendance object with extra cmidnumber
328 * @param mixed $grades optional array/object of grade(s); 'reset' means reset grades in gradebook
329 * @return int 0 if ok, error code otherwise
331 function attendance_grade_item_update($attendance, $grades=null
) {
334 require_once('locallib.php');
336 if (!function_exists('grade_update')) { // Workaround for buggy PHP versions.
337 require_once($CFG->libdir
.'/gradelib.php');
340 if (!isset($attendance->courseid
)) {
341 $attendance->courseid
= $attendance->course
;
343 if (!$DB->get_record('course', array('id' => $attendance->course
))) {
344 error("Course is misconfigured");
347 if (!empty($attendance->cmidnumber
)) {
348 $params = array('itemname' => $attendance->name
, 'idnumber' => $attendance->cmidnumber
);
351 $params = array('itemname' => $attendance->name
);
354 if ($attendance->grade
> 0) {
355 $params['gradetype'] = GRADE_TYPE_VALUE
;
356 $params['grademax'] = $attendance->grade
;
357 $params['grademin'] = 0;
358 } else if ($attendance->grade
< 0) {
359 $params['gradetype'] = GRADE_TYPE_SCALE
;
360 $params['scaleid'] = -$attendance->grade
;
363 $params['gradetype'] = GRADE_TYPE_NONE
;
366 if ($grades === 'reset') {
367 $params['reset'] = true
;
371 return grade_update('mod/attendance', $attendance->courseid
, 'mod', 'attendance', $attendance->id
, 0, $grades, $params);
375 * Delete grade item for given attendance
377 * @param object $attendance object
378 * @return object attendance
380 function attendance_grade_item_delete($attendance) {
382 require_once($CFG->libdir
.'/gradelib.php');
384 if (!isset($attendance->courseid
)) {
385 $attendance->courseid
= $attendance->course
;
388 return grade_update('mod/attendance', $attendance->courseid
, 'mod', 'attendance',
389 $attendance->id
, 0, null
, array('deleted' => 1));
393 * This function returns if a scale is being used by one attendance
394 * it it has support for grading and scales. Commented code should be
395 * modified if necessary. See book, glossary or journal modules
398 * @param int $attendanceid
399 * @param int $scaleid
400 * @return boolean True if the scale is used by any attendance
402 function attendance_scale_used ($attendanceid, $scaleid) {
407 * Checks if scale is being used by any instance of attendance
409 * This is used to find out if scale used anywhere
411 * @param int $scaleid
412 * @return bool true if the scale is used by any book
414 function attendance_scale_used_anywhere($scaleid) {
419 * Serves the attendance sessions descriptions files.
421 * @param object $course
423 * @param object $context
424 * @param string $filearea
426 * @param bool $forcedownload
427 * @return bool false if file not found, does not return if found - justsend the file
429 function attendance_pluginfile($course, $cm, $context, $filearea, $args, $forcedownload) {
432 if ($context->contextlevel
!= CONTEXT_MODULE
) {
436 require_login($course, false
, $cm);
438 if (!$DB->record_exists('attendance', array('id' => $cm->instance
))) {
442 // Session area is served by pluginfile.php.
443 $fileareas = array('session');
444 if (!in_array($filearea, $fileareas)) {
448 $sessid = (int)array_shift($args);
449 if (!$DB->record_exists('attendance_sessions', array('id' => $sessid))) {
453 $fs = get_file_storage();
454 $relativepath = implode('/', $args);
455 $fullpath = "/$context->id/mod_attendance/$filearea/$sessid/$relativepath";
456 if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->is_directory()) {
459 send_stored_file($file, 0, 0, true
);
463 * Print tabs on attendance settings page.
465 * @param string $selected - current selected tab.
467 function attendance_print_settings_tabs($selected = 'settings') {
469 // Print tabs for different settings pages.
471 $tabs[] = new tabobject('settings', $CFG->wwwroot
.'/admin/settings.php?section=modsettingattendance',
472 get_string('settings', 'attendance'), get_string('settings'), false
);
474 $tabs[] = new tabobject('defaultstatus', $CFG->wwwroot
.'/mod/attendance/defaultstatus.php',
475 get_string('defaultstatus', 'attendance'), get_string('defaultstatus', 'attendance'), false
);
477 if (get_config('attendance', 'enablewarnings')) {
478 $tabs[] = new tabobject('defaultwarnings', $CFG->wwwroot
. '/mod/attendance/warnings.php',
479 get_string('defaultwarnings', 'attendance'), get_string('defaultwarnings', 'attendance'), false
);
482 $tabs[] = new tabobject('coursesummary', $CFG->wwwroot
.'/mod/attendance/coursesummary.php',
483 get_string('coursesummary', 'attendance'), get_string('coursesummary', 'attendance'), false
);
485 if (get_config('attendance', 'enablewarnings')) {
486 $tabs[] = new tabobject('absentee', $CFG->wwwroot
. '/mod/attendance/absentee.php',
487 get_string('absenteereport', 'attendance'), get_string('absenteereport', 'attendance'), false
);
490 $tabs[] = new tabobject('resetcalendar', $CFG->wwwroot
.'/mod/attendance/resetcalendar.php',
491 get_string('resetcalendar', 'attendance'), get_string('resetcalendar', 'attendance'), false
);
493 $tabs[] = new tabobject('importsessions', $CFG->wwwroot
. '/mod/attendance/import/sessions.php',
494 get_string('importsessions', 'attendance'), get_string('importsessions', 'attendance'), false
);
497 print_tabs(array($tabs), $selected);
498 $tabmenu = ob_get_contents();