aboutsummaryrefslogtreecommitdiff
path: root/externallib.php
diff options
context:
space:
mode:
Diffstat (limited to 'externallib.php')
-rw-r--r--externallib.php627
1 files changed, 6 insertions, 621 deletions
diff --git a/externallib.php b/externallib.php
index b854b55..87e77e9 100644
--- a/externallib.php
+++ b/externallib.php
@@ -17,636 +17,21 @@
/**
* This file defines the plugin's external functions.
*
- * @package local_webhooks
- * @copyright 2017 "Valentin Popov" <info@valentineus.link>
+ * @copyright 2018 'Valentin Popov' <info@valentineus.link>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
+ * @package local_webhooks
*/
-defined("MOODLE_INTERNAL") || die();
-
-require_once(__DIR__ . "/lib.php");
+defined( "MOODLE_INTERNAL" ) || die();
-require_once($CFG->libdir . "/externallib.php");
+require_once( $CFG->libdir . "/externallib.php" );
/**
* External functions.
*
- * @copyright 2017 "Valentin Popov" <info@valentineus.link>
+ * @copyright 2018 'Valentin Popov' <info@valentineus.link>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
+ * @package local_webhooks
*/
class local_webhooks_external extends external_api {
- /**
- * Single template output parameters.
- *
- * @return external_description
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- private static function structure_record_parameters() {
- return new external_single_structure(
- array(
- "id" => new external_value(PARAM_INT, "Service ID."),
- "enable" => new external_value(PARAM_BOOL, "Enable or disable the service."),
- "title" => new external_value(PARAM_TEXT, "Name of the service."),
- "url" => new external_value(PARAM_URL, "Web address of the service."),
- "type" => new external_value(PARAM_TEXT, "Used header type."),
- "token" => new external_value(PARAM_RAW, "Authorization key.", VALUE_OPTIONAL),
- "other" => new external_value(PARAM_RAW, "Additional field.", VALUE_OPTIONAL),
- "events" => new external_multiple_structure(
- new external_single_structure(
- array(
- "name" => new external_value(PARAM_TEXT, "The name of the event."),
- "value" => new external_value(PARAM_BOOL, "Enabled or disabled handler.")
- )
- ), "List of observed events.", VALUE_OPTIONAL
- )
- ), "Information about the service."
- );
- }
-
- /**
- * Formation of the final list.
- *
- * @param array $listrecords
- * @return array
- */
- private static function formation_list($listrecords) {
- $result = array();
-
- foreach ($listrecords as $index => $record) {
- $result[$index] = (array) $record;
- $result[$index]["events"] = self::formation_events($record->events);
- }
-
- return $result;
- }
-
- /**
- * Formation of the final list of events.
- *
- * @param array $listevents
- * @return array
- */
- private static function formation_events($listevents) {
- $result = array();
-
- foreach ($listevents as $key => $value) {
- $result[] = array("name" => $key, "value" => $value);
- }
-
- return $result;
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function change_status_parameters() {
- return new external_function_parameters(
- array(
- "serviceid" => new external_value(PARAM_INT, "Service ID.")
- )
- );
- }
-
- /**
- * Change the status of the service.
- *
- * @param number $serviceid
- * @return boolean
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function change_status($serviceid) {
- $parameters = self::validate_parameters(self::change_status_parameters(), array("serviceid" => $serviceid));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- return local_webhooks_change_status($parameters["serviceid"]);
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function change_status_returns() {
- return new external_value(PARAM_BOOL, "Result of execution.");
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function search_services_by_event_parameters() {
- return new external_function_parameters(
- array(
- "eventname" => new external_value(PARAM_TEXT, "The name of the event."),
- "active" => new external_value(PARAM_BOOL, "Filter show active or all services.")
- )
- );
- }
-
- /**
- * Search for services that contain the specified event.
- *
- * @param string $eventname
- * @param boolean $active
- * @return array
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function search_services_by_event($eventname, $active) {
- $parameters = self::validate_parameters(self::search_services_by_event_parameters(), array("eventname" => $eventname, "active" => $active));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- $result = array();
-
- if ($listrecords = local_webhooks_search_services_by_event($parameters["eventname"], $parameters["active"])) {
- $result = self::formation_list($listrecords);
- }
-
- return $result;
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function search_services_by_event_returns() {
- return new external_multiple_structure(
- self::structure_record_parameters(), "List of services."
- );
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function get_record_parameters() {
- return new external_function_parameters(
- array(
- "serviceid" => new external_value(PARAM_INT, "Service ID.")
- )
- );
- }
-
- /**
- * Get the record from the database.
- *
- * @param number $serviceid
- * @return array
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function get_record($serviceid) {
- $parameters = self::validate_parameters(self::get_record_parameters(), array("serviceid" => $serviceid));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- $result = array();
-
- if ($record = local_webhooks_get_record($parameters["serviceid"])) {
- $result = (array) $record;
- $result["events"] = self::formation_events($record->events);
- }
-
- return $result;
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function get_record_returns() {
- return self::structure_record_parameters();
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function get_list_records_parameters() {
- return new external_function_parameters(
- array(
- "limitfrom" => new external_value(PARAM_INT, "Where to start results from."),
- "limitnum" => new external_value(PARAM_INT, "How many results to return.")
- )
- );
- }
-
- /**
- * Get all records from the database.
- *
- * @param number $limitfrom
- * @param number $limitnum
- * @return array
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function get_list_records($limitfrom, $limitnum) {
- $parameters = self::validate_parameters(self::get_list_records_parameters(), array("limitfrom" => $limitfrom, "limitnum" => $limitnum));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- $result = array();
-
- if ($listrecords = local_webhooks_get_list_records($parameters["limitfrom"], $parameters["limitnum"])) {
- $result = self::formation_list($listrecords);
- }
-
- return $result;
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function get_list_records_returns() {
- return new external_multiple_structure(
- self::structure_record_parameters(), "List of services."
- );
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function get_list_events_parameters() {
- return new external_function_parameters(array());
- }
-
- /**
- * Get a list of all system events.
- *
- * @return array
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function get_list_events() {
- $context = context_system::instance();
- self::validate_context($context);
-
- $result = array();
-
- if ($eventlist = local_webhooks_get_list_events()) {
- foreach ($eventlist as $item) {
- $result[] = $item["eventname"];
- }
- }
-
- return $result;
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function get_list_events_returns() {
- return new external_multiple_structure(
- new external_value(PARAM_TEXT, "The name of the event.")
- );
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function create_record_parameters() {
- return new external_function_parameters(
- array(
- "service" => new external_single_structure(
- array(
- "enable" => new external_value(PARAM_BOOL, "Enable or disable the service.", VALUE_OPTIONAL),
- "title" => new external_value(PARAM_TEXT, "Name of the service."),
- "url" => new external_value(PARAM_URL, "Web address of the service."),
- "type" => new external_value(PARAM_TEXT, "Used header type.", VALUE_OPTIONAL),
- "token" => new external_value(PARAM_RAW, "Authorization key.", VALUE_OPTIONAL),
- "other" => new external_value(PARAM_RAW, "Additional field.", VALUE_OPTIONAL),
- "events" => new external_multiple_structure(
- new external_single_structure(
- array(
- "name" => new external_value(PARAM_TEXT, "The name of the event."),
- "value" => new external_value(PARAM_BOOL, "Enabled or disabled handler.")
- )
- ), "List of observed events.", VALUE_OPTIONAL
- )
- ), "Information about the service."
- )
- )
- );
- }
-
- /**
- * Create an entry in the database.
- *
- * @param array $service
- * @return boolean
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function create_record($service) {
- $parameters = self::validate_parameters(self::create_record_parameters(), array("service" => $service));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- $record = new stdClass();
- $record->other = $parameters["service"]["other"];
- $record->title = $parameters["service"]["title"];
- $record->token = $parameters["service"]["token"];
- $record->url = $parameters["service"]["url"];
- $record->events = array();
-
- $record->enable = !empty($parameters["service"]["enable"]) ? $parameters["service"]["enable"] : false;
- $record->type = !empty($parameters["service"]["type"]) ? $parameters["service"]["type"] : "json";
-
- foreach ($parameters["service"]["events"] as $value) {
- $record->events[$value["name"]] = $value["value"];
- }
-
- return local_webhooks_create_record($record);
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function create_record_returns() {
- return new external_value(PARAM_BOOL, "Result of execution.");
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function update_record_parameters() {
- return new external_function_parameters(
- array(
- "service" => new external_single_structure(
- array(
- "id" => new external_value(PARAM_INT, "Service ID."),
- "enable" => new external_value(PARAM_BOOL, "Enable or disable the service.", VALUE_OPTIONAL),
- "title" => new external_value(PARAM_TEXT, "Name of the service.", VALUE_OPTIONAL),
- "url" => new external_value(PARAM_URL, "Web address of the service.", VALUE_OPTIONAL),
- "type" => new external_value(PARAM_TEXT, "Used header type.", VALUE_OPTIONAL),
- "token" => new external_value(PARAM_RAW, "Authorization key.", VALUE_OPTIONAL),
- "other" => new external_value(PARAM_RAW, "Additional field.", VALUE_OPTIONAL),
- "events" => new external_multiple_structure(
- new external_single_structure(
- array(
- "name" => new external_value(PARAM_TEXT, "The name of the event."),
- "value" => new external_value(PARAM_BOOL, "Enabled or disabled handler.")
- )
- ), "List of observed events.", VALUE_OPTIONAL
- )
- ), "Information about the service."
- )
- )
- );
- }
-
- /**
- * Update the record in the database.
- *
- * @param array $service
- * @return boolean
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function update_record($service) {
- $parameters = self::validate_parameters(self::update_record_parameters(), array("service" => $service));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- $result = false;
-
- if ($record = local_webhooks_get_record($parameters["service"]["id"])) {
- $record->enable = !empty($parameters["service"]["enable"]) ? $parameters["service"]["enable"] : $record->enable;
- $record->other = !empty($parameters["service"]["other"]) ? $parameters["service"]["other"] : $record->other;
- $record->title = !empty($parameters["service"]["title"]) ? $parameters["service"]["title"] : $record->title;
- $record->token = !empty($parameters["service"]["token"]) ? $parameters["service"]["token"] : $record->token;
- $record->type = !empty($parameters["service"]["type"]) ? $parameters["service"]["type"] : $record->type;
- $record->url = !empty($parameters["service"]["url"]) ? $parameters["service"]["url"] : $record->url;
-
- if (!empty($parameters["service"]["events"])) {
- $record->events = array();
-
- foreach ($parameters["service"]["events"] as $value) {
- $record->events[$value["name"]] = $value["value"];
- }
- }
-
- $result = local_webhooks_update_record($record);
- }
-
- return $result;
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function update_record_returns() {
- return new external_value(PARAM_BOOL, "Result of execution.");
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function delete_record_parameters() {
- return new external_function_parameters(
- array(
- "serviceid" => new external_value(PARAM_INT, "Service ID.")
- )
- );
- }
-
- /**
- * Delete the record from the database.
- *
- * @param number $serviceid
- * @return boolean
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function delete_record($serviceid) {
- $parameters = self::validate_parameters(self::delete_record_parameters(), array("serviceid" => $serviceid));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- return local_webhooks_delete_record($parameters["serviceid"]);
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function delete_record_returns() {
- return new external_value(PARAM_BOOL, "Result of execution.");
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function delete_all_records_parameters() {
- return new external_function_parameters(array());
- }
-
- /**
- * Delete all records from the database.
- *
- * @return boolean
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function delete_all_records() {
- $context = context_system::instance();
- self::validate_context($context);
-
- return local_webhooks_delete_all_records();
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function delete_all_records_returns() {
- return new external_value(PARAM_BOOL, "Result of execution.");
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function create_backup_parameters() {
- return new external_function_parameters(array());
- }
-
- /**
- * Create a backup.
- *
- * @return string
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function create_backup() {
- $context = context_system::instance();
- self::validate_context($context);
-
- return local_webhooks_create_backup();
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function create_backup_returns() {
- return new external_value(PARAM_RAW, "Backup copy.");
- }
-
- /**
- * Returns description of method parameters.
- *
- * @return external_function_parameters
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function restore_backup_parameters() {
- return new external_function_parameters(
- array(
- "options" => new external_single_structure(
- array(
- "backup" => new external_value(PARAM_RAW, "Backup copy."),
- "deleterecords" => new external_value(PARAM_BOOL, "Delete or leave all records.", VALUE_OPTIONAL)
- )
- )
- )
- );
- }
-
- /**
- * Restore from a backup.
- *
- * @param array $options
- * @since Moodle 2.9 Options available
- * @since Moodle 2.2
- */
- public static function restore_backup($options) {
- $parameters = self::validate_parameters(self::restore_backup_parameters(), array("options" => $options));
-
- $context = context_system::instance();
- self::validate_context($context);
-
- $deleterecords = !empty($parameters["options"]["deleterecords"]) ? $parameters["options"]["deleterecords"] : false;
- local_webhooks_restore_backup($parameters["options"]["backup"], $deleterecords);
- }
-
- /**
- * Returns description of method result value.
- *
- * @return external_description
- * @since Moodle 2.2
- */
- public static function restore_backup_returns() {
- return null;
- }
}