From ea1c9f7322202a10ab13526cb9734917ac323a00 Mon Sep 17 00:00:00 2001 From: Valentin Popov Date: Mon, 23 Oct 2017 08:31:09 +0400 Subject: Added a class to work with the form --- classes/forms.php | 81 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 81 insertions(+) create mode 100644 classes/forms.php (limited to 'classes') diff --git a/classes/forms.php b/classes/forms.php new file mode 100644 index 0000000..e3c962f --- /dev/null +++ b/classes/forms.php @@ -0,0 +1,81 @@ +. + +/** + * Defines the form of editing the service. + * + * @package local_webhooks + * @copyright 2017 "Valentin Popov" + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +namespace local_webhooks; + +defined("MOODLE_INTERNAL") || die(); + +require_once($CFG->libdir . "/formslib.php"); +use lang_string; +use moodleform; + +/** + * Description editing form definition. + * + * @copyright 2017 "Valentin Popov" + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ +class service_edit_form extends moodleform { + /** + * @param string $baseurl + */ + public function __construct($baseurl) { + parent::__construct($baseurl); + } + + /** + * Defines the standard structure of the form. + */ + protected function definition() { + $mform =& $this->_form; + + /* Form heading */ + $mform->addElement("header", "editserviceheader", + new lang_string("editserviceheader", "local_webhooks")); + + /* Name of the service */ + $mform->addElement("text", "title", + new lang_string("editservicetitle", "local_webhooks"), + array("size" => 60)); + $mform->setType("title", PARAM_NOTAGS); + $mform->addRule("title", null, "required"); + + /* Callback address */ + $mform->addElement("text", "url", + new lang_string("editserviceurl", "local_webhooks"), + array("size" => 60)); + $mform->setType("url", PARAM_URL); + $mform->addRule("url", null, "required"); + + /* Enabling the service */ + $mform->addElement("checkbox", "enable", + new lang_string("editserviceenable", "local_webhooks")); + $mform->setType("enable", PARAM_BOOL); + $mform->setDefault("enable", 1); + $mform->setAdvanced("enable"); + + /* Control Panel */ + $this->add_action_buttons(true); + } +} \ No newline at end of file -- cgit v1.2.3 From ed34626ef69805cb543e8765e0bbbc62f163d8cb Mon Sep 17 00:00:00 2001 From: Valentin Popov Date: Tue, 24 Oct 2017 05:03:44 +0400 Subject: Refactoring the editor class --- classes/forms.php | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'classes') diff --git a/classes/forms.php b/classes/forms.php index e3c962f..c232a7b 100644 --- a/classes/forms.php +++ b/classes/forms.php @@ -52,25 +52,25 @@ class service_edit_form extends moodleform { /* Form heading */ $mform->addElement("header", "editserviceheader", - new lang_string("editserviceheader", "local_webhooks")); + new lang_string("service", "webservice")); /* Name of the service */ $mform->addElement("text", "title", - new lang_string("editservicetitle", "local_webhooks"), + new lang_string("name", "moodle"), array("size" => 60)); $mform->setType("title", PARAM_NOTAGS); $mform->addRule("title", null, "required"); /* Callback address */ $mform->addElement("text", "url", - new lang_string("editserviceurl", "local_webhooks"), + new lang_string("url", "moodle"), array("size" => 60)); $mform->setType("url", PARAM_URL); $mform->addRule("url", null, "required"); /* Enabling the service */ $mform->addElement("checkbox", "enable", - new lang_string("editserviceenable", "local_webhooks")); + new lang_string("enable", "moodle")); $mform->setType("enable", PARAM_BOOL); $mform->setDefault("enable", 1); $mform->setAdvanced("enable"); -- cgit v1.2.3 From 8ebb1381c993c7174eaa2aff9587f98239c0a954 Mon Sep 17 00:00:00 2001 From: Valentin Popov Date: Wed, 25 Oct 2017 08:46:07 +0400 Subject: Adaptation of the handler under new conditions --- classes/events.php | 61 ++++++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 55 insertions(+), 6 deletions(-) (limited to 'classes') diff --git a/classes/events.php b/classes/events.php index bf77d4d..5dfb0cf 100644 --- a/classes/events.php +++ b/classes/events.php @@ -24,19 +24,68 @@ namespace local_webhooks; -defined('MOODLE_INTERNAL') || die(); +defined("MOODLE_INTERNAL") || die(); +/** + * Defines how to work with events. + * + * @copyright 2017 "Valentin Popov" + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ class events { + /** + * External handler. + * + * @param object $event + */ public static function handler($event) { - $enabled = boolval(get_config('local_webhooks', 'enabled')); - $url = get_config('local_webhooks', 'url'); + $config = get_config("local_webhooks"); - if ($enabled && !empty($url)) { + if (boolval($config->enable)) { $data = $event->get_data(); - $json = json_encode($data); + self::transmitter($data); + } + } + + /** + * Transmitter, processing event and services. + * + * @param array $data + */ + private static function transmitter($data) { + global $DB; + $callbacks = $DB->get_recordset("local_webhooks_service"); + + if ($callbacks->valid()) { + foreach ($callbacks as $callback) { + self::send($data, $callback); + } + } + + $callbacks->close(); + } + + /** + * Sending data to the node. + * + * @param array $data + * @param object $callback + */ + private static function send($data, $callback) { + if ($callback->enable) { $curl = new curl(); - $curl::request($url, $json); + $package = self::packup($data); + $curl::request($callback->url, $package); } } + + /** + * Packs the data for transmission. + * + * @param array $data + */ + private static function packup($data) { + return json_encode($data); + } } \ No newline at end of file -- cgit v1.2.3