[GithubIssueBridge] Fix issue comments and events parsing

Signed-off-by: Pierre Mazière <pierre.maziere@gmx.com>
This commit is contained in:
Pierre Mazière 2018-11-11 01:35:42 +01:00 committed by logmanoriginal
parent de575982a1
commit d7cabfca54

View file

@ -66,62 +66,50 @@ class GithubIssueBridge extends BridgeAbstract {
return parent::getURI(); return parent::getURI();
} }
protected function extractIssueComment($issueNbr, $title, $comment){ protected function extractIssueEvent($issueNbr, $title, $comment){
$class = $comment->getAttribute('class'); $comment = $comment->firstChild();
$classes = explode(' ', $class); $uri = static::URI . $this->getInput('u') . '/' . $this->getInput('p')
$event = false; . '/issues/' . $issueNbr . '#' . $comment->getAttribute('id');
if(in_array('discussion-item', $classes)) {
$event = true;
}
$author = 'unknown';
if($comment->find('.author', 0)) {
$author = $comment->find('.author', 0)->plaintext; $author = $comment->find('.author', 0)->plaintext;
$title .= ' / ' . trim($comment->plaintext);
$content = $title;
if (null !== $comment->nextSibling()) {
$content = $comment->nextSibling()->innertext;
if ($comment->nextSibling()->nodeName() === 'span') {
$content = $comment->nextSibling()->nextSibling()->innertext;
}
} }
$item = array();
$item['author'] = $author;
$item['uri'] = $uri;
$item['title'] = html_entity_decode($title, ENT_QUOTES, 'UTF-8');
$item['timestamp'] = strtotime(
$comment->find('relative-time', 0)->getAttribute('datetime')
);
$item['content'] = $content;
return $item;
}
protected function extractIssueComment($issueNbr, $title, $comment){
$uri = static::URI . $this->getInput('u') . '/' $uri = static::URI . $this->getInput('u') . '/'
. $this->getInput('p') . '/issues/' . $issueNbr; . $this->getInput('p') . '/issues/' . $issueNbr;
$comment = $comment->firstChild(); $author = $comment->find('.author', 0)->plaintext;
if(!$event) {
$comment = $comment->nextSibling();
$title .= ' / ' . trim($comment->firstChild()->plaintext);
$content = '<pre>';
$content .= $comment->find('.comment-body', 0)->innertext;
$content .= '</pre>';
}
if($event) { $title .= ' / ' . trim(
$title .= ' / '; $comment->find('.comment .timeline-comment-header-text', 0)->plaintext
$title .= substr(
$class,
strpos($class, 'discussion-item-') + strlen('discussion-item-')
); );
if(!$comment->hasAttribute('id')) {
$items = array(); $content = $comment->find('.comment-body', 0)->innertext;
$timestamp = strtotime(
$comment->find('relative-time', 0)->getAttribute('datetime')
);
$content = $comment->innertext;
while($comment = $comment->nextSibling()) {
$item = array();
$item['author'] = $author;
$item['title'] = html_entity_decode($title, ENT_QUOTES, 'UTF-8');
$item['timestamp'] = $timestamp;
$item['content'] = $content . '<p>'
. $comment->children(1)->innertext . '</p>';
$item['uri'] = $uri . '#'
. $comment->children(1)->getAttribute('id');
$items[] = $item;
}
return $items;
}
$content = $comment->parent()->innertext;
}
$item = array(); $item = array();
$item['author'] = $author; $item['author'] = $author;
$item['uri'] = $uri . '#' . $comment->getAttribute('id'); $item['uri'] = $uri
. '#' . $comment->firstChild()->nextSibling()->getAttribute('id');
$item['title'] = html_entity_decode($title, ENT_QUOTES, 'UTF-8'); $item['title'] = html_entity_decode($title, ENT_QUOTES, 'UTF-8');
$item['timestamp'] = strtotime( $item['timestamp'] = strtotime(
$comment->find('relative-time', 0)->getAttribute('datetime') $comment->find('relative-time', 0)->getAttribute('datetime')
@ -138,14 +126,24 @@ class GithubIssueBridge extends BridgeAbstract {
); );
$comments = $issue->find('.js-discussion', 0); $comments = $issue->find('.js-discussion', 0);
foreach($comments->children() as $comment) { foreach($comments->children() as $comment) {
$classes = explode(' ', $comment->getAttribute('class')); if (!$comment->hasChildNodes()) {
if(in_array('discussion-item', $classes) continue;
|| in_array('timeline-comment-wrapper', $classes)) {
$item = $this->extractIssueComment($issueNbr, $title, $comment);
if(array_keys($item) !== range(0, count($item) - 1)) {
$item = array($item);
} }
$items = array_merge($items, $item); $comment = $comment->firstChild();
$classes = explode(' ', $comment->getAttribute('class'));
if (in_array('timeline-comment-wrapper', $classes)) {
$item = $this->extractIssueComment($issueNbr, $title, $comment);
$items[] = $item;
continue;
}
while (in_array('discussion-item', $classes)) {
$item = $this->extractIssueEvent($issueNbr, $title, $comment);
$items[] = $item;
$comment = $comment->nextSibling();
if (null == $comment) {
break;
}
$classes = explode(' ', $comment->getAttribute('class'));
} }
} }
return $items; return $items;