Added a new class for processing events
Signed-off-by: Valentin Popov <info@valentineus.link>
This commit is contained in:
parent
4806fad728
commit
bde135499d
90
classes/task/notify.php
Normal file
90
classes/task/notify.php
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
<?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/>.
|
||||||
|
|
||||||
|
namespace local_webhooks\task;
|
||||||
|
|
||||||
|
defined('MOODLE_INTERNAL') || die();
|
||||||
|
|
||||||
|
global $CFG;
|
||||||
|
|
||||||
|
require_once($CFG->dirroot . '/local/webhooks/classes/local/api.php');
|
||||||
|
|
||||||
|
use core\task\adhoc_task;
|
||||||
|
use curl;
|
||||||
|
use local_webhooks\local\api;
|
||||||
|
use local_webhooks\local\record;
|
||||||
|
use function defined;
|
||||||
|
use function is_object;
|
||||||
|
use function is_string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for processing events.
|
||||||
|
*
|
||||||
|
* @package local_webhooks\task
|
||||||
|
*/
|
||||||
|
final class notify extends adhoc_task {
|
||||||
|
/**
|
||||||
|
* Debug information.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $debug;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process an event.
|
||||||
|
*
|
||||||
|
* @throws \dml_exception
|
||||||
|
*/
|
||||||
|
public function execute() {
|
||||||
|
$event = $this->get_custom_data();
|
||||||
|
|
||||||
|
if (!is_object($event) || !isset($event->eventname) || !is_string($event->eventname)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (api::get_services_by_event($event->eventname) as $service) {
|
||||||
|
if (!is_object($service)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$service->status) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->post($service, array_merge((array) $event, [
|
||||||
|
'token' => $service->token,
|
||||||
|
]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send a request for the service.
|
||||||
|
*
|
||||||
|
* @param \local_webhooks\local\record $service
|
||||||
|
* @param array $data
|
||||||
|
*/
|
||||||
|
public function post(record $service, array $data) {
|
||||||
|
$curl = new curl();
|
||||||
|
$curl->setHeader(['Content-Type: ' . $service->header]);
|
||||||
|
$curl->post($service->point, $data);
|
||||||
|
|
||||||
|
if (defined('PHPUNIT_TEST') && PHPUNIT_TEST) {
|
||||||
|
$this->debug = array_merge($this->debug ?? [], [
|
||||||
|
compact('data', 'service'),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,68 +0,0 @@
|
|||||||
<?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/>.
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Defining task handlers.
|
|
||||||
*
|
|
||||||
* @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\task;
|
|
||||||
|
|
||||||
defined('MOODLE_INTERNAL') || die();
|
|
||||||
|
|
||||||
global $CFG;
|
|
||||||
|
|
||||||
require_once($CFG->dirroot . '/local/webhooks/lib.php');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class process_events_task
|
|
||||||
*
|
|
||||||
* @copyright 2018 'Valentin Popov' <info@valentineus.link>
|
|
||||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
||||||
* @package local_webhooks\task
|
|
||||||
*/
|
|
||||||
class process_events_task extends \core\task\adhoc_task {
|
|
||||||
/**
|
|
||||||
* Task handler.
|
|
||||||
*
|
|
||||||
* @throws \dml_exception
|
|
||||||
* @throws \moodle_exception
|
|
||||||
*/
|
|
||||||
public function execute() {
|
|
||||||
$services = \local_webhooks_api::get_services_by_event($this->get_custom_data()->eventname);
|
|
||||||
|
|
||||||
foreach ($services as $service) {
|
|
||||||
if ((bool) $service->status !== true) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$curl = new \curl();
|
|
||||||
|
|
||||||
$event = (array) $this->get_custom_data();
|
|
||||||
$event['token'] = $service->token;
|
|
||||||
|
|
||||||
$curl->setHeader(array('Content-Type: ' . $service->header));
|
|
||||||
$curl->post($service->point, json_encode($event));
|
|
||||||
|
|
||||||
// TODO: Mark the log.
|
|
||||||
|
|
||||||
$curl->getResponse();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
111
tests/task_test.php
Normal file
111
tests/task_test.php
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
<?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/>.
|
||||||
|
|
||||||
|
defined('MOODLE_INTERNAL') || die();
|
||||||
|
|
||||||
|
global $CFG;
|
||||||
|
|
||||||
|
require_once($CFG->dirroot . '/local/webhooks/classes/local/api.php');
|
||||||
|
|
||||||
|
use core\task\manager;
|
||||||
|
use local_webhooks\local\api;
|
||||||
|
use local_webhooks\local\record;
|
||||||
|
use local_webhooks\task\notify;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class local_webhooks_task_testcase.
|
||||||
|
*
|
||||||
|
* @copyright 2019 'Valentin Popov' <info@valentineus.link>
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||||
|
*/
|
||||||
|
final class local_webhooks_task_testcase extends advanced_testcase {
|
||||||
|
/**
|
||||||
|
* Testing add a task to the queue.
|
||||||
|
*/
|
||||||
|
public function test_add_task() {
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
manager::queue_adhoc_task(new notify());
|
||||||
|
|
||||||
|
$tasks = manager::get_adhoc_tasks('\local_webhooks\task\notify');
|
||||||
|
|
||||||
|
self::assertCount(1, $tasks);
|
||||||
|
self::assertInstanceOf('\local_webhooks\task\notify', array_shift($tasks));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Testing disabled processing service.
|
||||||
|
*
|
||||||
|
* @throws \coding_exception
|
||||||
|
* @throws \dml_exception
|
||||||
|
*/
|
||||||
|
public function test_execute_disabled() {
|
||||||
|
curl::mock_response('{}');
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$record = new record();
|
||||||
|
$record->events = ['\core\event\course_viewed'];
|
||||||
|
$record->header = 'application/json';
|
||||||
|
$record->name = 'Example name';
|
||||||
|
$record->point = 'http://example.org/';
|
||||||
|
$record->status = false;
|
||||||
|
$record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
|
||||||
|
|
||||||
|
$record->id = api::create_service($record);
|
||||||
|
|
||||||
|
$task = new notify();
|
||||||
|
$task->set_custom_data(['eventname' => '\core\event\course_viewed']);
|
||||||
|
$task->execute();
|
||||||
|
|
||||||
|
self::assertNull($task->debug);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Testing enabled processing service.
|
||||||
|
*
|
||||||
|
* @throws \coding_exception
|
||||||
|
* @throws \dml_exception
|
||||||
|
*/
|
||||||
|
public function test_execute_enabled() {
|
||||||
|
curl::mock_response('{}');
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$record = new record();
|
||||||
|
$record->events = ['\core\event\course_viewed'];
|
||||||
|
$record->header = 'application/json';
|
||||||
|
$record->name = 'Example name';
|
||||||
|
$record->point = 'http://example.org/';
|
||||||
|
$record->status = true;
|
||||||
|
$record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
|
||||||
|
|
||||||
|
$record->id = api::create_service($record);
|
||||||
|
|
||||||
|
$task = new notify();
|
||||||
|
$task->set_custom_data(['eventname' => '\core\event\course_viewed']);
|
||||||
|
$task->execute();
|
||||||
|
|
||||||
|
self::assertCount(1, $task->debug);
|
||||||
|
self::assertInternalType('array', $task->debug);
|
||||||
|
|
||||||
|
$element = array_shift($task->debug);
|
||||||
|
self::assertInternalType('array', $element['data']);
|
||||||
|
self::assertInternalType('object', $element['service']);
|
||||||
|
|
||||||
|
self::assertEquals($record->events[0], $element['data']['eventname']);
|
||||||
|
self::assertEquals($record->id, $element['service']->id);
|
||||||
|
self::assertEquals($record->token, $element['data']['token']);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user