]> git.mxchange.org Git - friendica.git/commitdiff
Fix: posted unprepared posts hadn't been deleted
authorMichael <heluecht@pirati.ca>
Sun, 13 Dec 2020 18:17:50 +0000 (18:17 +0000)
committerMichael <heluecht@pirati.ca>
Sun, 13 Dec 2020 18:17:50 +0000 (18:17 +0000)
src/Model/Post/Delayed.php
src/Worker/DelayedPublish.php

index 913bcedae658e3e5406ad5471d1c6d5d368d8eab..0e6d8b921ad4b4b65ae334e5122a7ce306394442 100644 (file)
@@ -63,7 +63,7 @@ class Delayed
 
                Logger::notice('Adding post for delayed publishing', ['uid' => $item['uid'], 'delayed' => $delayed, 'uri' => $uri]);
 
-               if (!Worker::add(['priority' => PRIORITY_HIGH, 'delayed' => $delayed], 'DelayedPublish', $item, $notify, $taglist, $attachments, $unprepared)) {
+               if (!Worker::add(['priority' => PRIORITY_HIGH, 'delayed' => $delayed], 'DelayedPublish', $item, $notify, $taglist, $attachments, $unprepared, $uri)) {
                        return false;
                }
 
@@ -106,9 +106,10 @@ class Delayed
         * @param array $taglist
         * @param array $attachments
         * @param bool  $unprepared
+        * @param string $uri
         * @return bool
         */
-       public static function publish(array $item, int $notify = 0, array $taglist = [], array $attachments = [], bool $unprepared = false)
+       public static function publish(array $item, int $notify = 0, array $taglist = [], array $attachments = [], bool $unprepared = false, string $uri = '')
        {
                if ($unprepared) {
                        $_SESSION['authenticated'] = true;
@@ -126,15 +127,27 @@ class Delayed
                        require_once 'mod/item.php';
                        $id = item_post(DI::app());
 
-                       Logger::notice('Unprepared post stored', ['id' => $id, 'uid' => $item['uid'], 'extid' => $item['extid']]);
+                       if (empty($uri) && !empty($item['extid'])) {
+                               $uri = $item['extid'];
+                       }
+
+                       Logger::notice('Unprepared post stored', ['id' => $id, 'uid' => $item['uid'], 'uri' => $uri]);
+                       if (self::exists($uri, $item['uid'])) {
+                               self::delete($uri, $item['uid']);
+                       }
+       
                        return $id;
                }
                $id = Item::insert($item, $notify);
 
                Logger::notice('Post stored', ['id' => $id, 'uid' => $item['uid'], 'cid' => $item['contact-id']]);
 
-               if (!empty($item['uri']) && self::exists($item['uri'], $item['uid'])) {
-                       self::delete($item['uri'], $item['uid']);
+               if (empty($uri) && !empty($item['uri'])) {
+                       $uri = $item['uri'];
+               }
+
+               if (!empty($uri) && self::exists($uri, $item['uid'])) {
+                       self::delete($uri, $item['uid']);
                }
 
                if (!empty($id) && (!empty($taglist) || !empty($attachments))) {
index 2d08b25b005169b0a06fea71bd53ed8828019e03..a76e26ef704ec781d224cf2f567d48ba1621ea77 100644 (file)
@@ -34,11 +34,12 @@ class DelayedPublish
          * @param array $taglist
          * @param array $attachments
          * @param bool  $unprepared
+         * @param string $uri
          * @return void
          */
-       public static function execute(array $item, int $notify = 0, array $taglist = [], array $attachments = [], bool $unprepared = false)
+       public static function execute(array $item, int $notify = 0, array $taglist = [], array $attachments = [], bool $unprepared = false, string $uri = '')
        {
-               $id = Post\Delayed::publish($item, $notify, $taglist, $attachments, $unprepared);
+               $id = Post\Delayed::publish($item, $notify, $taglist, $attachments, $unprepared, $uri);
                Logger::notice('Post published', ['id' => $id, 'uid' => $item['uid'], 'cid' => $item['contact-id'], 'notify' => $notify, 'unprepared' => $unprepared]);
        }
 }