Skip to content

(re-write of the now legacy nodejs `backend` in Go)

Notifications You must be signed in to change notification settings

music-library/api

Repository files navigation

Music-Library API

API for the Music-Library project, written in Go.

Features

Core

  • /tracks
  • /albums
  • /track/:id
  • /track/:id/audio
  • /track/:id/cover/:size?
  • Extract metadata
  • Cache metadata
  • Re-index library every X hours

Additional

  • One instance, handle multiple libraries
    • Middleware to handle library selection (via X-Library header)
    • Frontend to select library
      • Default library needs to be set so FE is never blocked on what to load
      • Available libraries need to be sent to the FE
      • UI changes to select/swap library
  • /health
  • /health/metrics // Prometheus metrics?
  • /reindex/:password - Refresh all metadata (without restarting the server)
  • Websocket - create a custom implementation
    • Active user count (existing functionality)
    • Currently playing tracks (existing functionality)
    • Session following
    • Chat? - encrypted maybe?

Just for fun

  • tests
  • benchmarks
  • n-gram search
  • playlists?
  • Get average + primary color of album cover
  • video support - also stream audio only via ffmpeg on-the-fly streams
  • link straight to playing a track (track # in url - only plays if no track is playing)
  • file watcher, re-index after file change (wait a bit before re-indexing to avoid spamming)
  • /track/random
  • /track/search/:query - return audio (same as /track/:id/audio) - Useful for searching for a song and playing it directly

Development

ENV

  • HOST - Host to run the server on (default: localhost)
  • PORT - Port to run the server on (default: 3001)
  • LOG_LEVEL - Log severity level (default: error)
  • LOG_FILE - Log file (default: DATA_DIR/music-api.log)
  • DATA_DIR - Data directory to cache and store info (default: ./data)
  • MUSIC_DIR - Music directory - where all your lovely music is :) (default: ./music)

Setup

Setup by running the following bootstrap commands:

$ go install -mod vendor github.com/go-task/task/v3/cmd/task
$ task bootstrap

Available tasks are in Taskfile.yml and use go-task. To list all available tasks, run:

$ task --list-all

Start development server by running:

$ task dev

About

(re-write of the now legacy nodejs `backend` in Go)

Resources

Stars

Watchers

Forks

Packages

No packages published