From e8e20fc27ef3f3a5d27ab903b3ece922acd7e232 Mon Sep 17 00:00:00 2001 From: Aaron Parecki Date: Sat, 18 Apr 2020 17:13:50 -0700 Subject: [PATCH] better error when no link is found in microformats for https://github.com/aaronpk/webmention.io/issues/150 --- lib/XRay/Parser.php | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/lib/XRay/Parser.php b/lib/XRay/Parser.php index 674def1..e2900db 100644 --- a/lib/XRay/Parser.php +++ b/lib/XRay/Parser.php @@ -25,14 +25,16 @@ class Parser { // Ignore this check for any non-HTML documents since this will be uncommon anyway $found = false; } + $error_description = 'The source document does not have a link to the target URL'; } else { $found = $this->_findLinkInTree($opts['target'], $document['data']); + $error_description = 'The Microformats at the source URL do not contain a link to the target URL. Check the source URL in a Microformats parser such as php.microformats.io'; } if(!$found) { return [ 'error' => 'no_link_found', - 'error_description' => 'The source document does not have a link to the target URL', + 'error_description' => $error_description, 'code' => isset($document['code']) ? $document['code'] : 200, 'url' => $document['url'], 'debug' => $document['data'] @@ -41,7 +43,7 @@ class Parser { } // If the HTML parser couldn't parse the page it returns the full HTML for checking the target above, - // but we don't want to return that in the out put so remove it here + // but we don't want to return that in the output so remove it here unset($document['html']); return $document;