Skip to content

Commit

Permalink
create a user's birthday calendar right after they requested it
Browse files Browse the repository at this point in the history
Signed-off-by: Georg Ehrke <developer@georgehrke.com>
  • Loading branch information
georgehrke committed Nov 11, 2017
1 parent 4d5ed13 commit 4d3f33c
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 4 deletions.
Empty file.
11 changes: 10 additions & 1 deletion apps/dav/lib/CalDAV/BirthdayCalendar/EnablePlugin.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

namespace OCA\DAV\CalDAV\BirthdayCalendar;

use OCA\DAV\CalDAV\BirthdayService;
use OCA\DAV\CalDAV\CalendarHome;
use Sabre\DAV\Server;
use Sabre\DAV\ServerPlugin;
Expand All @@ -44,6 +45,11 @@ class EnablePlugin extends ServerPlugin {
*/
protected $config;

/**
* @var BirthdayService
*/
protected $birthdayService;

/**
* @var Server
*/
Expand All @@ -53,9 +59,11 @@ class EnablePlugin extends ServerPlugin {
* PublishPlugin constructor.
*
* @param IConfig $config
* @param BirthdayService $birthdayService
*/
public function __construct(IConfig $config) {
public function __construct(IConfig $config, BirthdayService $birthdayService) {
$this->config = $config;
$this->birthdayService = $birthdayService;
}

/**
Expand Down Expand Up @@ -122,6 +130,7 @@ public function httpPost(RequestInterface $request, ResponseInterface $response)
$userId = substr($principalUri, 17);

$this->config->setUserValue($userId, 'dav', 'generateBirthdayCalendar', 'yes');
$this->birthdayService->syncUser($userId);

$this->server->httpResponse->setStatus(204);

Expand Down
4 changes: 3 additions & 1 deletion apps/dav/lib/Server.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
namespace OCA\DAV;

use OC\AppFramework\Utility\TimeFactory;
use OCA\DAV\CalDAV\BirthdayService;
use OCA\DAV\CalDAV\Schedule\IMipPlugin;
use OCA\DAV\CardDAV\ImageExportPlugin;
use OCA\DAV\CardDAV\PhotoCache;
Expand Down Expand Up @@ -260,7 +261,8 @@ public function __construct(IRequest $request, $baseUri) {
)));
}
$this->server->addPlugin(new \OCA\DAV\CalDAV\BirthdayCalendar\EnablePlugin(
\OC::$server->getConfig()
\OC::$server->getConfig(),
\OC::$server->query(BirthdayService::class)
));
}

Expand Down
19 changes: 17 additions & 2 deletions apps/dav/tests/unit/CalDAV/BirthdayCalendar/EnablePluginTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
namespace OCA\DAV\Tests\unit\CalDAV\BirthdayCalendar;

use OCA\DAV\CalDAV\BirthdayCalendar\EnablePlugin;
use OCA\DAV\CalDAV\BirthdayService;
use OCA\DAV\CalDAV\Calendar;
use OCA\DAV\CalDAV\CalendarHome;
use OCP\IConfig;
Expand All @@ -35,6 +36,9 @@ class EnablePluginTest extends TestCase {
/** @var \OCP\IConfig|\PHPUnit_Framework_MockObject_MockObject */
protected $config;

/** @var BirthdayService |\PHPUnit_Framework_MockObject_MockObject */
protected $birthdayService;

/** @var \OCA\DAV\CalDAV\BirthdayCalendar\EnablePlugin $plugin */
protected $plugin;

Expand All @@ -51,8 +55,9 @@ public function setUp() {
$this->server->xml = $this->createMock(\Sabre\DAV\Xml\Service::class);

$this->config = $this->createMock(IConfig::class);
$this->birthdayService = $this->createMock(BirthdayService::class);

$this->plugin = new EnablePlugin($this->config);
$this->plugin = new EnablePlugin($this->config, $this->birthdayService);
$this->plugin->initialize($this->server);

$this->request = $this->createMock(\Sabre\HTTP\RequestInterface::class);
Expand All @@ -70,7 +75,7 @@ public function testGetName() {
public function testInitialize() {
$server = $this->createMock(\Sabre\DAV\Server::class);

$plugin = new EnablePlugin($this->config);
$plugin = new EnablePlugin($this->config, $this->birthdayService);

$server->expects($this->at(0))
->method('on')
Expand All @@ -93,6 +98,9 @@ public function testHttpPostNoCalendarHome() {
$this->config->expects($this->never())
->method('setUserValue');

$this->birthdayService->expects($this->never())
->method('syncUser');

$this->plugin->httpPost($this->request, $this->response);
}

Expand Down Expand Up @@ -124,6 +132,9 @@ public function testHttpPostWrongRequest() {
$this->config->expects($this->never())
->method('setUserValue');

$this->birthdayService->expects($this->never())
->method('syncUser');

$this->plugin->httpPost($this->request, $this->response);
}

Expand Down Expand Up @@ -160,6 +171,10 @@ public function testHttpPost() {
->method('setUserValue')
->with('BlaBlub', 'dav', 'generateBirthdayCalendar', 'yes');

$this->birthdayService->expects($this->once())
->method('syncUser')
->with('BlaBlub');

$this->server->httpResponse->expects($this->once())
->method('setStatus')
->with(204);
Expand Down

0 comments on commit 4d3f33c

Please sign in to comment.