From 6e3bf072af2bf9d31c93f08a7b553fd614ae11b7 Mon Sep 17 00:00:00 2001 From: Valentin Popov Date: Wed, 27 Dec 2017 15:26:59 +0400 Subject: Added external plugin functions --- externallib.php | 541 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 541 insertions(+) create mode 100644 externallib.php diff --git a/externallib.php b/externallib.php new file mode 100644 index 0000000..cbe89dd --- /dev/null +++ b/externallib.php @@ -0,0 +1,541 @@ +. + +/** + * This file defines the plugin's external functions. + * + * @package local_webhooks + * @copyright 2017 "Valentin Popov" + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +defined("MOODLE_INTERNAL") || die(); + +require_once(__DIR__ . "/lib.php"); + +require_once($CFG->libdir . "/externallib.php"); + +/** + * External functions. + * + * @copyright 2017 "Valentin Popov" + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ +class local_webhooks_external extends external_api { + /** + * 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 identifier.") + ) + ); + } + + /** + * 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 = 0) { + $parameters = self::validate_parameters(self::change_status_parameters(), array("serviceid" => $serviceid)); + + $context = context_system::instance(); + self::validate_context($context); + + $result = local_webhooks_change_status($parameters["serviceid"]); + return $result; + } + + /** + * 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, "The result of the operation."); + } + + /** + * 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 identifier.") + ) + ); + } + + /** + * 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 = 0) { + $parameters = self::validate_parameters(self::get_record_parameters(), array("serviceid" => $serviceid)); + + $context = context_system::instance(); + self::validate_context($context); + + $service = array(); + if ($record = local_webhooks_get_record($parameters["serviceid"])) { + $service["enable"] = $record->enable; + $service["id"] = $record->id; + $service["other"] = $record->other; + $service["title"] = $record->title; + $service["token"] = $record->token; + $service["type"] = $record->type; + $service["url"] = $record->url; + + $service["events"] = array(); + foreach ($record->events as $key => $value) { + $service["events"][] = array("name" => $key, "value" => $value); + } + } + + return $service; + } + + /** + * Returns description of method result value. + * + * @return external_description + * @since Moodle 2.2 + */ + public static function get_record_returns() { + return new external_single_structure( + array( + "id" => new external_value(PARAM_INT, "Service identifier."), + "enable" => new external_value(PARAM_INT, "Service status."), + "title" => new external_value(PARAM_TEXT, "Name of the service."), + "url" => new external_value(PARAM_URL, "URL address."), + "type" => new external_value(PARAM_TEXT, "Header type."), + "token" => new external_value(PARAM_TEXT, "Authorization key.", VALUE_OPTIONAL), + "other" => new external_value(PARAM_TEXT, "Additional field.", VALUE_OPTIONAL), + "events" => new external_multiple_structure( + new external_single_structure( + array( + "name" => new external_value(PARAM_TEXT, "Event name."), + "value" => new external_value(PARAM_INT, "Observation status.") + ) + ), "Observed events.", VALUE_OPTIONAL + ) + ), "Record about the service." + ); + } + + /** + * 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()); + } + + /** + * Get all records from the database. + * + * @return array + * @since Moodle 2.9 Options available + * @since Moodle 2.2 + */ + public static function get_list_records() { + $context = context_system::instance(); + self::validate_context($context); + + $result = array(); + if ($listrecords = local_webhooks_get_list_records()) { + foreach ($listrecords as $index => $record) { + $result[$index]["enable"] = $record->enable; + $result[$index]["id"] = $record->id; + $result[$index]["other"] = $record->other; + $result[$index]["title"] = $record->title; + $result[$index]["token"] = $record->token; + $result[$index]["type"] = $record->type; + $result[$index]["url"] = $record->url; + + $result[$index]["events"] = array(); + foreach ($record->events as $key => $value) { + $result[$index]["events"][] = array("name" => $key, "value" => $value); + } + } + } + + 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( + new external_single_structure( + array( + "id" => new external_value(PARAM_INT, "Service identifier."), + "enable" => new external_value(PARAM_INT, "Service status."), + "title" => new external_value(PARAM_TEXT, "Name of the service."), + "url" => new external_value(PARAM_URL, "URL address."), + "type" => new external_value(PARAM_TEXT, "Header type."), + "token" => new external_value(PARAM_TEXT, "Authorization key.", VALUE_OPTIONAL), + "other" => new external_value(PARAM_TEXT, "Additional field.", VALUE_OPTIONAL), + "events" => new external_multiple_structure( + new external_single_structure( + array( + "name" => new external_value(PARAM_TEXT, "Event name."), + "value" => new external_value(PARAM_INT, "Observation status.") + ) + ), "Observed events.", VALUE_OPTIONAL + ) + ), "Record about the service." + ), "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 create_record_parameters() { + return new external_function_parameters( + array( + "service" => new external_single_structure( + array( + "enable" => new external_value(PARAM_BOOL, "Service status.", VALUE_OPTIONAL), + "title" => new external_value(PARAM_TEXT, "Name of the service."), + "url" => new external_value(PARAM_URL, "URL address."), + "type" => new external_value(PARAM_TEXT, "Header type.", VALUE_OPTIONAL), + "token" => new external_value(PARAM_TEXT, "Authorization key.", VALUE_OPTIONAL), + "other" => new external_value(PARAM_TEXT, "Additional field.", VALUE_OPTIONAL), + "events" => new external_multiple_structure( + new external_single_structure( + array( + "name" => new external_value(PARAM_TEXT, "Event name."), + "value" => new external_value(PARAM_INT, "Observation status.") + ) + ), "Observed events.", VALUE_OPTIONAL + ) + ), "Record about the service." + ) + ) + ); + } + + /** + * Create an entry in the database. + * + * @param array $service + * @return number + * @since Moodle 2.9 Options available + * @since Moodle 2.2 + */ + public static function create_record($service = array()) { + $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->enable = !empty($parameters["service"]["enable"]) ? $parameters["service"]["enable"] : false; + $record->type = !empty($parameters["service"]["type"]) ? $parameters["service"]["type"] : "json"; + + $record->events = array(); + foreach ($parameters["service"]["events"] as $value) { + $record->events[$value["name"]] = $value["value"]; + } + + $result = local_webhooks_create_record($record); + return $result; + } + + /** + * Returns description of method result value. + * + * @return external_description + * @since Moodle 2.2 + */ + public static function create_record_returns() { + return new external_value(PARAM_INT, "Service identifier."); + } + + /** + * 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( + "id" => new external_value(PARAM_INT, "Service identifier."), + "service" => new external_single_structure( + array( + "enable" => new external_value(PARAM_BOOL, "Service status.", VALUE_OPTIONAL), + "title" => new external_value(PARAM_TEXT, "Name of the service.", VALUE_OPTIONAL), + "url" => new external_value(PARAM_URL, "URL address.", VALUE_OPTIONAL), + "type" => new external_value(PARAM_TEXT, "Header type.", VALUE_OPTIONAL), + "token" => new external_value(PARAM_TEXT, "Authorization key.", VALUE_OPTIONAL), + "other" => new external_value(PARAM_TEXT, "Additional field.", VALUE_OPTIONAL), + "events" => new external_multiple_structure( + new external_single_structure( + array( + "name" => new external_value(PARAM_TEXT, "Event name."), + "value" => new external_value(PARAM_INT, "Observation status.") + ) + ), "Observed events.", VALUE_OPTIONAL + ) + ), "Record about the service." + ) + ) + ); + } + + /** + * Update the record in the database. + * + * @param number $serviceid + * @param array $service + * @return boolean + * @since Moodle 2.9 Options available + * @since Moodle 2.2 + */ + public static function update_record($serviceid = 0, $service = array()) { + $parameters = self::validate_parameters(self::update_record_parameters(), array("id" => $serviceid, "service" => $service)); + + $context = context_system::instance(); + self::validate_context($context); + + $result = false; + if ($record = local_webhooks_get_record($parameters["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, "The result of the operation."); + } + + /** + * 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 identifier.") + ) + ); + } + + /** + * 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 = 0) { + $parameters = self::validate_parameters(self::delete_record_parameters(), array("serviceid" => $serviceid)); + + $context = context_system::instance(); + self::validate_context($context); + + $result = local_webhooks_delete_record($parameters["serviceid"]); + return $result; + } + + /** + * 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, "The result of the operation."); + } + + /** + * 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); + + $result = local_webhooks_delete_all_records(); + return $result; + } + + /** + * 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, "The result of the operation."); + } + + /** + * 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); + + $result = local_webhooks_create_backup(); + return $result; + } + + /** + * Returns description of method result value. + * + * @return external_description + * @since Moodle 2.2 + */ + public static function create_backup_returns() { + return new external_value(PARAM_TEXT, "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( + "backup" => new external_value(PARAM_TEXT, "Backup copy."), + "deleterecords" => new external_value(PARAM_BOOL, "Delete existing records.") + ) + ); + } + + /** + * Restore from a backup. + * + * @param string $data + * @param boolean $deleterecords + * @since Moodle 2.9 Options available + * @since Moodle 2.2 + */ + public static function restore_backup($backup = "", $deleterecords = false) { + $parameters = self::validate_parameters(self::restore_backup_parameters(), array("backup" => $backup, "deleterecords" => $deleterecords)); + + $context = context_system::instance(); + self::validate_context($context); + + local_webhooks_restore_backup($parameters["backup"], $parameters["deleterecords"]); + } + + /** + * Returns description of method result value. + * + * @return external_description + * @since Moodle 2.2 + */ + public static function restore_backup_returns() { + return null; + } +} \ No newline at end of file -- cgit v1.2.3