elements * @param Parser Object */ static function parserInit( $parser ) { # Install parser hook for tags $parser->setHook( 'rss', array( __CLASS__, 'renderRss' ) ); return true; } /** * Static function wrapping RSSParser to handle rendering of RSS elements * @param $input String: text inside the tags. * @param $args Array: value associative list of the element attributes and * their values. * @param $frame Frame parser context */ static function renderRss( $input, $args, $parser, $frame ) { global $wgRSSCacheAge, $wgRSSCacheCompare; if ( !Http::isValidURI( $input ) ) { return wfMsg( 'rss-invalid-url', htmlspecialchars( $input ) ); } if ( $wgRSSCacheCompare ) { $timeout = $wgRSSCacheCompare; } else { $timeout = $wgRSSCacheAge; } $parser->disableCache(); $parser->getOutput()->updateCacheExpiry( $timeout ); $rss = new RSSParser( $input, $args ); $status = $rss->fetch(); # Check for errors. if ( !$status->isGood() ) { return wfMsg( 'rss-error', htmlspecialchars( $input ), $status->getWikiText() ); } if ( !is_object( $rss->rss ) || !is_array( $rss->rss->items ) ) { return wfMsg( 'rss-empty', htmlspecialchars( $input ) ); } return $rss->renderFeed( $parser, $frame ); } }