From e26e782a50b8b48ff187cfc04d4210877e3ee3d5 Mon Sep 17 00:00:00 2001 From: pbrotherton Date: Tue, 25 Oct 2022 10:18:28 +0200 Subject: [PATCH] Update ExternalDetector.php Avoids edge case where PostID does not exist --- source/php/ExternalDetector.php | 62 +++++++++++++++++---------------- 1 file changed, 32 insertions(+), 30 deletions(-) diff --git a/source/php/ExternalDetector.php b/source/php/ExternalDetector.php index 91384b9..dcf9105 100644 --- a/source/php/ExternalDetector.php +++ b/source/php/ExternalDetector.php @@ -106,44 +106,46 @@ public function lookForBrokenLinks($postId = null, $url = null) } /* START MODULE SUPPORT */ - $modules = array(); - $sql = "select meta_value from $wpdb->postmeta where meta_key='modularity-modules' and post_id = $postId"; - $modularity = $wpdb->get_results($sql); - foreach($modularity as $module) { + if (is_numeric($postId)) { + $modules = array(); + $sql = "select meta_value from $wpdb->postmeta where meta_key='modularity-modules' and post_id = $postId"; + $modularity = $wpdb->get_results($sql); + foreach($modularity as $module) { $data = unserialize($module->meta_value); $keys = array_keys($data); foreach($keys as $k) { - $modules[] = array_column($data[$k], 'postid'); + $modules[] = array_column($data[$k], 'postid'); } - } - $modules = array_merge(...array_values($modules)); - foreach($modules as $mid) { - $meta = get_post_meta($mid, $key = '', $single = false ); - if(isset($meta['data']) && $meta['data'][0] > 0) { - for($i = 0; $i < $meta['data'][0]; $i++) { - $metakey = "data_".$i."_post_content"; - preg_match_all('/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i', $meta[$metakey][0], $matches); - foreach($matches[0] as $url) { - if (!$this->isBroken($url)) { - continue; + } + $modules = array_merge(...array_values($modules)); + foreach($modules as $mid) { + $meta = get_post_meta($mid, $key = '', $single = false ); + if(isset($meta['data']) && $meta['data'][0] > 0) { + for($i = 0; $i < $meta['data'][0]; $i++) { + $metakey = "data_".$i."_post_content"; + preg_match_all('/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i', $meta[$metakey][0], $matches); + foreach($matches[0] as $url) { + if (!$this->isBroken($url)) { + continue; + } + $foundUrls[] = array( + 'post_id' => $postId, + 'url' => $url + ); } - $foundUrls[] = array( - 'post_id' => $postId, - 'url' => $url - ); } } - } - $mpost = get_post($mid); - preg_match_all('/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i', $mpost->post_content, $matches); - foreach($matches[0] as $url) { - if (!$this->isBroken($url)) { - continue; + $mpost = get_post($mid); + preg_match_all('/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i', $mpost->post_content, $matches); + foreach($matches[0] as $url) { + if (!$this->isBroken($url)) { + continue; + } + $foundUrls[] = array( + 'post_id' => $postId, + 'url' => $url + ); } - $foundUrls[] = array( - 'post_id' => $postId, - 'url' => $url - ); } } /* END MODULE SUPPORT */