Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jypelle/mifasol
Self-hosted music server in Go.
https://github.com/jypelle/mifasol
flac go golang mp3 music-library self-hosted wasm
Last synced: 2 months ago
JSON representation
Self-hosted music server in Go.
- Host: GitHub
- URL: https://github.com/jypelle/mifasol
- Owner: jypelle
- License: apache-2.0
- Created: 2019-10-02T17:37:53.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-03-12T17:00:21.000Z (almost 3 years ago)
- Last Synced: 2024-08-03T17:18:22.435Z (6 months ago)
- Topics: flac, go, golang, mp3, music-library, self-hosted, wasm
- Language: Go
- Homepage:
- Size: 4.02 MB
- Stars: 58
- Watchers: 2
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ![logo](docs/logo32.png) Mifasol
Mifasol is a self-hosted *opinionated* music server.
![mifasolsrv web_client](docs/mifasolsrv-web-screenshot.png)
![mifasolcli console client](docs/mifasolcli-ui-screenshot.png)
## Key features
1. Management of homonym artists and albums.
2. Management of multi-artist songs.
3. Avoiding playlists being broken updating songs, albums, or artists.
4. Listening to songs
- in streaming (via web or console clients)
- or locally (via file synchronization and the music player of your choice).
5. REST API for those who want to develop their own client.
6. Easy to
1. Install (one executable file to copy, and you are done)
2. Backup (all data in one folder)
3. Secure (https by default)
7. Blazing fast navigation with console & web clients.
8. Multiplatform.
9. You can even build your [own internet radio](https://github.com/jypelle/vekigi) to listen to your playlists !Mifasol is a free and open source project distributed under the permissive Apache 2.0 License.
## Table of Contents
- [Opinionated](#opinionated)
- [Mifasol server](#mifasol-server)
- [Installation](#installation)
- [Usage](#usage)
- [Where is my data stored ?](#where-is-my-data-stored-)
- [Auto start and stop mifasol server with systemd on linux](#auto-start-and-stop-mifasol-server-with-systemd-on-linux)
- [Mifasol web client](#mifasol-web-client)
- [Mifasol console client](#mifasol-console-client)
- [Installation](#installation-1)
- [Usage](#usage-1)### Opinionated
This software doesn’t try to satisfy the needs of everyone.
- The number of features is voluntarily limited to facilitate its maintenance.
- Only **flac** and **mp3** formats are supported.
- When you import some music on mifasol server, **song filenames are ignored**, only song tags are used to link your song to an artist, an album or to know the song name.
- Once your music is imported, **song tags are partially managed by mifasol server** and are used to generate song filename during files sync.
- **Only one-way sync is supported**: song files and playlists are copied from mifasol server to client device.## Mifasol server
### Installation
#### From prebuild binaries
Drop the dedicated `mifasolsrv` binary on your server and you are done.
#### From sources
You need:
- Linux
- Golang >= 1.17
- ANDROID_NDK_HOME set (to build android console client).
- GOROOT set```
make release
```### Usage
#### Run
```
mifasolsrv run
```Use Ctrl+C to gracefully stop it (and to avoid database corruption).
On first launch, `mifasolsrv run` will:
- Create default admin user with `mifasol`/`mifasol` as username/password
- Create a self-signed certificate valid for localhost only
- Listen requests on https://localhost:6620#### Configuration
If you want to access your server with those external urls: https://mypersonaldomain.org:6630 and https://77.77.77.77:6630, you should configure mifasolsrv accordingly with:
```
mifasolsrv config -hostnames mypersonaldomain.org,77.77.77.77 -n 6630 -enable-ssl
```#### More options
Run
```
mifasolsrv --help
mifasolsrv --help
```for more information.
### Where is my data stored ?
Configuration file, embedded database, song and cover files are all saved into **mifasolsrv** config folder:
- `$HOME/.config/mifasolsrv` on linux
- `%LocalAppData%\mifasolsrv` on windows
- `$HOME/Library/Application Support/mifasolsrv` on mac#### Backup data
- Stop mifasol server
- Backup **mifasolsrv** config folder content
- Start mifasol server#### Restore data
- Stop mifasol server
- Replace **mifasolsrv** config folder with content from your last backup
- Start mifasol server### Auto start and stop mifasol server with systemd on linux
- Copy `mifasolsrv` to `/usr/bin`
- Create systemd service file```
sudo touch /etc/systemd/system/mifasolsrv.service
sudo chmod 664 /etc/systemd/system/mifasolsrv.service
```- Edit /etc/systemd/system/mifasolsrv.service
```
[Unit]
Description=Mifasol server
[Service]
Type=simple
Restart=on-failure
ExecStart=/usr/bin/mifasolsrv run
User=myuser
Group=myuser
[Install]
WantedBy=multi-user.target
```- Enable & start mifasol server
```
sudo systemctl daemon-reload
sudo systemctl enable mifasolsrv.service
sudo systemctl start mifasolsrv.service
```## Mifasol web client
You just have to connect to your mifasol server: https://localhost:6620
## Mifasol console client
### Installation
#### From prebuild binaries
Mifasol server embeds clients, so you just have to download the dedicated `mifasolcli` binary from your mifasol server: https://localhost:6620
#### From sources
You need golang >= 1.17 and
- `libasound2-dev` on linux
- `mingw-w64` on windows
- `AudioToolbox.framework` on mac```
go install ./cmd/mifasolcli
```### Usage
#### Configuration
On first launch, *mifasolcli* try to connect to mifasol server using https://localhost:6620
(only accepting server self-signed certificate read on first connection) with `mifasol`/`mifasol` as username/password.You can change default configuration with:
```
mifasolcli config -hostname -n 6620 -u mifasol -p mifasol
```NB: \ should match with one of the hostnames configured on mifasol server.
#### Import music folder content to mifasol server
```
mifasolcli import [Location of music folder to import]
```*mifasolcli* will recursively loop through specified folder to import every `flac` and `mp3` files to mifasol server.
#### Sync local music folder with mifasol server's user favorite content
Prepare local music folder (one-time):
```
mifasolcli filesync init [Location of folder to synchronize]
```Launch synchronization:
```
mifasolcli filesync sync [Location of folder to synchronize]
```#### Console user interface
Run console user interface to manage and listen mifasol server content:
```
mifasolcli ui
```Press `h` to display available shortcuts to navigate through the interface.
##### Tips:
- **After a fresh server installation, use the console or web client to change the default username/password**.
- Windows users should use new *Windows Terminal* to correctly display unicode emojis.#### More options
Run
```
mifasolcli --help
mifasolcli --help
mifasolcli --help
```for more information.