Added external function update existing service

Signed-off-by: Valentin Popov <info@valentineus.link>
This commit is contained in:
Valentin Popov 2019-05-11 03:45:50 +04:00
parent 3a865453a4
commit 7dc023b05a
Signed by: Valentin Popov
GPG Key ID: 269A00ACA90A8EA3
2 changed files with 149 additions and 14 deletions

View File

@ -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, '');
}
}

View File

@ -311,4 +311,76 @@ final class local_webhooks_external_testcase extends externallib_advanced_testca
self::assertNotEquals($service1['id'], $service2['id']);
}
/**
* Testing full update parameters of the service.
*
* @throws \ReflectionException
* @throws \coding_exception
* @throws \dml_exception
* @throws \invalid_parameter_exception
* @throws \restricted_context_exception
*/
public function test_updating_full() {
$this->resetAfterTest();
self::setAdminUser();
$record = self::get_random_record();
$record2 = self::get_random_record();
$record2->id = api::add_service($record);
$return = local_webhooks_external::set_service((array) $record2);
$return = external_api::validate_parameters(local_webhooks_external::set_service_returns(), $return);
self::assertInternalType('bool', $return);
$service = api::get_service($record2->id);
self::assertEquals($record2->id, $service->id);
self::assertEquals($record2->header, $service->header);
self::assertEquals($record2->name, $service->name);
self::assertEquals($record2->point, $service->point);
self::assertEquals($record2->status, $service->status);
self::assertEquals($record2->token, $service->token);
self::assertInternalType('array', $service->events);
self::assertCount(count($record2->events), $service->events);
foreach ($service->events as $event) {
self::assertContains($event, $record2->events);
}
}
/**
* Testing selective update parameters of the service.
*
* @throws \ReflectionException
* @throws \coding_exception
* @throws \dml_exception
* @throws \invalid_parameter_exception
* @throws \restricted_context_exception
*/
public function test_updating_short() {
$this->resetAfterTest();
self::setAdminUser();
$record = self::get_random_record();
$record2 = self::get_random_record();
$record->id = api::add_service($record);
$return = local_webhooks_external::set_service(['id' => $record->id, 'name' => $record2->name, 'point' => $record2->point]);
$return = external_api::validate_parameters(local_webhooks_external::set_service_returns(), $return);
self::assertInternalType('bool', $return);
$service = api::get_service($record->id);
self::assertEquals($record->header, $service->header);
self::assertEquals($record->id, $service->id);
self::assertEquals($record->status, $service->status);
self::assertEquals($record->token, $service->token);
self::assertEquals($record2->name, $service->name);
self::assertEquals($record2->point, $service->point);
self::assertInternalType('array', $service->events);
self::assertCount(count($record->events), $service->events);
foreach ($service->events as $event) {
self::assertContains($event, $record->events);
}
}
}