702 lines
23 KiB
PHP
702 lines
23 KiB
PHP
<?php
|
|
// This file is part of the Studyplan plugin for Moodle
|
|
//
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Moodle. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
/**
|
|
* Webservice class for retrieving student studyplans
|
|
* @package local_treestudyplan
|
|
* @copyright 2023 P.M. Kuipers
|
|
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
namespace local_treestudyplan;
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
require_once($CFG->libdir.'/externallib.php');
|
|
|
|
use local_treestudyplan\local\helpers\webservicehelper;
|
|
use local_treestudyplan\task\autocohortsync;
|
|
|
|
require_once($CFG->libdir.'/badgeslib.php');
|
|
/**
|
|
* Webservice class for retrieving student studyplans
|
|
*/
|
|
class studentstudyplanservice extends \external_api {
|
|
/**
|
|
* Capability required to view studyplans of other users
|
|
* @var string
|
|
*/
|
|
const CAP_VIEWOTHER = "local/treestudyplan:viewuserreports";
|
|
/**
|
|
* Capability required to be linked as coach to a studyplan
|
|
* @var string
|
|
*/
|
|
const CAP_COACH = "local/treestudyplan:coach";
|
|
/************************
|
|
* *
|
|
* list_user_studyplans *
|
|
* *
|
|
************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function list_user_studyplans
|
|
*/
|
|
public static function list_user_studyplans_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters([
|
|
"userid" => new \external_value(PARAM_INT, 'id of student', VALUE_DEFAULT),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function list_user_studyplans
|
|
*/
|
|
public static function list_user_studyplans_returns(): \external_description {
|
|
return new \external_multiple_structure(
|
|
studyplan::simple_structure()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Return overview of the studyplans for a specific user
|
|
* @param int $userid ID of user to check specific info for
|
|
* @return array
|
|
*/
|
|
public static function list_user_studyplans($userid) {
|
|
global $CFG, $DB;
|
|
|
|
$list = [];
|
|
$studyplans = studyplan::find_for_user($userid);
|
|
foreach ($studyplans as $studyplan) {
|
|
// Only include studyplans in the context the user has permissions for.
|
|
if (webservicehelper::has_capabilities(self::CAP_VIEWOTHER, $studyplan->context(), false)) {
|
|
$list[] = $studyplan->simple_model($userid);
|
|
}
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/************************
|
|
* *
|
|
* get_user_studyplan *
|
|
* *
|
|
************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_user_studyplan
|
|
*/
|
|
public static function get_user_studyplan_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"userid" => new \external_value(PARAM_INT, 'id of user'),
|
|
"studyplanid" => new \external_value(PARAM_INT, 'id of specific studyplan to provide'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_user_studyplan
|
|
*/
|
|
public static function get_user_studyplan_returns(): \external_description {
|
|
return studyplan::user_structure();
|
|
}
|
|
|
|
/**
|
|
* Get a specific studyplan for a given user
|
|
* @param int $userid ID of user to check specific info for
|
|
* @param int $studyplanid ID of studyplan to view
|
|
* @return array|null
|
|
*/
|
|
public static function get_user_studyplan($userid, $studyplanid) {
|
|
global $CFG, $DB;
|
|
|
|
$studyplan = studyplan::find_by_id($studyplanid);
|
|
if ($studyplan->is_coach() && !$studyplan->suspended()) {
|
|
\external_api::validate_context($studyplan->context());
|
|
} else {
|
|
webservicehelper::require_capabilities(self::CAP_VIEWOTHER, $studyplan->context());
|
|
}
|
|
|
|
if ($studyplan->exist_for_user($userid)) {
|
|
|
|
$model = $studyplan->user_model($userid);
|
|
return $model;
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
/************************
|
|
* *
|
|
* get_user_page *
|
|
* *
|
|
************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_user_page
|
|
*/
|
|
public static function get_user_page_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"userid" => new \external_value(PARAM_INT, 'id of user'),
|
|
"pageid" => new \external_value(PARAM_INT, 'id of specific studyplan to provide'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_user_page
|
|
*/
|
|
public static function get_user_page_returns(): \external_description {
|
|
return studyplan::user_structure();
|
|
}
|
|
|
|
/**
|
|
* Get a specific studyplan page for a given user
|
|
* @param int $userid ID of user to check specific info for
|
|
* @param int $pageid ID of studyplan to view
|
|
* @return array|null
|
|
*/
|
|
public static function get_user_page($userid, $pageid) {
|
|
global $CFG, $DB;
|
|
|
|
$studyplan = studyplan::find_by_id($pageid);
|
|
webservicehelper::require_capabilities(self::CAP_VIEWOTHER, $studyplan->context());
|
|
|
|
if ($studyplan->exist_for_user($userid)) {
|
|
return $studyplan->user_model($userid);
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
/****************************
|
|
* *
|
|
* list_invited_studyplan *
|
|
* *
|
|
****************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function list_invited_studyplan
|
|
*/
|
|
public static function list_invited_studyplans_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"invitekey" => new \external_value(PARAM_RAW, 'invite key'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function list_invited_studyplan
|
|
*/
|
|
public static function list_invited_studyplans_returns(): \external_description {
|
|
return new \external_multiple_structure(
|
|
studyplan::simple_structure()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* List available studyplans based on invite key
|
|
* @param int $invitekey Invitation key
|
|
* @return array
|
|
*/
|
|
public static function list_invited_studyplans($invitekey) {
|
|
global $DB;
|
|
// First check if studyplan sharing is enabled.
|
|
if (!get_config("local_treestudyplan", "enableplansharing")) {
|
|
return [];
|
|
}
|
|
|
|
$invite = $DB->get_record_select(
|
|
"local_treestudyplan_invit",
|
|
$DB->sql_compare_text("invitekey"). " = " . $DB->sql_compare_text(":invitekey"),
|
|
['invitekey' => $invitekey]
|
|
);
|
|
|
|
if (empty($invite)) {
|
|
return [];
|
|
}
|
|
|
|
// Do not validate the context in this instance to avoid requiring logins when this is not wanted.
|
|
|
|
$userid = $invite->user_id;
|
|
|
|
$list = [];
|
|
$studyplans = studyplan::find_for_user($userid);
|
|
foreach ($studyplans as $studyplan) {
|
|
$list[] = $studyplan->simple_model($userid);
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/****************************
|
|
* *
|
|
* get_invited_studyplan *
|
|
* *
|
|
****************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_invited_studyplan
|
|
*/
|
|
public static function get_invited_studyplan_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"invitekey" => new \external_value(PARAM_RAW, 'invite key'),
|
|
"studyplanid" => new \external_value(PARAM_INT, 'studyplan_id'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_invited_studyplan
|
|
*/
|
|
public static function get_invited_studyplan_returns(): \external_description {
|
|
return studyplan::user_structure();
|
|
}
|
|
|
|
/**
|
|
* Get studyplan based on invite key and studyplan id
|
|
* @param string $invitekey Invitation key
|
|
* @param int $studyplanid ID of the studyplan to retrieve
|
|
* @return array
|
|
*/
|
|
public static function get_invited_studyplan($invitekey, $studyplanid) {
|
|
global $DB;
|
|
// First check if studyplan sharing is enabled.
|
|
if (!get_config("local_treestudyplan", "enableplansharing")) {
|
|
return [];
|
|
}
|
|
$invite = $DB->get_record_select(
|
|
"local_treestudyplan_invit",
|
|
$DB->sql_compare_text("invitekey"). " = " . $DB->sql_compare_text(":invitekey"),
|
|
['invitekey' => $invitekey]
|
|
);
|
|
|
|
if (empty($invite)) {
|
|
return [];
|
|
}
|
|
|
|
// Do not validate the context in this instance to avoid requiring logins when this is not wanted.
|
|
|
|
$studyplan = studyplan::find_by_id($studyplanid);
|
|
$userid = $invite->user_id;
|
|
|
|
if ($studyplan->exist_for_user($userid)) {
|
|
if (!$studyplan->suspended()) {
|
|
return $studyplan->user_model($userid);
|
|
} else {
|
|
throw new \moodle_exception("The selected studyplan is suspended");
|
|
}
|
|
|
|
} else {
|
|
throw new \moodle_exception("Invitation's user is not linked to this studyplan");
|
|
}
|
|
}
|
|
|
|
/****************************
|
|
* *
|
|
* get_invited_page *
|
|
* *
|
|
****************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_invited_studyplan
|
|
*/
|
|
public static function get_invited_page_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"invitekey" => new \external_value(PARAM_RAW, 'invite key'),
|
|
"pageid" => new \external_value(PARAM_INT, 'studyplan page id'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_invited_studyplan
|
|
*/
|
|
public static function get_invited_page_returns(): \external_description {
|
|
return studyplanpage::user_structure();
|
|
}
|
|
|
|
/**
|
|
* Get studyplan based on invite key and studyplan id
|
|
* @param string $invitekey Invitation key
|
|
* @param int $pageid ID of the studyplan to retrieve
|
|
* @return array
|
|
*/
|
|
public static function get_invited_page($invitekey, $pageid) {
|
|
global $DB;
|
|
// First check if studyplan sharing is enabled.
|
|
if (!get_config("local_treestudyplan", "enableplansharing")) {
|
|
return [];
|
|
}
|
|
$invite = $DB->get_record_select(
|
|
"local_treestudyplan_invit",
|
|
$DB->sql_compare_text("invitekey"). " = " . $DB->sql_compare_text(":invitekey"),
|
|
['invitekey' => $invitekey]
|
|
);
|
|
|
|
if (empty($invite)) {
|
|
return [];
|
|
}
|
|
|
|
// Do not validate the context in this instance to avoid requiring logins when this is not wanted.
|
|
|
|
$page = studyplanpage::find_by_id($pageid);
|
|
$studyplan = $page->studyplan();
|
|
$userid = $invite->user_id;
|
|
|
|
if ($studyplan->exist_for_user($userid)) {
|
|
return $page->user_model($userid);
|
|
} else {
|
|
throw new \moodle_exception("Invitation's user is not linked to this studyplan");
|
|
}
|
|
}
|
|
|
|
/************************
|
|
* *
|
|
* list_own_studyplans *
|
|
* *
|
|
************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function list_own_studyplans
|
|
*/
|
|
public static function list_own_studyplans_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters([]);
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function list_own_studyplans
|
|
*/
|
|
public static function list_own_studyplans_returns(): \external_description {
|
|
return new \external_multiple_structure(
|
|
studyplan::simple_structure()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Return overview of the studyplans the current user is linked to
|
|
* @return array
|
|
*/
|
|
public static function list_own_studyplans() {
|
|
global $CFG, $DB, $USER;
|
|
$userid = $USER->id;
|
|
|
|
$list = [];
|
|
$studyplans = studyplan::find_for_user($userid);
|
|
foreach ($studyplans as $studyplan) {
|
|
$list[] = $studyplan->simple_model($userid);
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/************************
|
|
* *
|
|
* get_own_studyplan *
|
|
* *
|
|
************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_own_studyplan
|
|
*/
|
|
public static function get_own_studyplan_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"studyplanid" => new \external_value(PARAM_INT, 'id of studyplan to retrieve'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_own_studyplan
|
|
*/
|
|
public static function get_own_studyplan_returns(): \external_description {
|
|
return studyplan::user_structure();
|
|
}
|
|
|
|
/**
|
|
* Get a studyplans for the current user
|
|
* @param int $studyplanid Id of specific studyplan
|
|
* @return array
|
|
*/
|
|
public static function get_own_studyplan($studyplanid) {
|
|
global $USER;
|
|
|
|
// Validate this call in the system context.
|
|
\external_api::validate_context(\context_system::instance());
|
|
|
|
$userid = $USER->id;
|
|
|
|
$studyplan = studyplan::find_by_id($studyplanid);
|
|
|
|
if ($studyplan->exist_for_user($userid) && !$studyplan->suspended()) {
|
|
$model = $studyplan->user_model($userid);
|
|
return $model;
|
|
} else {
|
|
throw new \moodle_exception("You do not have access to this studyplan");
|
|
}
|
|
}
|
|
|
|
/************************
|
|
* *
|
|
* get_own_page *
|
|
* *
|
|
************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_own_page
|
|
*/
|
|
public static function get_own_page_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"pageid" => new \external_value(PARAM_INT, 'id of studyplan to retrieve'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_own_page
|
|
*/
|
|
public static function get_own_page_returns(): \external_description {
|
|
return studyplan::user_structure();
|
|
}
|
|
|
|
/**
|
|
* Get studyplanpage for current user
|
|
* @param int $pageid ID of specific studyplan page
|
|
* @return array
|
|
*/
|
|
public static function get_own_page($pageid) {
|
|
global $USER;
|
|
|
|
// Validate this call in the system context.
|
|
\external_api::validate_context(\context_system::instance());
|
|
|
|
$userid = $USER->id;
|
|
|
|
$page = studyplanpage::find_by_id($pageid);
|
|
$studyplan = $page->studyplan();
|
|
|
|
if ($studyplan->exist_for_user($userid && !$studyplan->suspended())) {
|
|
return $page->user_model($userid);
|
|
} else {
|
|
throw new \moodle_exception("You do not have access to this studyplan page");
|
|
}
|
|
}
|
|
|
|
/***************************
|
|
* *
|
|
* list_teaching_studyplans *
|
|
* *
|
|
***************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function list_teaching_studyplans
|
|
*/
|
|
public static function list_teaching_studyplans_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function list_teaching_studyplans
|
|
*/
|
|
public static function list_teaching_studyplans_returns(): \external_description {
|
|
return new \external_multiple_structure(
|
|
studyplan::simple_structure()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get all studyplans the current user is teaching in
|
|
* @return array
|
|
*/
|
|
public static function list_teaching_studyplans() {
|
|
global $USER;
|
|
$userid = $USER->id;
|
|
|
|
\external_api::validate_context(\context_system::instance());
|
|
$studyplans = teachingfinder::list_my_plans();
|
|
|
|
$list = [];
|
|
foreach ($studyplans as $studyplan) {
|
|
$list[] = $studyplan->simple_model($userid);
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/***************************
|
|
* *
|
|
* list_coaching_studyplans *
|
|
* *
|
|
***************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function list_teaching_studyplans
|
|
*/
|
|
public static function list_coaching_studyplans_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function list_teaching_studyplans
|
|
*/
|
|
public static function list_coaching_studyplans_returns(): \external_description {
|
|
return new \external_multiple_structure(
|
|
studyplan::simple_structure()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get all studyplans the current user is coaching
|
|
* @return array
|
|
*/
|
|
public static function list_coaching_studyplans() {
|
|
global $USER, $DB;
|
|
$userid = $USER->id;
|
|
|
|
\external_api::validate_context(\context_system::instance());
|
|
|
|
// Return empty list if coach role not enabled.
|
|
if (! (\get_config("local_treestudyplan", "enablecoach"))) {
|
|
return [];
|
|
}
|
|
|
|
$records = $DB->get_records("local_treestudyplan_coach", ["user_id" => $userid]);
|
|
|
|
$list = [];
|
|
foreach ($records as $r) {
|
|
try {
|
|
$studyplan = studyplan::find_by_id($r->studyplan_id);
|
|
if (has_capability(self::CAP_COACH, $studyplan->context(), $USER)) {
|
|
$list[] = $studyplan->simple_model_coach();
|
|
}
|
|
} catch (\Exception $x) {
|
|
$studyplan = null;
|
|
}
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/***************************
|
|
* *
|
|
* get_teaching_studyplan *
|
|
* *
|
|
***************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_teaching_studyplan
|
|
*/
|
|
public static function get_teaching_studyplan_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"studyplanid" => new \external_value(PARAM_INT, 'id of specific studyplan to provide', VALUE_DEFAULT),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_teaching_studyplan
|
|
*/
|
|
public static function get_teaching_studyplan_returns(): \external_description {
|
|
return studyplan::editor_structure();
|
|
}
|
|
|
|
/**
|
|
* Get all or one studyplan the current user is teaching in
|
|
* @param int $studyplanid ID of studyplan to retrieve
|
|
* @return array
|
|
*/
|
|
public static function get_teaching_studyplan($studyplanid) {
|
|
global $USER;
|
|
$userid = $USER->id;
|
|
|
|
\external_api::validate_context(\context_system::instance());
|
|
$studyplan = studyplan::find_by_id($studyplanid);
|
|
|
|
if (teachingfinder::am_teaching_studyplan($studyplan)) {
|
|
return $studyplan->editor_model();
|
|
} else {
|
|
throw new \moodle_exception("You are not teaching in this studyplan");
|
|
}
|
|
}
|
|
|
|
/***************************
|
|
* *
|
|
* get_teaching_page *
|
|
* *
|
|
***************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_teaching_page
|
|
*/
|
|
public static function get_teaching_page_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"pageid" => new \external_value(PARAM_INT, 'id of specific studyplan page to provide', VALUE_DEFAULT),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_teaching_page
|
|
*/
|
|
public static function get_teaching_page_returns(): \external_description {
|
|
return studyplanpage::editor_structure();
|
|
}
|
|
|
|
/**
|
|
* Get one studyplan page if the current user is teaching in it
|
|
* @param int $pageid ID of studyplan to retrieve
|
|
* @return array
|
|
* @throws moodle_exception if current user is not teaching in this studyplan
|
|
*/
|
|
public static function get_teaching_page($pageid) {
|
|
\external_api::validate_context(\context_system::instance());
|
|
$page = studyplanpage::find_by_id($pageid);
|
|
$studyplan = $page->studyplan();
|
|
|
|
if (teachingfinder::am_teaching_studyplan($studyplan)) {
|
|
return $page->editor_model();
|
|
} else {
|
|
throw new \moodle_exception("You are not teaching in this studyplan");
|
|
}
|
|
}
|
|
|
|
/***************************
|
|
* *
|
|
* line_enrol_self *
|
|
* *
|
|
***************************/
|
|
|
|
/**
|
|
* Parameter description for webservice function get_teaching_page
|
|
*/
|
|
public static function line_enrol_self_parameters(): \external_function_parameters {
|
|
return new \external_function_parameters( [
|
|
"id" => new \external_value(PARAM_INT, 'id of specific studyline to enrol into'),
|
|
] );
|
|
}
|
|
|
|
/**
|
|
* Return value description for webservice function get_teaching_page
|
|
*/
|
|
public static function line_enrol_self_returns(): \external_description {
|
|
return studyline::enrol_info_structure();
|
|
}
|
|
|
|
/**
|
|
* Get all or one studyplan the current user is teaching in
|
|
* @param int $id ID of studyplan to retrieve
|
|
* @return array
|
|
*/
|
|
public static function line_enrol_self($id) {
|
|
global $USER;
|
|
$userid = $USER->id;
|
|
|
|
$o = studyline::find_by_id($id);
|
|
if ($o->can_enrol($userid)) {
|
|
$o->enrol($userid);
|
|
}
|
|
|
|
// Trigger immediate cohort synchronization for this line only.
|
|
autocohortsync::syncline($o);
|
|
|
|
return $o->enrol_info_model($userid);
|
|
}
|
|
|
|
}
|