mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-07 20:40:28 +01:00
103 lines
3.0 KiB
PHP
103 lines
3.0 KiB
PHP
|
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
namespace Xentral\Modules\GoogleCalendar\Service;
|
||
|
|
||
|
use Xentral\Components\Database\Database;
|
||
|
use Xentral\Modules\GoogleCalendar\Data\GoogleCalenderSyncValue;
|
||
|
|
||
|
final class GoogleSyncService
|
||
|
{
|
||
|
/** @var Database $db */
|
||
|
private $db;
|
||
|
|
||
|
/** @var GoogleSyncGateway $gateway */
|
||
|
private $gateway;
|
||
|
|
||
|
/**
|
||
|
* @param Database $database
|
||
|
* @param GoogleSyncGateway $gateway
|
||
|
*/
|
||
|
public function __construct(Database $database, GoogleSyncGateway $gateway)
|
||
|
{
|
||
|
$this->db = $database;
|
||
|
$this->gateway = $gateway;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param GoogleCalenderSyncValue $sync
|
||
|
*
|
||
|
* @return int new Id
|
||
|
*/
|
||
|
public function saveSyncEntry(GoogleCalenderSyncValue $sync): int
|
||
|
{
|
||
|
if ($sync->getId() > 0 && $this->gateway->existsSyncEntry($sync->getId())) {
|
||
|
return $this->updateSyncEntry($sync);
|
||
|
}
|
||
|
|
||
|
return $this->insertSyncEntry($sync);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $googleEventId
|
||
|
* @param int $calendarEventId
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function deleteSyncEntry(string $googleEventId, int $calendarEventId): void
|
||
|
{
|
||
|
$sql = 'DELETE FROM `googleapi_calendar_sync` WHERE `foreign_id` = :foreign_id AND `event_id` = :event_id';
|
||
|
$values = ['foreign_id' => $googleEventId, 'event_id' => $calendarEventId];
|
||
|
$this->db->perform($sql, $values);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param GoogleCalenderSyncValue $sync
|
||
|
*
|
||
|
* @return int
|
||
|
*/
|
||
|
private function insertSyncEntry(GoogleCalenderSyncValue $sync): int
|
||
|
{
|
||
|
$sql = 'INSERT INTO `googleapi_calendar_sync`
|
||
|
(`event_id`, `foreign_id`, `owner`, `from_google`, `event_date`, `html_link`) VALUES
|
||
|
(:event_id, :foreign_id, :owner, :from_google, :event_date, :html_link)';
|
||
|
$values = [
|
||
|
'event_id' => $sync->getEventId(),
|
||
|
'foreign_id' => $sync->getGoogleId(),
|
||
|
'owner' => $sync->getOwner(),
|
||
|
'from_google' => (int)$sync->isFromGoogle(),
|
||
|
'event_date' => $sync->getEventDateAsString(),
|
||
|
'html_link' => $sync->getHtmlLink(),
|
||
|
];
|
||
|
$this->db->perform($sql, $values);
|
||
|
|
||
|
return $this->db->lastInsertId();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param GoogleCalenderSyncValue $sync
|
||
|
*
|
||
|
* @return int updated Id
|
||
|
*/
|
||
|
private function updateSyncEntry(GoogleCalenderSyncValue $sync): int
|
||
|
{
|
||
|
$sql = 'UPDATE `googleapi_calendar_sync`
|
||
|
SET `event_id` = :event_id,
|
||
|
`foreign_id` = :foreign_id,
|
||
|
`event_date` = :event_date,
|
||
|
`owner` = :owner
|
||
|
WHERE `id` = :id';
|
||
|
$values = [
|
||
|
'id' => $sync->getId(),
|
||
|
'event_id' => $sync->getEventId(),
|
||
|
'foreign_id' => $sync->getGoogleId(),
|
||
|
'event_date' => $sync->getEventDateAsString(),
|
||
|
'owner' => $sync->getOwner(),
|
||
|
];
|
||
|
$this->db->fetchAffected($sql, $values);
|
||
|
|
||
|
return $sync->getId();
|
||
|
}
|
||
|
}
|