This project exists to help me transition podcast listening from PodcastAddict to a Tangara.
podcast-playlist currently supports fetching feeds, downloading episodes, building playlists and tracking listen history. It's probably 'good enough' to use, but I've not fully used it in anger yet, so there's likely quirks and bugs yet to be discovered!
This assumes you have node/npm and ffmpeg installed.
- Clone the repo
- npm i
- npm run build
- node .\dist\index.js
Invoke podcast-playlist with node .\dist\index.js
. The documentation below just shows the subsequent commands (i.e. feed list
means node .\dist\index.js feed list
).
To get stuck in you can use --help
for any (sub)command to get help.
Data is by default stored in ./data
. To change this set the environment variable PODCASTPLAYLISTDIR
.
All the data is plain JSON files in a (hopefully!) sensible folder structure, with audio files in cache/podcastname
directories.
Unless you're starting completely from scratch, you probably have some existing subscriptions to import. OPML files are supported for this, or you can just use RSS fees URLs:
For ingestion, create a configuration file listing any OPML files or RSS feeds you want to add:
Configuration file:
{
"opml": [
"A:/Path/To/File.opml"
],
"rss": [
"https://example.com/rss"
]
}
Then
feed ingest --path "./config.json"
Items in the history are skipped when creating playlists.
If you have a previous listen history from Podcast Addict, you can import the sqlite database (App settings > Backup / Restore) to add your listen history:
history import --podcastAddict "<path/to/export.db>"
Otherwise, you can add entire feeds to the history with history feed --name "feedname"
or mark all episodes in a playlist as played - history import --playlist "path/to/playlist.m3u"
You can refresh feeds using cache refresh
. This will re-download all the RSS feeds.
To have episodes added to the cache, run cache update
. Note that this will download all uncached episodes. To avoid this you can run update cache skip
to mark episodes you don't want downloaded:
# Don't cache any episodes that are in the history
node .\dist\index.js cache skip --history
# Don't cache any episodes in the feed "EXAMPLE"
node .\dist\index.js cache skip --feed "EXAMPLE"
# Don't cache any episodes present in the feeds currently
node .\dist\index.js cache skip --all
You can also manually curate a history JSON and replace the one in the root data directory if you need more control:
{
"_items": [
{
"_episodeName": "Episode title as it appears in the feed",
"_episodeURL": "https://example.com/this/can/also/be/null.rss",
"_listenDate": "2016-03-22T08:51:47.453Z",
"_podcastName": "Name of the podcast as it appears in the feed",
"_podcastId": null
}
],
...
}
Existing files can be imported provided there is enough metadata to match the file to an item in a feed.
cache import --path /home/user/Music/Podcasts/ --recursive --ignoreArtist
Removing --ignoreArtist
will be quicker, but will mean that podcasts that have changed names, or files that don't have a valid tag (e.g. artist
), will not find a match.
To create a playlist, create a configuration file like below:
Configuration file:
{
"playlist": {
"include": [
{
"name": "Hello From The Magic Tavern",
"exclude": [
"^Introducing"
],
"ordered": true
},
{
"name": "Pitch, Please",
"ordered": false
},
{
"name": "Regulation Podcast",
"ordered": false,
"skipTypes": ["bonus"]
}
],
"episodeTitleFilters": [
"^BONUS.*"
],
"count": 4
}
}
Then invoke the creation:
playlist create --title playlist_name --configPath .\playlist_config.json --local
If you don't want the files downloaded, and just want the playlist to point to the URL of the episodes, drop the --local
.