diff options
author | Jordan <me@jordan.im> | 2020-04-05 20:20:41 -0700 |
---|---|---|
committer | Jordan <me@jordan.im> | 2020-04-05 20:20:41 -0700 |
commit | 2df5addacd82ac7463ff6d3ec6754b21dab71737 (patch) | |
tree | 0e6bdb96de5c78bb2e67fd5bad29190e436919b5 /README | |
download | roka-2df5addacd82ac7463ff6d3ec6754b21dab71737.tar.gz roka-2df5addacd82ac7463ff6d3ec6754b21dab71737.zip |
initial commit
Diffstat (limited to 'README')
-rw-r--r-- | README | 35 |
1 files changed, 35 insertions, 0 deletions
@@ -0,0 +1,35 @@ +audiobook-rss: stream directory of audiobooks to podcasting apps via RSS + +installation +------------ +a) copy and populate app.cfg and uwsgi.ini (if using UWSGI) + +b) create venv, install flask and uwsgi + +c) execute rebuild.py to populate audiobook JSON cache + +d) execute uwsgi.sh to start the server + +design decisions +---------------- +1. directories contained within config:ROOT_PATH are marked as audiobooks if and + only if they contain at least one MP3 file + +2. audiobooks are uniquely identifiable by the collective hash of each MP3 file + contained in the audiobook directory. + + pro: if the directory structure is changed or files are moved, RSS/download + link integrity is maintained, preserve app-side listening progress and + history + + con: each MP3 file is hashed, which can be slow on spinning rust w/ large + collections + +3. XML pubDate and list order is derived from MP3 track attributes; if not + present or duplicates exist, tracks are sorted alphanumerically + +4. partial content handling (HTTP 206) implemented to satisfy podcasting apps + which require valid responses to Range requests (e.g. Apple podcasts) + +5. no rebuild endpoint exists; cache-affecting routines are run externally via + rebuild.py |