diff options
Diffstat (limited to 'apps/federation/lib/syncfederationaddressbooks.php')
-rw-r--r-- | apps/federation/lib/syncfederationaddressbooks.php | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/apps/federation/lib/syncfederationaddressbooks.php b/apps/federation/lib/syncfederationaddressbooks.php new file mode 100644 index 00000000000..cff848bf135 --- /dev/null +++ b/apps/federation/lib/syncfederationaddressbooks.php @@ -0,0 +1,55 @@ +<?php + +namespace OCA\Federation; + +use OCA\DAV\CardDAV\SyncService; +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Helper\ProgressBar; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Output\OutputInterface; + +class SyncFederationAddressBooks { + + /** @var DbHandler */ + protected $dbHandler; + + /** @var SyncService */ + private $syncService; + + /** + * @param DbHandler $dbHandler + */ + function __construct(DbHandler $dbHandler) { + + $this->syncService = \OC::$server->query('CardDAVSyncService'); + $this->dbHandler = $dbHandler; + } + + public function syncThemAll(\Closure $callback) { + + $trustedServers = $this->dbHandler->getAllServer(); + foreach ($trustedServers as $trustedServer) { + $url = $trustedServer['url']; + $callback($url); + $sharedSecret = $trustedServer['shared_secret']; + $syncToken = $trustedServer['sync_token']; + + if (is_null($sharedSecret)) { + continue; + } + $targetBookId = sha1($url); + $targetPrincipal = "principals/system/system"; + $targetBookProperties = [ + '{DAV:}displayname' => $url + ]; + try { + $newToken = $this->syncService->syncRemoteAddressBook($url, 'system', $sharedSecret, $syncToken, $targetPrincipal, $targetBookId, $targetBookProperties); + if ($newToken !== $syncToken) { + $this->dbHandler->setServerStatus($url, TrustedServers::STATUS_OK, $newToken); + } + } catch (\Exception $ex) { + $callback($url, $ex); + } + } + } +} |