90 lines
2.9 KiB
PHP
90 lines
2.9 KiB
PHP
|
<?php
|
||
|
namespace local_treestudyplan;
|
||
|
|
||
|
class teachingfinder {
|
||
|
const TABLE = "local_treestudyplan_teachers";
|
||
|
|
||
|
|
||
|
public static function list_my_plans(){
|
||
|
global $USER,$DB;
|
||
|
$userid = $USER->id;
|
||
|
|
||
|
$records = $DB->get_records(self::TABLE,['teacher_id' => $userid]);
|
||
|
if(count($records) == 0){
|
||
|
// initiate a search if the cache is empty
|
||
|
self::update_teaching_cache($userid);
|
||
|
$DB->get_records(self::TABLE,['teacher_id' => $userid]);
|
||
|
}
|
||
|
$list = [];
|
||
|
foreach($records as $r){
|
||
|
$list[] = studyplan::findById($r->studyplan_id);
|
||
|
}
|
||
|
return $list;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Find The active studyplans where the specified user is a teacher
|
||
|
* (Has the mod/assign::grade capability in one of the linked courses)
|
||
|
* TODO: OPTIMIZE THIS CHECK!!!
|
||
|
*/
|
||
|
public static function update_teaching_cache($userid){
|
||
|
global $DB;
|
||
|
$list = [];
|
||
|
|
||
|
// First find all active study plans
|
||
|
|
||
|
$sql = "SELECT s.id FROM {local_treestudyplan} s
|
||
|
WHERE startdate <= NOW() and enddate >= NOW()";
|
||
|
$plan_ids = $DB->get_fieldset_sql($sql, []);
|
||
|
|
||
|
// then parse them to see if the user has the grading permission in any of them
|
||
|
// (Which would make them a teacher for all intents and purposes)
|
||
|
|
||
|
foreach($plan_ids as $planid) {
|
||
|
$sql = "SELECT i.course_id FROM mdl_local_treestudyplan_item i
|
||
|
INNER JOIN mdl_local_treestudyplan_line l ON i.line_id = l.id
|
||
|
WHERE l.studyplan_id = :plan_id AND i.course_id IS NOT NULL";
|
||
|
$course_ids = $DB->get_fieldset_sql($sql, ["plan_id" => $planid]);
|
||
|
|
||
|
$linked = false;
|
||
|
foreach($course_ids as $cid){
|
||
|
$coursecontext = \context_course::instance($cid);
|
||
|
if (is_enrolled($coursecontext, $userid, 'mod/assign:grade')){
|
||
|
$linked = true;
|
||
|
break; // No need to search further
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if($linked)
|
||
|
{
|
||
|
$list[] = $planid;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// Now, clear the database of all records for this user
|
||
|
$DB->delete_records(self::TABLE,["teacher_id"=>$userid]);
|
||
|
// And add new records for the found studyplans
|
||
|
$now = time();
|
||
|
foreach($list as $planid){
|
||
|
$DB->insert_record(self::TABLE,["teacher_id"=>$userid,"studyplan_id"=>$planid,"update_time"=>$now]);
|
||
|
}
|
||
|
|
||
|
return $list;
|
||
|
}
|
||
|
|
||
|
public static function list_teacher_ids(){
|
||
|
global $DB;
|
||
|
return $DB->get_fieldset_sql("SELECT DISTINCT teacher_id FROM {".self::TABLE."}");
|
||
|
}
|
||
|
|
||
|
public static function get_update_time($teacher_id): int {
|
||
|
global $DB;
|
||
|
$r = $DB->get_field_sql("SELECT MIN(update_time)FROM {".self::TABLE."} WHERE teacher_id=:teacher_id",
|
||
|
["teacher_id" => $teacher_id]);
|
||
|
return (int)($r->update_time);
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|