]> source.dussan.org Git - nextcloud-server.git/commitdiff
Add a repair step to remove sensitive event activity
authorJoas Schilling <coding@schilljs.com>
Tue, 8 Jan 2019 17:39:40 +0000 (18:39 +0100)
committerJoas Schilling <coding@schilljs.com>
Wed, 9 Jan 2019 12:19:12 +0000 (13:19 +0100)
Signed-off-by: Joas Schilling <coding@schilljs.com>
apps/dav/appinfo/info.xml
apps/dav/composer/composer/autoload_classmap.php
apps/dav/composer/composer/autoload_static.php
apps/dav/lib/Migration/RemoveClassifiedEventActivity.php [new file with mode: 0644]

index 9e0779a934d046a5ccd1035a5a58f8edb0ef5248..43034e5a40c54789b7d806672319c471717e7432 100644 (file)
@@ -5,7 +5,7 @@
        <name>WebDAV</name>
        <summary>WebDAV endpoint</summary>
        <description>WebDAV endpoint</description>
-       <version>1.6.0</version>
+       <version>1.6.1</version>
        <licence>agpl</licence>
        <author>owncloud.org</author>
        <namespace>DAV</namespace>
@@ -30,6 +30,7 @@
                        <step>OCA\DAV\Migration\FixBirthdayCalendarComponent</step>
                        <step>OCA\DAV\Migration\CalDAVRemoveEmptyValue</step>
                        <step>OCA\DAV\Migration\BuildCalendarSearchIndex</step>
+                       <step>OCA\DAV\Migration\RemoveClassifiedEventActivity</step>
                </post-migration>
        </repair-steps>
 
