. /** * 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 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, "Service status filter switch.", VALUE_OPTIONAL) ) ); } /** * 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 = false) { $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"])) { 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 search_services_by_event_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 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 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, "Event name.") ); } /** * 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( "options" => new external_single_structure( array( "backup" => new external_value(PARAM_TEXT, "Backup copy."), "deleterecords" => new external_value(PARAM_BOOL, "Delete existing 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 = array()) { $parameters = self::validate_parameters(self::restore_backup_parameters(), array("options" => $options)); $context = context_system::instance(); self::validate_context($context); $deleterecords = !empty($parameters["options"]["deleterecords"]) ? boolval($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; } }