diff options
author | Valentin Popov <info@valentineus.link> | 2017-10-25 08:08:30 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-25 08:08:30 +0300 |
commit | 7862e885ede09fe6ca0003d20437fa927fe8d756 (patch) | |
tree | 817757f761580a253af37cdea386831f3cf4cea8 /editservice.php | |
parent | d974670910aa1151cc1bc739981ea8149cdcfa64 (diff) | |
parent | 8ebb1381c993c7174eaa2aff9587f98239c0a954 (diff) | |
download | local_webhooks-7862e885ede09fe6ca0003d20437fa927fe8d756.tar.xz local_webhooks-7862e885ede09fe6ca0003d20437fa927fe8d756.zip |
Merge pull request #1 from valentineus/multiple-choice-url
Multiple choice url
Diffstat (limited to 'editservice.php')
-rw-r--r-- | editservice.php | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/editservice.php b/editservice.php new file mode 100644 index 0000000..5c6d1f6 --- /dev/null +++ b/editservice.php @@ -0,0 +1,91 @@ +<?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/>. + +/** + * Service editor. + * + * @package local_webhooks + * @copyright 2017 "Valentin Popov" <info@valentineus.link> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +require_once(__DIR__ . "/../../config.php"); +require_once(__DIR__ . "/classes/forms.php"); + +$idservice = optional_param("idservice", 0, PARAM_INT); + +require_login(); + +/* Link generation */ +$urlparameters = array("idservice" => $idservice); +$managerservice = new moodle_url("/local/webhooks/managerservice.php", $urlparameters); +$baseurl = new moodle_url("/local/webhooks/editservice.php", $urlparameters); +$PAGE->set_url($baseurl, $urlparameters); + +/* Configure the context of the page */ +$context = context_system::instance(); +$PAGE->set_context($context); + +/* Preparing a template for data */ +$titlepage = new lang_string("externalservice", "webservice"); +$servicerecord = new stdClass; + +/* Create an editing form */ +$mform = new \local_webhooks\service_edit_form($PAGE->url); + +/* Cancel processing */ +if ($mform->is_cancelled()) { + redirect($managerservice); +} + +/* Getting the data */ +if ($idediting = boolval($idservice)) { + $servicerecord = $DB->get_record("local_webhooks_service", array("id" => $idservice), "*", MUST_EXIST); + $mform->set_data($servicerecord); +} + +/* Processing of received data */ +if ($data = $mform->get_data()) { + if (empty($data->enable)) { + $data->enable = 0; + } + + if ($idediting) { + $data->id = $idservice; + $DB->update_record("local_webhooks_service", $data); + } else { + $DB->insert_record("local_webhooks_service", $data); + } + + redirect($managerservice); +} + +/* Page template */ +$PAGE->set_pagelayout("admin"); +$PAGE->set_heading($titlepage); +$PAGE->set_title($titlepage); + +/* The page title */ +$PAGE->navbar->add(new lang_string("local", "moodle")); +$PAGE->navbar->add(new lang_string("pluginname", "local_webhooks")); +$PAGE->navbar->add(new lang_string("managerservice", "local_webhooks"), $managerservice); +$PAGE->navbar->add($titlepage); +echo $OUTPUT->header(); + +/* Displays the form */ +$mform->display(); + +echo $OUTPUT->footer();
\ No newline at end of file |