index b03e866ab543ee68a1b8f6d1274257edab553e76..cac3b7b83de97a5005ee79fe1d32c288ca4f3e2b 100644 (file)
@@ -148,6 +148,7 @@ return array(
     'OCA\\DAV\\Migration\\BuildCalendarSearchIndexBackgroundJob' => $baseDir . '/../lib/Migration/BuildCalendarSearchIndexBackgroundJob.php',
     'OCA\\DAV\\Migration\\CalDAVRemoveEmptyValue' => $baseDir . '/../lib/Migration/CalDAVRemoveEmptyValue.php',
     'OCA\\DAV\\Migration\\FixBirthdayCalendarComponent' => $baseDir . '/../lib/Migration/FixBirthdayCalendarComponent.php',
+    'OCA\\DAV\\Migration\\RemoveClassifiedEventActivity' => $baseDir . '/../lib/Migration/RemoveClassifiedEventActivity.php',
     'OCA\\DAV\\Migration\\Version1004Date20170825134824' => $baseDir . '/../lib/Migration/Version1004Date20170825134824.php',
     'OCA\\DAV\\Migration\\Version1004Date20170919104507' => $baseDir . '/../lib/Migration/Version1004Date20170919104507.php',
     'OCA\\DAV\\Migration\\Version1004Date20170924124212' => $baseDir . '/../lib/Migration/Version1004Date20170924124212.php',
index 0d4c880138265074d22ba8d1e5ac4cc60a7b57f7..8fb92e2e5100330b1b14579256e08039c2d13dad 100644 (file)
@@ -163,6 +163,7 @@ class ComposerStaticInitDAV
         'OCA\\DAV\\Migration\\BuildCalendarSearchIndexBackgroundJob' => __DIR__ . '/..' . '/../lib/Migration/BuildCalendarSearchIndexBackgroundJob.php',
         'OCA\\DAV\\Migration\\CalDAVRemoveEmptyValue' => __DIR__ . '/..' . '/../lib/Migration/CalDAVRemoveEmptyValue.php',
         'OCA\\DAV\\Migration\\FixBirthdayCalendarComponent' => __DIR__ . '/..' . '/../lib/Migration/FixBirthdayCalendarComponent.php',
+        'OCA\\DAV\\Migration\\RemoveClassifiedEventActivity' => __DIR__ . '/..' . '/../lib/Migration/RemoveClassifiedEventActivity.php',
         'OCA\\DAV\\Migration\\Version1004Date20170825134824' => __DIR__ . '/..' . '/../lib/Migration/Version1004Date20170825134824.php',
         'OCA\\DAV\\Migration\\Version1004Date20170919104507' => __DIR__ . '/..' . '/../lib/Migration/Version1004Date20170919104507.php',
         'OCA\\DAV\\Migration\\Version1004Date20170924124212' => __DIR__ . '/..' . '/../lib/Migration/Version1004Date20170924124212.php',
diff --git a/apps/dav/lib/Migration/RemoveClassifiedEventActivity.php b/apps/dav/lib/Migration/RemoveClassifiedEventActivity.php
new file mode 100644 (file)
index 0000000..1f1edf2
--- /dev/null
@@ -0,0 +1,124 @@
+<?php
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2019 Joas Schilling <coding@schilljs.com>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCA\DAV\Migration;
+
+use OCA\DAV\CalDAV\CalDavBackend;
+use OCP\IDBConnection;
+use OCP\Migration\IOutput;
+use OCP\Migration\IRepairStep;
+
+class RemoveClassifiedEventActivity implements IRepairStep {
+
+       /** @var IDBConnection */
+       private $connection;
+
+       public function __construct(IDBConnection $connection) {
+               $this->connection = $connection;
+       }
+
+       /**
+        * @inheritdoc
+        */
+       public function getName() {
+               return 'Remove activity entries of private events';
+       }
+
+       /**
+        * @inheritdoc
+        */
+       public function run(IOutput $output) {
+               if (!$this->connection->tableExists('activity')) {
+                       return;
+               }
+
+               $deletedEvents = $this->removePrivateEventActivity();
+               $deletedEvents += $this->removeConfidentialUncensoredEventActivity();
+
+               $output->info("Removed $deletedEvents activity entries");
+       }
+
+       protected function removePrivateEventActivity(): int {
+               $deletedEvents = 0;
+
+               $delete = $this->connection->getQueryBuilder();
+               $delete->delete('activity')
+                       ->where($delete->expr()->neq('affecteduser', $delete->createParameter('owner')))
+                       ->andWhere($delete->expr()->eq('object_type', $delete->createParameter('type')))
+                       ->andWhere($delete->expr()->eq('object_id', $delete->createParameter('calendar_id')))
+                       ->andWhere($delete->expr()->like('subjectparams', $delete->createParameter('event_uid')));
+
+               $query = $this->connection->getQueryBuilder();
+               $query->select('c.principaluri', 'o.calendarid', 'o.uid')
+                       ->from('calendarobjects', 'o')
+                       ->leftJoin('o', 'calendars', 'c', $query->expr()->eq('c.id', 'o.calendarid'))
+                       ->where($query->expr()->eq('o.classification', $query->createNamedParameter(CalDavBackend::CLASSIFICATION_PRIVATE)));
+               $result = $query->execute();
+
+               while ($row = $result->fetch()) {
+                       $delete->setParameter('owner', $this->getPrincipal($row['principaluri']))
+                               ->setParameter('type', 'calendar')
+                               ->setParameter('calendar_id', $row['calendarid'])
+                               ->setParameter('event_uid', '%' . $this->connection->escapeLikeParameter('{"id":"' . $row['uid'] . '"') . '%');
+                       $deletedEvents += $delete->execute();
+               }
+               $result->closeCursor();
+
+               return $deletedEvents;
+       }
+
+       protected function removeConfidentialUncensoredEventActivity(): int {
+               $deletedEvents = 0;
+
+               $delete = $this->connection->getQueryBuilder();
+               $delete->delete('activity')
+                       ->where($delete->expr()->neq('affecteduser', $delete->createParameter('owner')))
+                       ->andWhere($delete->expr()->eq('object_type', $delete->createParameter('type')))
+                       ->andWhere($delete->expr()->eq('object_id', $delete->createParameter('calendar_id')))
+                       ->andWhere($delete->expr()->like('subjectparams', $delete->createParameter('event_uid')))
+                       ->andWhere($delete->expr()->notLike('subjectparams', $delete->createParameter('filtered_name')));
+
+               $query = $this->connection->getQueryBuilder();
+               $query->select('c.principaluri', 'o.calendarid', 'o.uid')
+                       ->from('calendarobjects', 'o')
+                       ->leftJoin('o', 'calendars', 'c', $query->expr()->eq('c.id', 'o.calendarid'))
+                       ->where($query->expr()->eq('o.classification', $query->createNamedParameter(CalDavBackend::CLASSIFICATION_CONFIDENTIAL)));
+               $result = $query->execute();
+
+               while ($row = $result->fetch()) {
+                       $delete->setParameter('owner', $this->getPrincipal($row['principaluri']))
+                               ->setParameter('type', 'calendar')
+                               ->setParameter('calendar_id', $row['calendarid'])
+                               ->setParameter('event_uid', '%' . $this->connection->escapeLikeParameter('{"id":"' . $row['uid'] . '"') . '%')
+                               ->setParameter('filtered_name', '%' . $this->connection->escapeLikeParameter('{"id":"' . $row['uid'] . '","name":"Busy"') . '%');
+                       $deletedEvents += $delete->execute();
+               }
+               $result->closeCursor();
+
+               return $deletedEvents;
+       }
+
+       protected function getPrincipal(string $principalUri): string {
+               $uri = explode('/', $principalUri);
+               return $uri[2];
+       }
+}