From 7dc023b05a9292cb9e5ea4fa65e86668c857cd82 Mon Sep 17 00:00:00 2001 From: Valentin Popov Date: Sat, 11 May 2019 03:45:50 +0400 Subject: Added external function update existing service Signed-off-by: Valentin Popov --- externallib.php | 91 ++++++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 77 insertions(+), 14 deletions(-) (limited to 'externallib.php') diff --git a/externallib.php b/externallib.php index d6e3604..1e4884a 100644 --- a/externallib.php +++ b/externallib.php @@ -45,17 +45,13 @@ final class local_webhooks_external extends external_api { */ public static function add_service(array $conditions): int { $parameters = self::validate_parameters(self::add_service_parameters(), [ - 'events' => $conditions['events'], - 'header' => $conditions['header'], - 'name' => $conditions['name'], - 'point' => $conditions['point'], - 'status' => $conditions['status'], - 'token' => $conditions['token'], + 'record' => array_filter($conditions), ]); $context = context_system::instance(); self::validate_context($context); + $parameters = array_filter($parameters['record']); $record = new record($parameters); return api::add_service($record); @@ -68,14 +64,16 @@ final class local_webhooks_external extends external_api { */ public static function add_service_parameters(): external_function_parameters { return new external_function_parameters([ - 'events' => new external_multiple_structure( - new external_value(PARAM_RAW, 'The event\'s name.'), 'The service\'s list events.' - ), - 'header' => new external_value(PARAM_RAW, 'The request\'s header or type'), - 'name' => new external_value(PARAM_RAW, 'The service\'s name.'), - 'point' => new external_value(PARAM_URL, 'The service\'s endpoint.'), - 'status' => new external_value(PARAM_BOOL, 'The service\'s status.'), - 'token' => new external_value(PARAM_RAW, 'The service\'s secret key.'), + 'record' => new external_single_structure([ + 'events' => new external_multiple_structure( + new external_value(PARAM_RAW, 'The event\'s name.'), 'The service\'s list events.', false + ), + 'header' => new external_value(PARAM_RAW, 'The request\'s header or type', false, 'application/json'), + 'name' => new external_value(PARAM_RAW, 'The service\'s name.'), + 'point' => new external_value(PARAM_URL, 'The service\'s endpoint.'), + 'status' => new external_value(PARAM_BOOL, 'The service\'s status.', false, true), + 'token' => new external_value(PARAM_RAW, 'The service\'s secret key.'), + ], ''), ], ''); } @@ -300,4 +298,69 @@ final class local_webhooks_external extends external_api { ], ''), '' ); } + + /** + * Update the existing service. + * + * @param array $conditions + * + * @return bool + * + * @throws \coding_exception + * @throws \dml_exception + * @throws \invalid_parameter_exception + * @throws \restricted_context_exception + */ + public static function set_service(array $conditions): bool { + $conditions = array_filter($conditions); + $conditions['events'] = $conditions['events'] ?? []; + + $parameters = self::validate_parameters(self::set_service_parameters(), [ + 'record' => $conditions, + ]); + + $context = context_system::instance(); + self::validate_context($context); + + $parameters = array_filter($parameters['record']); + $record = api::get_service($parameters['id']); + + foreach ($parameters as $index => $value) { + if (property_exists($record, $index)) { + $record->$index = $value; + } + } + + return api::set_service($record); + } + + /** + * Returns description of the method parameters. + * + * @return \external_function_parameters + */ + public static function set_service_parameters(): external_function_parameters { + return new external_function_parameters([ + 'record' => new external_single_structure([ + 'events' => new external_multiple_structure( + new external_value(PARAM_RAW, 'The event\'s name.'), 'The service\'s list events.', false + ), + 'header' => new external_value(PARAM_RAW, 'The request\'s header or type', false), + 'id' => new external_value(PARAM_INT, 'The service\'s ID.'), + 'name' => new external_value(PARAM_RAW, 'The service\'s name.', false), + 'point' => new external_value(PARAM_URL, 'The service\'s endpoint.', false), + 'status' => new external_value(PARAM_BOOL, 'The service\'s status.', false), + 'token' => new external_value(PARAM_RAW, 'The service\'s secret key.', false), + ], ''), + ], ''); + } + + /** + * Returns description of the method result value. + * + * @return \external_value + */ + public static function set_service_returns(): external_value { + return new external_value(PARAM_BOOL, ''); + } } \ No newline at end of file -- cgit v1.2.3