aschmelyun/basic-feeds

A simple PHP library to generate RSS and Atom feeds

v1.0.0 2022-04-02 05:39 UTC

This package is auto-updated.

Last update: 2024-04-30 00:42:48 UTC


README

This package provides a basic way of generating RSS 2 and Atom XML feeds in PHP using a simplified syntax. There are no external dependencies as this package relies on the built-in SimpleXMLElement class.

Installation

composer require aschmelyun/basic-feeds

Usage

Initialize a feed by using the Feed::create() method, passing in an array of attributes needed to set up your feed's base.

use Aschmelyun\BasicFeeds\Feed;

$feed = Feed::create([
    'link' => 'https://example.com/blog',
    'authors' => 'Andrew Schmelyun',
    'title' => 'My Example Blog',
    'feed' => 'https://example.com/feed.xml',
]);

Then use the entry() method on the Feed object to attach entries to your feed.

$feed->entry([
    'title' => 'Post One',
    'link' => 'https://example.com/blog/post-one',
    'summary' => 'This is my summary',
    'content' => '<p>This is my example content!</p>'
]);

The entry() method can also expect multiple items at once, using a nested array.

$feed->entry([
    'title' => 'Post Two',
    'link' => 'https://example.com/blog/post-two',
    'summary' => 'This is my second summary',
    'content' => '<p>This is my second example content!</p>'
], [
    'title' => 'Post Three',
    'link' => 'https://example.com/blog/post-three',
    'summary' => 'This is my third summary',
    'content' => '<p>This is my third example content!</p>'
]);

You can then use either the asAtom() or asRss() method to compile the feed to the requested format and return it as an XML string:

$xml = $feed->asAtom();
// $xml = $feed->asRss();

Requirements

There are a few required attributes, and they change based on the format(s) you choose.

For Feed::create() they are:

  • RSS: title, link, description
  • Atom: title, link, authors, feed

For entry() they are:

  • RSS: title, link, description
  • Atom: title, link, summary, content

Extending

This package comes with an interface that you can use to help extend off of this package to create your own feed generator.

Check out the Atom and RSS classes to see how the included feed generators are structured.

Testing

If you don't already have PHPUnit required in your current project, install this package with dev dependencies:

composer require aschmelyun/basic-feeds --dev

Then run the PHPUnit tests:

./vendor/bin/phpunit

License

This package is licensed under the The MIT License. See LICENSE for more details.