diff options
author | Valentin Popov <info@valentineus.link> | 2019-05-06 04:45:35 +0300 |
---|---|---|
committer | Valentin Popov <info@valentineus.link> | 2019-05-06 04:47:03 +0300 |
commit | eb4b9b69f862df8ba23cafc8cd5e4a887baa02f0 (patch) | |
tree | e112a43f17173e02eada16b8d85ea4c4adc9cb4d /classes | |
parent | bde135499d1fe0ca67a1f50fea79848cbdb370ea (diff) | |
download | local_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.php | 2 |
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 ?? [], [ |