You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
287 lines
12 KiB
287 lines
12 KiB
2 years ago
|
<?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/>.
|
||
|
|
||
|
/**
|
||
|
* Class site_registration_form
|
||
|
*
|
||
|
* @package core
|
||
|
* @copyright 2017 Marina Glancy
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
|
||
|
namespace core\hub;
|
||
|
defined('MOODLE_INTERNAL') || die();
|
||
|
|
||
|
use context_course;
|
||
|
use stdClass;
|
||
|
|
||
|
global $CFG;
|
||
|
require_once($CFG->libdir . '/formslib.php');
|
||
|
|
||
|
/**
|
||
|
* The site registration form. Information will be sent to moodle.net
|
||
|
*
|
||
|
* @author Jerome Mouneyrac <jerome@mouneyrac.com>
|
||
|
* @package core
|
||
|
* @copyright 2017 Marina Glancy
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class site_registration_form extends \moodleform {
|
||
|
|
||
|
/**
|
||
|
* Form definition
|
||
|
*/
|
||
|
public function definition() {
|
||
|
global $CFG;
|
||
|
|
||
|
$strrequired = get_string('required');
|
||
|
$mform = & $this->_form;
|
||
|
$admin = get_admin();
|
||
|
$site = get_site();
|
||
|
|
||
|
$siteinfo = registration::get_site_info([
|
||
|
'name' => format_string($site->fullname, true, array('context' => context_course::instance(SITEID))),
|
||
|
'description' => $site->summary,
|
||
|
'contactname' => fullname($admin, true),
|
||
|
'contactemail' => $admin->email,
|
||
|
'contactphone' => $admin->phone1,
|
||
|
'street' => '',
|
||
|
'countrycode' => $admin->country ?: $CFG->country,
|
||
|
'regioncode' => '-', // Not supported yet.
|
||
|
'language' => explode('_', current_language())[0],
|
||
|
'geolocation' => '',
|
||
|
'emailalert' => 1,
|
||
|
'commnews' => 1,
|
||
|
'policyagreed' => 0
|
||
|
|
||
|
]);
|
||
|
|
||
|
// Fields that need to be highlighted.
|
||
|
$highlightfields = registration::get_new_registration_fields();
|
||
|
|
||
|
$mform->addElement('header', 'moodle', get_string('registrationinfo', 'hub'));
|
||
|
|
||
|
$mform->addElement('text', 'name', get_string('sitename', 'hub'),
|
||
|
array('class' => 'registration_textfield'));
|
||
|
$mform->setType('name', PARAM_TEXT);
|
||
|
$mform->addHelpButton('name', 'sitename', 'hub');
|
||
|
|
||
|
$mform->addElement('select', 'privacy', get_string('siteprivacy', 'hub'), registration::site_privacy_options());
|
||
|
$mform->setType('privacy', PARAM_ALPHA);
|
||
|
$mform->addHelpButton('privacy', 'siteprivacy', 'hub');
|
||
|
unset($options);
|
||
|
|
||
|
$mform->addElement('textarea', 'description', get_string('sitedesc', 'hub'),
|
||
|
array('rows' => 3, 'cols' => 41));
|
||
|
$mform->setType('description', PARAM_TEXT);
|
||
|
$mform->addHelpButton('description', 'sitedesc', 'hub');
|
||
|
|
||
|
$languages = get_string_manager()->get_list_of_languages();
|
||
|
\core_collator::asort($languages);
|
||
|
$mform->addElement('select', 'language', get_string('sitelang', 'hub'), $languages);
|
||
|
$mform->setType('language', PARAM_ALPHANUMEXT);
|
||
|
$mform->addHelpButton('language', 'sitelang', 'hub');
|
||
|
|
||
|
// Postal address was part of this form before but not any more.
|
||
|
$mform->addElement('hidden', 'street');
|
||
|
$mform->setType('street', PARAM_TEXT);
|
||
|
$mform->addHelpButton('street', 'postaladdress', 'hub');
|
||
|
|
||
|
$mform->addElement('hidden', 'regioncode', '-');
|
||
|
$mform->setType('regioncode', PARAM_ALPHANUMEXT);
|
||
|
|
||
|
$countries = ['' => ''] + get_string_manager()->get_list_of_countries();
|
||
|
$mform->addElement('select', 'countrycode', get_string('sitecountry', 'hub'), $countries);
|
||
|
$mform->setType('countrycode', PARAM_ALPHANUMEXT);
|
||
|
$mform->addHelpButton('countrycode', 'sitecountry', 'hub');
|
||
|
$mform->addRule('countrycode', $strrequired, 'required', null, 'client');
|
||
|
|
||
|
// Geolocation was part of this form before but not any more.
|
||
|
$mform->addElement('hidden', 'geolocation');
|
||
|
$mform->setType('geolocation', PARAM_RAW);
|
||
|
$mform->addHelpButton('geolocation', 'sitegeolocation', 'hub');
|
||
|
|
||
|
// Admin name was part of this form before but not any more.
|
||
|
$mform->addElement('hidden', 'contactname');
|
||
|
$mform->setType('contactname', PARAM_TEXT);
|
||
|
$mform->addHelpButton('contactname', 'siteadmin', 'hub');
|
||
|
|
||
|
$mform->addElement('hidden', 'contactphone');
|
||
|
$mform->setType('contactphone', PARAM_TEXT);
|
||
|
$mform->addHelpButton('contactphone', 'sitephone', 'hub');
|
||
|
|
||
|
$mform->addElement('text', 'contactemail', get_string('siteemail', 'hub'),
|
||
|
array('class' => 'registration_textfield'));
|
||
|
$mform->addRule('contactemail', $strrequired, 'required', null, 'client');
|
||
|
$mform->setType('contactemail', PARAM_EMAIL);
|
||
|
$mform->addHelpButton('contactemail', 'siteemail', 'hub');
|
||
|
|
||
|
$options = array();
|
||
|
$options[0] = get_string("registrationcontactno");
|
||
|
$options[1] = get_string("registrationcontactyes");
|
||
|
$mform->addElement('select', 'contactable', get_string('siteregistrationcontact', 'hub'), $options);
|
||
|
$mform->setType('contactable', PARAM_INT);
|
||
|
$mform->addHelpButton('contactable', 'siteregistrationcontact', 'hub');
|
||
|
$mform->hideIf('contactable', 'privacy', 'eq', registration::HUB_SITENOTPUBLISHED);
|
||
|
unset($options);
|
||
|
|
||
|
$this->add_select_with_email('emailalert', 'siteregistrationemail', [
|
||
|
0 => get_string('registrationno'),
|
||
|
1 => get_string('registrationyes'),
|
||
|
]);
|
||
|
|
||
|
$this->add_select_with_email('commnews', 'sitecommnews', [
|
||
|
0 => get_string('sitecommnewsno', 'hub'),
|
||
|
1 => get_string('sitecommnewsyes', 'hub'),
|
||
|
], in_array('commnews', $highlightfields));
|
||
|
|
||
|
// TODO site logo.
|
||
|
$mform->addElement('hidden', 'imageurl', ''); // TODO: temporary.
|
||
|
$mform->setType('imageurl', PARAM_URL);
|
||
|
|
||
|
$mform->addElement('checkbox', 'policyagreed', get_string('policyagreed', 'hub'),
|
||
|
get_string('policyagreeddesc', 'hub', HUB_MOODLEORGHUBURL . '/privacy'));
|
||
|
$mform->addRule('policyagreed', $strrequired, 'required', null, 'client');
|
||
|
|
||
|
$mform->addElement('header', 'sitestats', get_string('sendfollowinginfo', 'hub'));
|
||
|
$mform->setExpanded('sitestats', !empty($highlightfields));
|
||
|
$mform->addElement('static', 'urlstring', get_string('siteurl', 'hub'), $siteinfo['url']);
|
||
|
$mform->addHelpButton('urlstring', 'siteurl', 'hub');
|
||
|
|
||
|
// Display statistic that are going to be retrieve by moodle.net.
|
||
|
$mform->addElement('static', 'siteinfosummary', get_string('sendfollowinginfo', 'hub'), registration::get_stats_summary($siteinfo));
|
||
|
|
||
|
// Check if it's a first registration or update.
|
||
|
if (registration::is_registered()) {
|
||
|
$buttonlabel = get_string('updatesite', 'hub', 'Moodle.net');
|
||
|
$mform->addElement('hidden', 'update', true);
|
||
|
$mform->setType('update', PARAM_BOOL);
|
||
|
} else {
|
||
|
$buttonlabel = get_string('registersite', 'hub', 'Moodle.net');
|
||
|
}
|
||
|
|
||
|
$this->add_action_buttons(false, $buttonlabel);
|
||
|
|
||
|
$mform->addElement('hidden', 'returnurl');
|
||
|
$mform->setType('returnurl', PARAM_LOCALURL);
|
||
|
|
||
|
// Prepare and set data.
|
||
|
$siteinfo['emailalertnewemail'] = !empty($siteinfo['emailalert']) && !empty($siteinfo['emailalertemail']);
|
||
|
if (empty($siteinfo['emailalertnewemail'])) {
|
||
|
$siteinfo['emailalertemail'] = '';
|
||
|
}
|
||
|
$siteinfo['commnewsnewemail'] = !empty($siteinfo['commnews']) && !empty($siteinfo['commnewsemail']);
|
||
|
if (empty($siteinfo['commnewsnewemail'])) {
|
||
|
$siteinfo['commnewsemail'] = '';
|
||
|
}
|
||
|
|
||
|
// Set data. Always require to check policyagreed even if it was checked earlier.
|
||
|
$this->set_data(['policyagreed' => 0] + $siteinfo);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add yes/no select with additional checkbox allowing to specify another email
|
||
|
*
|
||
|
* @param string $elementname
|
||
|
* @param string $stridentifier
|
||
|
* @param array|null $options options for the select element
|
||
|
* @param bool $highlight highlight as a new field
|
||
|
*/
|
||
|
protected function add_select_with_email($elementname, $stridentifier, $options = null, $highlight = false) {
|
||
|
$mform = $this->_form;
|
||
|
|
||
|
if ($options === null) {
|
||
|
$options = [0 => get_string('no'), 1 => get_string('yes')];
|
||
|
}
|
||
|
|
||
|
$group = [
|
||
|
$mform->createElement('select', $elementname, get_string($stridentifier, 'hub'), $options),
|
||
|
$mform->createElement('static', $elementname . 'sep', '', '<br/>'),
|
||
|
$mform->createElement('advcheckbox', $elementname . 'newemail', '', get_string('usedifferentemail', 'hub'),
|
||
|
['onchange' => "this.form.elements['{$elementname}email'].focus();"]),
|
||
|
$mform->createElement('text', $elementname . 'email', get_string('email'))
|
||
|
];
|
||
|
|
||
|
$element = $mform->addElement('group', $elementname . 'group', get_string($stridentifier, 'hub'), $group, '', false);
|
||
|
if ($highlight) {
|
||
|
$element->setAttributes(['class' => $element->getAttribute('class') . ' needsconfirmation mark']);
|
||
|
}
|
||
|
$mform->hideIf($elementname . 'email', $elementname, 'eq', 0);
|
||
|
$mform->hideIf($elementname . 'newemail', $elementname, 'eq', 0);
|
||
|
$mform->hideIf($elementname . 'email', $elementname . 'newemail', 'notchecked');
|
||
|
$mform->setType($elementname, PARAM_INT);
|
||
|
$mform->setType($elementname . 'email', PARAM_RAW_TRIMMED); // E-mail will be validated in validation().
|
||
|
$mform->addHelpButton($elementname . 'group', $stridentifier, 'hub');
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Validation of the form data
|
||
|
*
|
||
|
* @param array $data array of ("fieldname"=>value) of submitted data
|
||
|
* @param array $files array of uploaded files "element_name"=>tmp_file_path
|
||
|
* @return array of "element_name"=>"error_description" if there are errors,
|
||
|
* or an empty array if everything is OK
|
||
|
*/
|
||
|
public function validation($data, $files) {
|
||
|
$errors = parent::validation($data, $files);
|
||
|
// Validate optional emails. We do not use PARAM_EMAIL because it blindly clears the field if it is not a valid email.
|
||
|
if (!empty($data['emailalert']) && !empty($data['emailalertnewemail']) && !validate_email($data['emailalertemail'])) {
|
||
|
$errors['emailalertgroup'] = get_string('invalidemail');
|
||
|
}
|
||
|
if (!empty($data['commnews']) && !empty($data['commnewsnewemail']) && !validate_email($data['commnewsemail'])) {
|
||
|
$errors['commnewsgroup'] = get_string('invalidemail');
|
||
|
}
|
||
|
return $errors;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the form data
|
||
|
*
|
||
|
* @return stdClass
|
||
|
*/
|
||
|
public function get_data() {
|
||
|
if ($data = parent::get_data()) {
|
||
|
// Never return '*newemail' checkboxes, always return 'emailalertemail' and 'commnewsemail' even if not applicable.
|
||
|
if (empty($data->emailalert) || empty($data->emailalertnewemail)) {
|
||
|
$data->emailalertemail = null;
|
||
|
}
|
||
|
unset($data->emailalertnewemail);
|
||
|
if (empty($data->commnews) || empty($data->commnewsnewemail)) {
|
||
|
$data->commnewsemail = null;
|
||
|
}
|
||
|
unset($data->commnewsnewemail);
|
||
|
// Always return 'contactable'.
|
||
|
$data->contactable = empty($data->contactable) ? 0 : 1;
|
||
|
|
||
|
if (debugging('', DEBUG_DEVELOPER)) {
|
||
|
// Display debugging message for developers who added fields to the form and forgot to add them to registration::FORM_FIELDS.
|
||
|
$keys = array_diff(array_keys((array)$data),
|
||
|
['returnurl', 'mform_isexpanded_id_sitestats', 'submitbutton', 'update']);
|
||
|
if ($extrafields = array_diff($keys, registration::FORM_FIELDS)) {
|
||
|
debugging('Found extra fields in the form results: ' . join(', ', $extrafields), DEBUG_DEVELOPER);
|
||
|
}
|
||
|
if ($missingfields = array_diff(registration::FORM_FIELDS, $keys)) {
|
||
|
debugging('Some fields are missing in the form results: ' . join(', ', $missingfields), DEBUG_DEVELOPER);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|