You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

95 lines
2.8 KiB
PHP

<?php
// This file is part of Moodle - http://moodle.org/
//
// 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 <http://www.gnu.org/licenses/>.
/**
* IServ enrolment plugin implementation
*
* This plugin synchronizes courses and their enrolments with an IServ school server.
* Based partially on the OSS plugin by Frank Schütte
*
* @package enrol
* @subpackage iserv
* @author Jonas Lührig based on code by Frank Schütte based on code by Iñaki Arenaza
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com}
* @copyright 2010 Iñaki Arenaza <iarenaza@eps.mondragon.edu>
* @copyright 2020 Frank Schütte <fschuett@gymhim.de>
* @copyright 2023 Gruelag GmbH <buero@gruelag.de>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
define("CLI_SCRIPT", true);
require (dirname(dirname(dirname(dirname(__FILE__)))) . "/config.php");
require_once ("{$CFG -> libdir}/clilib.php");
// Parse CLI arguments
list ($options, $unrecognized) = cli_get_params (
[
"help" => false,
"user" => false
],
[
"h" => "help",
"u" => "user"
],
);
if ($unrecognized) {
$unrecognized = implode ("\n ", $unrecognized);
cli_error (get_string ("cliunknownoption", "enrol_iserv", $unrecognized));
} else if ($options["help"]) {
$help = <<< EOH
Manually do a sync of IServ groups as courses.
Please ensure to enable and configure the enrol_iserv Plugin beforehand.
Options:
-h, --help Print out this help
Example:
\$sudo -u www-data /usr/bin/php enrol/iserv/cli/sync.php
Notice:
Do not call this file through the system cron scheduler, rather
use the scheduled task within Moodle this plugin provides.
EOH;
echo $help;
die;
}
// Enable debug messages
$CFG -> debug = DEBUG_NORMAL;
// Ensure required plugins are enabled
if (! is_enabled_auth ("ldap")) {
print ("[AUTH LDAP] " . get_string ("pluginnotenabled", "auth_ldap"));
die;
}
if (! enrol_is_enabled ("iserv")) {
print ("[ENROL IServ] " . get_string ("pluginnotenabled", "enrol_iserv"));
die;
}
// Sync courses
$enrol = enrol_get_plugin ("iserv");
if (! $enrol -> sync_courses ($options["user"] ?? "*")) {
cli_error (get_string ("sync_failed", "enrol_iserv"), 1);
};
exit(0);