]> git.mxchange.org Git - friendica.git/commitdiff
Issue 10365: Event updates are now processed
authorMichael <heluecht@pirati.ca>
Sat, 5 Feb 2022 11:16:50 +0000 (11:16 +0000)
committerMichael <heluecht@pirati.ca>
Sat, 5 Feb 2022 11:16:50 +0000 (11:16 +0000)
src/Model/Item.php
src/Protocol/ActivityPub/Processor.php

index 29fe0ad8c6d5d2863b5587711265f3088b3b10d6..217e77fd53fa097f08cd763556059fe40e00c447 100644 (file)
@@ -1428,6 +1428,16 @@ class Item
        private static function storeForUser(array $item, int $uid)
        {
                if (Post::exists(['uri-id' => $item['uri-id'], 'uid' => $uid])) {
+                       if (!empty($item['event-id'])) {
+                               $post = Post::selectFirst(['event-id'], ['uri-id' => $item['uri-id'], 'uid' => $uid]);
+                               if (!empty($post['event-id'])) {
+                                       $event = DBA::selectFirst('event', ['edited', 'start', 'finish', 'summary', 'desc', 'location', 'nofinish', 'adjust'], ['id' => $item['event-id']]);
+                                       if (!empty($event)) {
+                                               $ret = DBA::update('event', $event, ['id' => $post['event-id']]);
+                                               Logger::info('Event updated', ['uid' => $uid, 'source-event' => $item['event-id'], 'target-event' => $post['event-id'], 'ret' => $ret]);
+                                       }
+                               }
+                       }
                        Logger::info('Item already exists', ['uri-id' => $item['uri-id'], 'uid' => $uid]);
                        return 0;
                }
index bd198fb30e6637994094c3f176f01f881cbcbd4a..948a3983bc1d6bde8d9ff02a3792af0c715b3bb9 100644 (file)
@@ -180,6 +180,38 @@ class Processor
                }
 
                Item::update($item, ['uri' => $activity['id']]);
+
+               if ($activity['object_type'] == 'as:Event') {
+                       $posts = Post::select(['event-id', 'uid'], ['uri' => $activity['id']]);
+                       while ($post = DBA::fetch($posts)) {
+                               if (empty($post['event-id'])) {
+                                       continue;
+                               }
+                               self::updateEvent($post['event-id'], $activity);
+                       }
+               }
+       }
+
+       /**
+        * Update an existing event
+        *
+        * @param int $event_id 
+        * @param array $activity 
+        */
+       private static function updateEvent(int $event_id, array $activity)
+       {
+               $event = DBA::selectFirst('event', [], ['id' => $event_id]);
+
+               $event['edited']   = DateTimeFormat::utc($activity['updated']);
+               $event['summary']  = HTML::toBBCode($activity['name']);
+               $event['desc']     = HTML::toBBCode($activity['content']);
+               $event['start']    = $activity['start-time'];
+               $event['finish']   = $activity['end-time'];
+               $event['nofinish'] = empty($event['finish']);
+               $event['location'] = $activity['location'];
+
+               Logger::info('Updating event', ['uri' => $activity['id'], 'id' => $event_id]);
+               Event::store($event);
        }
 
        /**