namespace Friendica\Module;
use Friendica\BaseModule;
-use Friendica\Core\System;
+use Friendica\DI;
use Friendica\Protocol\OStatus;
/**
*
* @brief Provides public Atom feeds
*
- * @author Hypolite Petovan <mrpetovan@gmail.com>
+ * @author Hypolite Petovan <hypolite@mrpetovan.com>
*/
class Feed extends BaseModule
{
- public static function content()
+ public static function content(array $parameters = [])
{
- $a = self::getApp();
+ $a = DI::app();
- $last_update = x($_GET, 'last_update') ? $_GET['last_update'] : '';
- $nocache = x($_GET, 'nocache') && local_user();
+ $last_update = $_GET['last_update'] ?? '';
+ $nocache = !empty($_GET['nocache']) && local_user();
+ // @TODO: Replace with parameter from router
if ($a->argc < 2) {
- System::httpExit(400);
+ throw new \Friendica\Network\HTTPException\BadRequestException();
}
$type = null;
+ // @TODO: Replace with parameter from router
if ($a->argc > 2) {
$type = $a->argv[2];
}
case 'posts':
case 'comments':
case 'activity':
+ // Correct type names, no change needed
break;
case 'replies':
$type = 'comments';
$type = 'posts';
}
+ // @TODO: Replace with parameter from router
$nickname = $a->argv[1];
- header("Content-type: application/atom+xml");
- echo OStatus::feed($nickname, $last_update, 10, $type, $nocache);
- killme();
+ header("Content-type: application/atom+xml; charset=utf-8");
+ echo OStatus::feed($nickname, $last_update, 10, $type, $nocache, true);
+ exit();
}
}