Skip to content

Mix Server is a web based audio player intended for listening to long audio files such as DJ mixes without losing track of your progress using a simple file explorer based UI

License

Notifications You must be signed in to change notification settings

a-m-brewer/mix-server

Repository files navigation

Mix Server

Mix Server is a web based audio player intended for listening to long audio files such as DJ mixes without losing track of your progress using a simple file explorer based UI.

Before developing this project I struggled to find an audio player that satisfied the following.

  1. Remembered my progress through a mix
  2. Had an option to view my files through a file explorer rather than through ID3 tags.
  3. Was available on all my devices

Screenshots

Desktop

Mix Server UI

Mobile

drawing

Features

  • Progress tracking: Mix Server will keep track of progress in an audio file so you can pick up where you left off
  • File Explorer UI: Rather than having to meticulously tag all your MP3 files view them through a file explorer
  • Multi Device Control: Listen on your phone whist controlling playback from your computer, as well as being able to seamlessly transfer playback to another device
  • User Management: Create multiple users who can each keep track of there own progress
  • History: View a history of all the files you have listened to
  • Queue: Queue audio from any folder to be played next
  • Themes: Choose between a light and dark theme
  • Tracklists: Add tracklists to your mixes

Installation

The easiest way to install Mix Server is through Docker Compose.

Here is an example docker-compose.yml

version: "3.5"

services:
  mix-server:
    hostname: mix-server
    container_name: mix-server
    image: adammbrewer/mix-server
    restart: unless-stopped
    networks:
      - mix-server-network
    ports:
      - "5225:5225"
    environment:
      - DOTNET_ENVIRONMENT=Production
      - ASPNETCORE_URLS=http://+:5225
      - MIX_SERVER_HostSettings__ValidUrls=https://mix-server.example.com
      - MIX_SERVER_RootFolder__Children=/media
    volumes:
      - mix-server-media:/media
      - mix-server-data:/data

networks:
  mix-server-network:

volumes:
  mix-server-data:
  mix-server-media:
  • DOTNET_ENVIRONMENT: Either Development or Production if you're just hosting the app keep this as Production
  • ASPNETCORE_URLS: The URL you want the server to be hosted on
  • MIX_SERVER_HostSettings__ValidUrls: Valid URLs clients can access the UI on. Add multiple using ; as a separator
  • MIX_SERVER_RootFolder__Children: Set this to the folders you want to access via the UI. In the example above this is set to /media as that's where mix-server-media is mounted. You can mount multiple locations using ; as a seperator
  • /data: Is the location where Mix Server's database and config is held. Mix Server currently uses SQLite as its data store

For further configuration see

Help

Importing tracklists

Tracklists are imported using JSON and must match the following schema

{
   "$schema": "http://json-schema.org/draft-07/schema#",
   "title": "Generated schema for Root",
   "type": "object",
   "properties": {
      "cues": {
         "type": "array",
         "items": {
            "type": "object",
            "properties": {
               "cue": {
                  "type": "string"
               },
               "tracks": {
                  "type": "array",
                  "items": {
                     "type": "object",
                     "properties": {
                        "name": {
                           "type": "string"
                        },
                        "artist": {
                           "type": "string"
                        },
                        "players": {
                           "type": "array",
                           "items": {
                              "type": "object",
                              "properties": {
                                 "type": {
                                    "type": "string"
                                 },
                                 "urls": {
                                    "type": "array",
                                    "items": {
                                       "type": "string"
                                    }
                                 }
                              },
                              "required": [
                                 "type",
                                 "urls"
                              ]
                           }
                        }
                     },
                     "required": [
                        "players"
                     ]
                  }
               }
            },
            "required": [
               "cue",
               "tracks"
            ]
         }
      }
   },
   "required": [
      "cues"
   ]
}

Developing

Mix Server is developed using ASP.NET Core 8.0 and Angular 17. Using Powershell Core for development scripts

  1. Download .NET 8.0 SDK and Node.js LTS and Powershell Core
  2. Open the client (src/clients/mix-server-client) project and run the following
    1. npm install
    2. ng build
    3. ng serve
  3. Open the API Project (MixServer.sln)
    1. Run pwsh scripts/link_wwwroot.ps1
    2. Create a data directory in the root of the repo
    3. Create a appsettings.Local.json file and specify your media directory
{
    "RootFolder": {
        "Children": "./media"
    }
}
  1. Run the project
  2. Access the angular UI on http://localhost:4200 and the API on http://localhost:5225

Regenerating API Clients

If you make a change to an API Controller / DTO / SignalR Dto you will need to regenerate the API client.

Run scripts/regenerate_api_clients.ps1 to regenerate the clients

About

Mix Server is a web based audio player intended for listening to long audio files such as DJ mixes without losing track of your progress using a simple file explorer based UI

Topics

Resources

License

Stars

Watchers

Forks

Packages