mirror of
https://github.com/moodle/moodle.git
synced 2025-08-04 08:26:37 +02:00
MDL-72464 webservice: fix detection of non-expiring external tokens.
This commit is contained in:
parent
e746dc75af
commit
797cff78d5
4 changed files with 76 additions and 3 deletions
|
@ -866,7 +866,7 @@ class webservice {
|
|||
|
||||
$sql = 'SELECT t.*, s.name as servicename FROM {external_tokens} t JOIN
|
||||
{external_services} s ON t.externalserviceid = s.id WHERE
|
||||
t.userid = :userid AND (t.validuntil IS NULL OR t.validuntil > :now)';
|
||||
t.userid = :userid AND (COALESCE(t.validuntil, 0) = 0 OR t.validuntil > :now)';
|
||||
$params = array('userid' => $userid, 'now' => time());
|
||||
return $DB->get_records_sql($sql, $params);
|
||||
}
|
||||
|
|
|
@ -49,6 +49,7 @@ class core_webservice_generator extends component_generator_base {
|
|||
}
|
||||
|
||||
$optionalfields = [
|
||||
'enabled' => false,
|
||||
'requiredcapability' => '',
|
||||
'restrictedusers' => 0,
|
||||
'component' => '',
|
||||
|
|
|
@ -252,6 +252,47 @@ class webservice_test extends advanced_testcase {
|
|||
$this->assertContains('moodle/course:managegroups', $missing[$user3->id]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Data provider for {@see test_get_active_tokens}
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function get_active_tokens_provider(): array {
|
||||
return [
|
||||
'No expiration' => [0, true],
|
||||
'Active' => [time() + DAYSECS, true],
|
||||
'Expired' => [time() - DAYSECS, false],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Test getting active tokens for a user
|
||||
*
|
||||
* @param int $validuntil
|
||||
* @param bool $expectedactive
|
||||
*
|
||||
* @dataProvider get_active_tokens_provider
|
||||
*/
|
||||
public function test_get_active_tokens(int $validuntil, bool $expectedactive): void {
|
||||
$this->resetAfterTest();
|
||||
|
||||
$user = $this->getDataGenerator()->create_user();
|
||||
|
||||
/** @var core_webservice_generator $generator */
|
||||
$generator = $this->getDataGenerator()->get_plugin_generator('core_webservice');
|
||||
|
||||
$service = $generator->create_service(['name' => 'My test service', 'shortname' => 'mytestservice']);
|
||||
$generator->create_token(['userid' => $user->id, 'service' => $service->shortname, 'validuntil' => $validuntil]);
|
||||
|
||||
$tokens = webservice::get_active_tokens($user->id);
|
||||
if ($expectedactive) {
|
||||
$this->assertCount(1, $tokens);
|
||||
$this->assertEquals($service->id, reset($tokens)->externalserviceid);
|
||||
} else {
|
||||
$this->assertEmpty($tokens);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Utility method that tests the parameter type of a method info's input/output parameter.
|
||||
*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue