メインコンテンツへスキップ

Feedable Core の概要

feedable-core は Feedable のコアヘルパーと内蔵ドライバーを分離した Composer パッケージです。
新規 Laravel プロジェクトへ導入すると、スターターキットと同等の基盤を再利用できます。

Response クラス

Rss2ResponseJsonFeedResponse で出力フォーマットを固定できます。
ユーザーがフォーマットを選ぶ構成では ResponseFactory を使います。
use Revolution\Feedable\Core\Response\Rss2Response;

return new Rss2Response(
    title: $title,
    items: $items,
);
use Revolution\Feedable\Core\Enums\Format;
use Revolution\Feedable\Core\Response\ResponseFactory;

Route::get('feed.{format?}', function (Format $format = Format::RSS) use ($title, $items) {
    return ResponseFactory::format($format)->make(
        title: $title,
        items: $items,
    );
});

FeedItem / Author

FeedItem は RSS/JSON Feed で共通化されたアイテムオブジェクトです。
Authorauthors フィールド用のオブジェクトで、Author::make() を使って作成します。
use Revolution\Feedable\Core\Elements\Author;
use Revolution\Feedable\Core\Elements\FeedItem;

$item = new FeedItem(
    id: $url,
    url: $url,
    title: $title,
    summary: $summary,
    authors: [Author::make(name: $authorName)->toArray()],
);

Support ヘルパー

AbsoluteUri::resolve()

相対パスを絶対パスに変換。
use Revolution\Feedable\Core\Support\AbsoluteUri;

$absolute = AbsoluteUri::resolve('https://example.com/', '/images/sample.jpg');
use Revolution\Feedable\Core\Support\RSS;

$xml = RSS::filterLinks($rss, $links);

RSS::each()

use DOMElement;
use Revolution\Feedable\Core\Support\RSS;

$xml = RSS::each($rss, function (DOMElement $item) {
    $title = $item->getElementsByTagName('title')->item(0);

    if ($title && str_contains($title->textContent, 'NGワード')) {
        $item->parentNode?->removeChild($item);
    }
});

カスタムドライバーの作り方

1) スターターキットへ直接追加する

スターターキットは通常の Laravel アプリなので、routes/web.php にルート追加し、コントローラー(または invokable クラス)で実装できます。
use App\Http\Controllers\CustomFeedController;
use Revolution\Feedable\Core\Enums\Format;

Route::get('/custom/site.{format?}', CustomFeedController::class)
    ->whereIn('format', array_column(Format::cases(), 'value'));

2) Composer パッケージとして追加する

複数プロジェクトで再利用する場合は、ServiceProvider でルートを登録する構成が扱いやすくなります。
use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\Route;

class CustomDriverServiceProvider extends ServiceProvider
{
    public function boot(): void
    {
        Route::middleware('web')->group(__DIR__.'/../routes/web.php');
    }
}

3) Driver::about() で情報を登録する(オプション)

Driver::about() の登録は対応サイト一覧に表示するためのメタデータです。
未登録でもドライバー自体は動作します。

参考: Laravel ブログドライバー

実装例として Laravel 公式ブログ向けドライバーを参照してください。
最終更新日 2026年5月30日