torann / podcastfeed
Generate RSS feeds for podcasts in Laravel 5.
Installs: 5 800
Dependents: 0
Suggesters: 0
Security: 0
Stars: 48
Watchers: 4
Forks: 26
Open Issues: 7
Requires
- php: >=5.5.9
- illuminate/support: ~5.1
This package is auto-updated.
Last update: 2024-12-08 10:41:41 UTC
README
Generate a RSS feed for podcast for Laravel 5.
Installation
From the command line run
$ composer require torann/podcastfeed
Setup
Once installed you need to register the service provider with the application. Open up config/app.php
and find the providers
key.
'providers' => [ ... Torann\PodcastFeed\PodcastFeedServiceProvider::class, ... ]
This package also comes with a facade, which provides an easy way to call the the class. Open up config/app.php
and find the aliases
key
'aliases' => [ ... 'PodcastFeed' => Torann\PodcastFeed\Facades\PodcastFeed::class, ... ];
Publish the configurations
Run this on the command line from the root of your project:
$ php artisan vendor:publish --provider="Torann\PodcastFeed\PodcastFeedServiceProvider"
A configuration file will be publish to config/podcast-feed.php
.
Methods
setHeader
The header of the feed can be set in the config file or manually using the setHeader
method:
PodcastFeed::setHeader([ 'title' => 'All About Everything', 'subtitle' => 'A show about everything', 'description' => 'Great site description', 'link' => 'http://www.example.com/podcasts/everything/index.html', 'image' => 'http://example.com/podcasts/everything/AllAboutEverything.jpg', 'author' => 'John Doe', 'email' => 'john.doe@example.com', 'category' => 'Technology', 'language' => 'en-us', 'copyright' => '2016 John Doe & Family', ]);
addMedia Adding media to the feed.
foreach($this->podcastRepository->getPublished() as $podcast) { PodcastFeed::addMedia([ 'title' => $podcast->title, 'description' => $podcast->title, 'publish_at' => $podcast->publish_at, 'guid' => route('podcast.show', $podcast->slug), 'url' => $podcast->media->url(), 'type' => $podcast->media_content_type, 'duration' => $podcast->duration, 'image' => $podcast->image->url(), ]); }
toString Converting feed to a presentable string. The example below was pulled from a controller. In theory you could implement a caching method so that it doesn't have to render each time.
public function index() { foreach($this->podcastRepository->getPublished() as $podcast) { PodcastFeed::addMedia([ 'title' => $podcast->title, 'description' => $podcast->title, 'publish_at' => $podcast->publish_at, 'guid' => route('podcast.show', $podcast->slug), 'url' => $podcast->media->url(), 'type' => $podcast->media_content_type, 'duration' => $podcast->duration, 'image' => $podcast->image->url(), ]); } return Response::make(PodcastFeed::toString()) ->header('Content-Type', 'text/xml'); }
Change Log
v0.2.1
- Fixes foreign characters like 'æ', 'ø' and 'å'
v0.2.0
- Support Laravel 5
v0.1.0
- First release