Skip to content

Latest commit

 

History

History
71 lines (52 loc) · 2.99 KB

README.md

File metadata and controls

71 lines (52 loc) · 2.99 KB

ElevenFM

A music streaming webapp that uses YouTube to get the audio and video. The artist and album data is provided by Last.fm and TheAudioDB APIs.

Tech Stack

Main page screenshot

Features

  • Search for artists.

  • View artist details and discography.

  • Play albums and tracks.

  • Autoplay artist's tracks.

  • Add tracks to queue.

  • View lyrics.

  • Randomize the queue.

  • Manage playlists.

  • Import playlists from Spotify, YouTube and SoundCloud. (100 max at a time)

  • Simple account creation with no email required.

  • Fully responsive design.

    Add songs to your playlists by dragging and dropping: Reorder tracks in your playlists:
    drag to playlist reorder playlist

Installation

Clone the repository and run pnpm install to install the dependencies. Then run pnpm run db:migrate to create the database, on development it will create a local SQLite database file, on production it receives a Turso connection URL and auth token as environment variables. Finally pnpm run dev to start the development server.

Environment variables

  • LASTFM_API_KEY - Last.fm API key
  • AUDIODB_API_KEY - TheAudioDB API key
  • GENIUS_ACCESS_TOKEN - Genius API access token for lyrics
  • NEXT_PUBLIC_INVIDIOUS_URLS - Invidious instances to get YouTube video embeds
  • NEXT_PUBLIC_SITE_URL - Site URL for CORS
  • TURSO_CONNECTION_URL and TURSO_AUTH_TOKEN - Turso variables
  • UPSTASH_REDIS_URL and UPSTASH_REDIS_TOKEN - Upstash Redis variables for sessions

NextAuth variables

  • NEXTAUTH_URL - hostname + /api/auth
  • AUTH_SECRET
  • AUTH_GITHUB_ID
  • AUTH_GITHUB_SECRET

Other commands

  • pnpm run gen - Generate GraphQL types
  • pnpm run build - Build the app for production
  • pnpm run update - Run npm-check-updates and update dependencies

Recommended VS Code extensions

Motivation

Many songs I like were not available on Spotify and some never got lyrics, some were only available on SoundCloud or YouTube, and I don't like Youtube Music interface and ads. Also I didn't want to bother with managing or self-hosting my own music library. So I decided to make my own music streaming platform.