A modern self-hosted music player.
Go to file
2022-12-19 17:44:40 -08:00
.erb Add files 2022-12-19 17:44:40 -08:00
.github Add files 2022-12-19 17:44:40 -08:00
.husky Add files 2022-12-19 17:44:40 -08:00
.vscode Add files 2022-12-19 17:44:40 -08:00
assets Add files 2022-12-19 17:44:40 -08:00
release/app Add files 2022-12-19 17:44:40 -08:00
scripts Add files 2022-12-19 17:44:40 -08:00
src Add files 2022-12-19 17:44:40 -08:00
.dockerignore Add files 2022-12-19 17:44:40 -08:00
.editorconfig Add files 2022-12-19 17:44:40 -08:00
.eslintignore Add files 2022-12-19 17:44:40 -08:00
.eslintrc.js Add files 2022-12-19 17:44:40 -08:00
.gitattributes Add files 2022-12-19 17:44:40 -08:00
.gitignore Add files 2022-12-19 17:44:40 -08:00
.prettierrc Add files 2022-12-19 17:44:40 -08:00
.stylelintrc.json Add files 2022-12-19 17:44:40 -08:00
CHANGELOG.md Add files 2022-12-19 17:44:40 -08:00
docker-compose.dev.yml Add files 2022-12-19 17:44:40 -08:00
docker-compose.prod.yml Add files 2022-12-19 17:44:40 -08:00
docker-compose.yml Add files 2022-12-19 17:44:40 -08:00
docker-entrypoint.sh Add files 2022-12-19 17:44:40 -08:00
Dockerfile Add files 2022-12-19 17:44:40 -08:00
example.env Add files 2022-12-19 17:44:40 -08:00
LICENSE Add files 2022-12-19 17:44:40 -08:00
package-lock.json Add files 2022-12-19 17:44:40 -08:00
package.json Add files 2022-12-19 17:44:40 -08:00
README.md Add files 2022-12-19 17:44:40 -08:00
tsconfig.json Add files 2022-12-19 17:44:40 -08:00

Feishin

License Release Downloads Docker Docker pulls

Discord Matrix

Repository for the rewrite of Sonixd.

Getting Started

The default credentials to login will be admin/admin.

Download the latest desktop client.

Docker Compose

Warning: Check the environment variable configuration before running the commands below.

  1. Copy and rename example.env to .env and make any changes necessary
  2. Run the compose file: docker compose --file docker-compose.yml --env-file .env up

Docker

Warning: Check the environment variable configuration before running the commands below.

Run a postgres database container:

docker run postgres:13 \
  -p 5432:5432 \
  -e POSTGRES_USER=admin \
  -e POSTGRES_PASSWORD=admin \
  -e POSTGRES_DB=feishin

Run the Feishin server container:

docker run jeffvictorli/feishin:latest \
  -p 8643:9321 \
  -e APP_BASE_URL=http://192.168.0.1:8643 \
  -e DATABASE_PORT=5432 \
  -e DATABASE_URL=postgresql://admin:admin@localhost:5432/feishin?schema=public \
  -e TOKEN_SECRET=secret

Docker Environment Variables

APP_BASE_URL — The URL the site will be accessible at from your server (needed for CORS)

DATABASE_PORT — The port of your running postgres container

DATABASE_URL — The connection string to your postgres instance following this format: postgresql://<DB_USERNAME>:<DB_PASSWORD>@<DB_URL>/<DB_NAME>?schema=public

    Replace the following:
        <DB_USERNAME> — The admin username of your postgres container (POSTGRES_USER)
        <DB_PASSWORD> — The admin password of your postgres container (POSTGRES_PASSWORD)
        <DB_NAME> — The name of the database created in your postgres container (POSTGRES_DB)
        <DB_URL> — The URL the postgres container is reachable from

    Example: postgresql://admin:password@192.168.0.1:5432/feishin?schema=public

TOKEN_SECRET — The string used to sign auth tokens

(optional) TOKEN_EXPIRATION — The time before the auth JWT expires

(optional) TOKEN_REFRESH_EXPIRATION - The time before the auth JWT refresh token expires

After installing the server and database

You can access the desktop client via the latest release, or you can visit the web client at your server URL (e.g http://192.168.0.1:8643).

FAQ

Why is there a red lock next to the server I want to select?

If the server is specified to "require user credentials", you will need to add and enable your own credentials to access it. Since the songs and images aren't proxied by the Feishin backend, the server credentials would otherwise be leaked to any user that has access to it. The added credentials are stored locally in the browser and are then used to generate the audio and image URLs in the client.

What music servers does Feishin support?

Feishin supports any music server that implements a Subsonic, Navidrome, or Jellyfin API.

Why does Feishin use its own database and backend instead of just use (insert music server)'s API?

Feishin was an idea I had after I ran into usage limitations while building out Sonixd. Each music server has their own quirks, and I decided I wanted to consolidate and extend their features with my own backend implemntation which includes: web/desktop clients, advanced filtering, smart playlists, desktop MPV player, and more.

Can I use (insert database) instead of Postgresql?

Due to Prisma limitations, there is no easy way to switch to a different database provider at this time.

Development

Built and tested using Node v16.15.0.

This project is built off of electron-react-boilerplate v4.6.0.

Developing with Docker Compose

  1. Copy and rename the example.env to .env.dev and make any changes necessary
  2. Run the server: Use npm run docker:up to build and run the dev server
    1. Prisma studio available on http://localhost:5555
    2. Server available on http://localhost:8643
    3. Default seeded login credentials are admin/admin
  3. Run the client: Use npm run start to run the development Electron client
    1. The web version of the client is available on http://localhost:4343

Docker Compose files

docker-compose.yml — The public compose file for running the latest release

docker-compose.dev.yml - Build and run the development environment locally (includes Prisma studio)

docker-compose.prod.yml - Build and run the production environment locally

NPM Scripts:

$ npm run package — Packages the application for the local system

$ npm run start — Runs the development Electron and web client

$ npm run start:web — Runs the development web client

$ npm run docker:up — Builds and starts the docker development environment using the 'docker-compose.dev.yml' file

$ npm run docker:down — Stops the running docker development environment

$ npm run docker:dbpush — Pushes any schema changes made in 'schema.prisma' to the docker development database without migrating

$ npm run docker:migrate - Migrates any schema changes made in 'schema.prisma' and creates a migration file

$ npm run docker:createmigrate - Creates a migration file for any schema changes made in 'schema.prisma' without applying the migration

$ npm run docker:reset - Resets the docker development database and applies the default seed

$ npm run prod:buildserver - Builds and tags the server docker images locally with the 'latest' and '$VERSION' tags

$ npm run prod:publishserver - Pushes the locally build server docker images to docker hub

License

GNU General Public License v3.0 ©