chore(absence): Add capability for absence api

Signed-off-by: Marcel Müller <marcel-mueller@gmx.de>
This commit is contained in:
Marcel Müller 2024-12-01 22:22:38 +01:00
parent 0718ac7c92
commit 235e1fb878
4 changed files with 45 additions and 4 deletions

View file

@ -7,16 +7,19 @@ namespace OCA\DAV;
use OCP\Capabilities\ICapability;
use OCP\IConfig;
use OCP\User\IAvailabilityCoordinator;
class Capabilities implements ICapability {
private IConfig $config;
private IAvailabilityCoordinator $coordinator;
public function __construct(IConfig $config) {
public function __construct(IConfig $config, IAvailabilityCoordinator $coordinator) {
$this->config = $config;
$this->coordinator = $coordinator;
}
/**
* @return array{dav: array{chunking: string, bulkupload?: string}}
* @return array{dav: array{chunking: string, bulkupload?: string, absence-supported?: bool}}
*/
public function getCapabilities() {
$capabilities = [
@ -27,6 +30,9 @@ class Capabilities implements ICapability {
if ($this->config->getSystemValueBool('bulkupload.enabled', true)) {
$capabilities['dav']['bulkupload'] = '1.0';
}
if ($this->coordinator->isEnabled()) {
$capabilities['dav']['absence-supported'] = true;
}
return $capabilities;
}
}

View file

@ -37,6 +37,9 @@
},
"bulkupload": {
"type": "string"
},
"absence-supported": {
"type": "boolean"
}
}
}

View file

@ -16,6 +16,9 @@ use OCA\DAV\CalDAV\Reminder\NotificationTypeDoesNotExistException;
use OCA\DAV\Capabilities;
use Test\TestCase;
/**
* @group DB
*/
class NotificationProviderManagerTest extends TestCase {
/** @var NotificationProviderManager|\PHPUnit\Framework\MockObject\MockObject */

View file

@ -7,6 +7,7 @@ namespace OCA\DAV\Tests\unit;
use OCA\DAV\Capabilities;
use OCP\IConfig;
use OCP\User\IAvailabilityCoordinator;
use Test\TestCase;
/**
@ -19,7 +20,11 @@ class CapabilitiesTest extends TestCase {
->method('getSystemValueBool')
->with('bulkupload.enabled', $this->isType('bool'))
->willReturn(false);
$capabilities = new Capabilities($config);
$coordinator = $this->createMock(IAvailabilityCoordinator::class);
$coordinator->expects($this->once())
->method('isEnabled')
->willReturn(false);
$capabilities = new Capabilities($config, $coordinator);
$expected = [
'dav' => [
'chunking' => '1.0',
@ -34,7 +39,11 @@ class CapabilitiesTest extends TestCase {
->method('getSystemValueBool')
->with('bulkupload.enabled', $this->isType('bool'))
->willReturn(true);
$capabilities = new Capabilities($config);
$coordinator = $this->createMock(IAvailabilityCoordinator::class);
$coordinator->expects($this->once())
->method('isEnabled')
->willReturn(false);
$capabilities = new Capabilities($config, $coordinator);
$expected = [
'dav' => [
'chunking' => '1.0',
@ -43,4 +52,24 @@ class CapabilitiesTest extends TestCase {
];
$this->assertSame($expected, $capabilities->getCapabilities());
}
public function testGetCapabilitiesWithAbsence(): void {
$config = $this->createMock(IConfig::class);
$config->expects($this->once())
->method('getSystemValueBool')
->with('bulkupload.enabled', $this->isType('bool'))
->willReturn(false);
$coordinator = $this->createMock(IAvailabilityCoordinator::class);
$coordinator->expects($this->once())
->method('isEnabled')
->willReturn(true);
$capabilities = new Capabilities($config, $coordinator);
$expected = [
'dav' => [
'chunking' => '1.0',
'absence-supported' => true,
],
];
$this->assertSame($expected, $capabilities->getCapabilities());
}
}