2019-03-23 16:27:07 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class MozillaBugTrackerBridge extends BridgeAbstract
|
2022-07-01 15:10:30 +02:00
|
|
|
{
|
2019-03-23 16:27:07 +01:00
|
|
|
const NAME = 'Mozilla Bug Tracker';
|
|
|
|
const URI = 'https://bugzilla.mozilla.org';
|
2022-06-24 05:04:49 -04:00
|
|
|
const DESCRIPTION = 'DEPRECATED: Use BugzillaBridge instead.
|
|
|
|
Returns feeds for bug comments';
|
2019-03-23 16:27:07 +01:00
|
|
|
const MAINTAINER = 'AntoineTurmel';
|
|
|
|
const PARAMETERS = [
|
|
|
|
'Bug comments' => [
|
|
|
|
'id' => [
|
|
|
|
'name' => 'Bug tracking ID',
|
|
|
|
'type' => 'number',
|
|
|
|
'required' => true,
|
|
|
|
'title' => 'Insert bug tracking ID',
|
|
|
|
'exampleValue' => 121241
|
|
|
|
],
|
|
|
|
'limit' => [
|
|
|
|
'name' => 'Number of comments to return',
|
|
|
|
'type' => 'number',
|
|
|
|
'required' => false,
|
|
|
|
'title' => 'Specify number of comments to return',
|
|
|
|
'defaultValue' => -1
|
|
|
|
],
|
|
|
|
'sorting' => [
|
|
|
|
'name' => 'Sorting',
|
|
|
|
'type' => 'list',
|
|
|
|
'required' => false,
|
|
|
|
'title' => 'Defines the sorting order of the comments returned',
|
|
|
|
'defaultValue' => 'of',
|
|
|
|
'values' => [
|
|
|
|
'Oldest first' => 'of',
|
|
|
|
'Latest first' => 'lf'
|
2022-07-01 15:10:30 +02:00
|
|
|
]
|
|
|
|
]
|
|
|
|
]
|
2019-03-23 16:27:07 +01:00
|
|
|
];
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
private $bugid = '';
|
|
|
|
private $bugdesc = '';
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
public function getIcon()
|
|
|
|
{
|
|
|
|
return self::URI . '/extensions/BMO/web/images/favicon.ico';
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
public function collectData()
|
|
|
|
{
|
|
|
|
$limit = $this->getInput('limit');
|
|
|
|
$sorting = $this->getInput('sorting');
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
// We use the print preview page for simplicity
|
|
|
|
$html = getSimpleHTMLDOMCached(
|
|
|
|
$this->getURI() . '&format=multiple',
|
|
|
|
86400,
|
|
|
|
null,
|
|
|
|
null,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
DEFAULT_TARGET_CHARSET,
|
|
|
|
false, // Do NOT remove line breaks
|
|
|
|
DEFAULT_BR_TEXT,
|
|
|
|
DEFAULT_SPAN_TEXT
|
|
|
|
);
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2020-05-17 18:33:01 +00:00
|
|
|
// Fix relative URLs
|
|
|
|
defaultLinkTo($html, self::URI);
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
// Store header information into private members
|
2021-10-14 05:13:18 -04:00
|
|
|
$this->bugid = trim($html->find('#field-value-bug_id', 0)->plaintext);
|
2020-05-17 18:33:01 +00:00
|
|
|
$this->bugdesc = $html->find('h1#field-value-short_desc', 0)->plaintext;
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
// Get and limit comments
|
2020-05-17 18:33:01 +00:00
|
|
|
$comments = $html->find('div.change-set');
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
if ($limit > 0 && count($comments) > $limit) {
|
|
|
|
$comments = array_slice($comments, count($comments) - $limit, $limit);
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2020-05-17 18:33:01 +00:00
|
|
|
if ($sorting === 'lf') {
|
|
|
|
$comments = array_reverse($comments, true);
|
2019-03-23 16:27:07 +01:00
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
foreach ($comments as $comment) {
|
|
|
|
$comment = $this->inlineStyles($comment);
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
$item = [];
|
2020-05-17 18:33:01 +00:00
|
|
|
$item['uri'] = $comment->find('h3.change-name', 0)->find('a', 0)->href;
|
|
|
|
$item['author'] = $comment->find('td.change-author', 0)->plaintext;
|
|
|
|
$item['title'] = $comment->find('h3.change-name', 0)->plaintext;
|
|
|
|
$item['timestamp'] = strtotime($comment->find('span.rel-time', 0)->title);
|
|
|
|
$item['content'] = '';
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2020-05-17 18:33:01 +00:00
|
|
|
if ($comment->find('.comment-text', 0)) {
|
|
|
|
$item['content'] = $comment->find('.comment-text', 0)->outertext;
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2020-05-17 18:33:01 +00:00
|
|
|
if ($comment->find('div.activity', 0)) {
|
|
|
|
$item['content'] .= $comment->find('div.activity', 0)->innertext;
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
$this->items[] = $item;
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2019-03-23 16:27:07 +01:00
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
public function getURI()
|
|
|
|
{
|
|
|
|
switch ($this->queriedContext) {
|
|
|
|
case 'Bug comments':
|
|
|
|
return parent::getURI()
|
|
|
|
. '/show_bug.cgi?id='
|
|
|
|
. $this->getInput('id');
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return parent::getURI();
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2019-03-23 16:27:07 +01:00
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
switch ($this->queriedContext) {
|
|
|
|
case 'Bug comments':
|
2020-05-17 18:33:01 +00:00
|
|
|
return $this->bugid
|
|
|
|
. ' - '
|
2019-03-23 16:27:07 +01:00
|
|
|
. $this->bugdesc
|
|
|
|
. ' - '
|
|
|
|
. parent::getName();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return parent::getName();
|
|
|
|
}
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
/**
|
|
|
|
* Adds styles as attributes to tags with known classes
|
|
|
|
*
|
|
|
|
* @param object $html A simplehtmldom object
|
|
|
|
* @return object Returns the original object with styles added as
|
|
|
|
* attributes.
|
|
|
|
*/
|
|
|
|
private function inlineStyles($html)
|
|
|
|
{
|
2020-05-17 18:33:01 +00:00
|
|
|
foreach ($html->find('.bz_closed') as $element) {
|
2019-03-23 16:27:07 +01:00
|
|
|
$element->style = 'text-decoration:line-through;';
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2020-05-17 18:33:01 +00:00
|
|
|
foreach ($html->find('pre') as $element) {
|
|
|
|
$element->style = 'white-space: pre-wrap;';
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
2019-03-23 16:27:07 +01:00
|
|
|
return $html;
|
|
|
|
}
|
|
|
|
}
|