GitXplorerGitXplorer
S

podcast-playlist

public
1 stars
0 forks
9 issues

Commits

List of commits on branch main.
Verified
33e6b8dc911fc62db2385f8c09d61ce20ebda3e0

Merge pull request #13 from Slord6/feature/add-feed-to-history

SSlord6 committed 9 months ago
Unverified
4e0020af58d968f635593887466daa0391b73d35

Add `...history feed` command to mark all played

SSlord6 committed 9 months ago
Unverified
2a426d07b76b860624df22cca6ee3760efdaef5a

Allow null podcastId

SSlord6 committed 9 months ago
Verified
96f1205a39d58c2de121667b7def34aef92c45d0

Merge pull request #12 from Slord6/bug/create-playlist-missing-path

SSlord6 committed 9 months ago
Unverified
e8c09f6bde784d6ab41e929fb735af9906ab4e95

Fix path issue, not using cache for playlist

SSlord6 committed 9 months ago
Verified
e24d100d1c2c1e08c0e802eae3033010881b4f16

Merge pull request #11 from Slord6/feature/consolidate-cli-args

SSlord6 committed 9 months ago

README

The README file for this repository.

podcast-playlist

This project exists to help me transition podcast listening from PodcastAddict to a Tangara. Ultimately it will tie into whatever process the companion app uses to transfer media and playlists to the device and scrobbling back off.

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!

Install

This assumes you have node/npm installed.

  1. Clone the repo
  2. npm i
  3. npm run build
  4. node .\dist\index.js

Usage

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

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.

Ingestion

Subscriptions

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"

History

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"

Feed updates and the cache

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
        }
    ],
    ...
}

Audio

Importing existing audio files is being tracked in issue #15.

Playlist creation

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
            }
        ],
        "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.