aboutsummaryrefslogtreecommitdiff
path: root/classes
diff options
context:
space:
mode:
authorValentin Popov <info@valentineus.link>2019-05-06 04:45:35 +0300
committerValentin Popov <info@valentineus.link>2019-05-06 04:47:03 +0300
commiteb4b9b69f862df8ba23cafc8cd5e4a887baa02f0 (patch)
treee112a43f17173e02eada16b8d85ea4c4adc9cb4d /classes
parentbde135499d1fe0ca67a1f50fea79848cbdb370ea (diff)
downloadlocal_webhooks-eb4b9b69f862df8ba23cafc8cd5e4a887baa02f0.tar.xz
local_webhooks-eb4b9b69f862df8ba23cafc8cd5e4a887baa02f0.zip
Added worked a class observer
Signed-off-by: Valentin Popov <info@valentineus.link>
Diffstat (limited to 'classes')
-rw-r--r--classes/event/observer.php (renamed from classes/event_observer.php)34
-rw-r--r--classes/task/notify.php2
2 files changed, 16 insertions, 20 deletions
diff --git a/classes/event_observer.php b/classes/event/observer.php
index 983552a..ff6a89e 100644
--- a/classes/event_observer.php
+++ b/classes/event/observer.php
@@ -14,35 +14,31 @@
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
-/**
- * Handlers of observers for events.
- *
- * @copyright 2018 'Valentin Popov' <info@valentineus.link>
- * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
- * @package local_webhooks
- */
-
-namespace local_webhooks;
+namespace local_webhooks\event;
defined('MOODLE_INTERNAL') || die();
+use core\event\base as event;
+use core\task\manager;
+use local_webhooks\task\notify;
+use function defined;
+
/**
- * Defines event handlers.
+ * Class observer.
*
- * @copyright 2018 'Valentin Popov' <info@valentineus.link>
+ * @copyright 2019 'Valentin Popov' <info@valentineus.link>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
- * @package local_webhooks
+ * @package local_webhooks\event
*/
-class event_observer {
+final class observer {
/**
- * Handler of all the events.
- * Each event is put into the job queue.
+ * Main handler for events.
*
- * @param object $event
+ * @param \core\event\base $event
*/
- public static function observe_all($event) {
- $task = new \local_webhooks\task\process_events_task();
+ public static function handler(event $event) {
+ $task = new notify();
$task->set_custom_data($event->get_data());
- \core\task\manager::queue_adhoc_task($task);
+ manager::queue_adhoc_task($task);
}
} \ No newline at end of file
diff --git a/classes/task/notify.php b/classes/task/notify.php
index faa68a9..bd11f24 100644
--- a/classes/task/notify.php
+++ b/classes/task/notify.php
@@ -79,7 +79,7 @@ final class notify extends adhoc_task {
public function post(record $service, array $data) {
$curl = new curl();
$curl->setHeader(['Content-Type: ' . $service->header]);
- $curl->post($service->point, $data);
+ $curl->post($service->point, json_encode($data));
if (defined('PHPUNIT_TEST') && PHPUNIT_TEST) {
$this->debug = array_merge($this->debug ?? [], [