Aonsoku
A modern desktop client for Navidrome/Subsonic servers built with React and Electron.
Install / Use
/learn @victoralvesf/AonsokuREADME
<a id="readme-top"></a>
<br /> <div align="center"> <a href="https://github.com/victoralvesf/aonsoku"> <img src="./resources/icons/icon.png" alt="Aonsoku" width="80" height="80"> </a> <h3 align="center">Aonsoku</h3> <p align="center"> A modern desktop client for Navidrome/Subsonic servers built with React and Electron. <br /> <br /> <a href="https://aonsoku.vercel.app">Web App</a> · <a href="https://github.com/victoralvesf/aonsoku/issues/new?labels=bug&template=bug-report---.md">Report Bug</a> · <a href="https://github.com/victoralvesf/aonsoku/issues/new?labels=enhancement&template=feature-request---.md">Request Feature</a> </p>[![React][React.js]][React-url] [![Electron][Electron]][Electron-url]
[![Download][Download-badge]][Download-url] [![Flathub][Flathub-badge]][Flathub-url]
</div> <!-- TABLE OF CONTENTS --> <details open> <summary>Table of Contents</summary> <ol> <li> <a href="#features">Features</a> </li> <li> <a href="#screenshots">Screenshots</a> </li> <li> <a href="#getting-started">Getting Started</a> <ul> <li><a href="#prerequisites">Prerequisites</a></li> <li><a href="#installation">Installation</a></li> <li><a href="#running">Running</a></li> <li><a href="#recommended-ide-setup">Recommended IDE Setup</a></li> </ul> </li> <li><a href="#apple-users">macOS Users: "App cannot be opened" or Crash on Launch</a></li> <li><a href="#roadmap">Roadmap</a></li> <li><a href="#contributing">Contributing</a></li> <li><a href="#translation">Translation</a></li> <li><a href="#license">License</a></li> </ol> </details> <!-- ABOUT THE PROJECT -->Features
- Subsonic Integration: Aonsoku integrates with your Navidrome or Subsonic server, providing you with easy access to your music collection.
- Intuitive UI: Modern, clean and user-friendly interface designed to enhance your music listening experience.
- Podcast Support: With Aonsoku Podcasts you can easily access, manage, and listen to your favorites podcasts directly within the app. Enjoy advanced search options, customizable filters and seamless listening synchronization to enhance your podcast experience.
- Synchronized lyrics: Aonsoku will automatically find a synced lyric from LRCLIB if none is provided by the server.
- Unsynchronized lyrics: If your songs have embedded unsynchronized lyrics, Aonsoku is able to show them.
- Radio: If your server supports it, listen to radio shows directly within Aonsoku.
- Scrobble: Sync played songs with your server.
Screenshots
<a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/home.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/home.png" width="49.5%"/></a> <a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/album.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/album.png" width="49.5%"/></a>
<a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/playlist.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/playlist.png" width="49.5%"/></a> <a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/albums.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/albums.png" width="49.5%"/></a>
<a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/albumsByArtist.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/albumsByArtist.png" width="49.5%"/></a> <a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/artist.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/artist.png" width="49.5%"/></a>
<a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/player.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/player.png" width="49.5%"/></a> <a href="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/lyrics.png"><img src="https://raw.githubusercontent.com/victoralvesf/aonsoku/main/media/lyrics.png" width="49.5%"/></a>
<p align="right">(<a href="#readme-top">back to top</a>)</p>Getting Started
Prerequisites
- Node.js
- pnpm, npm or yarn
- cargo
Installation
- Clone the repo
git clone https://github.com/victoralvesf/aonsoku.git
- Install NPM packages
pnpm install
Running
- Web App
pnpm run dev
- Desktop App
pnpm run electron:dev
- Docker
version: '3.8'
services:
aonsoku:
container_name: aonsoku
image: ghcr.io/victoralvesf/aonsoku:latest
restart: unless-stopped
ports:
- 8080:8080
- Podman Quadlet
[Unit]
Description=Aonsoku Container
[Container]
ContainerName=aonsoku
Image=ghcr.io/victoralvesf/aonsoku:latest
PublishPort=8080:8080
AutoUpdate=registry
[Service]
Restart=always
[Install]
WantedBy=multi-user.target default.target
<details>
<summary>Environment Variables</summary>
</br>
Below is a table describing the environment variables that can be used in this project. Adjust them as necessary in your .env file.
| Variable | Default | Description | Required for Automatic Login |
|-----------------------|------------|-------------------------------------------------------------------------------------------------------------------|------------------------------|
| PORT | 8080 | The port the application runs on. | |
| SERVER_URL | | If you want the app to access a predefined Subsonic server. </br> Format: http://your-subsonic-server:port. | ✅ |
| HIDE_SERVER | false | Set to true to hide the server URL field on login and only show username and password. | ✅ |
| APP_USER | | The username for automatic login. | ✅ |
| APP_PASSWORD | | The password for automatic login. | ✅ |
| APP_AUTH_TYPE | token | Specifies the authentication method. </br> Options: token or password. | |
| SERVER_TYPE | subsonic | Specifies the server name (important for some fixes). </br> Options: subsonic, navidrome or lms | |
| HIDE_RADIOS_SECTION | false | Set to true to hide the radios page from the sidebar menu. | |
| APP_THEME | dark | Specify the app theme. </br> Possible values: light, dark, black, one-dark, night-owl-light, marmalade-beaver, noctis-lilac, material-theme, monokai-pro, github-dark, shades-of-purple, bearded-solarized, catppuccin-mocha, nuclear-dark, achiever, dracula, discord, tinacious-design, vue-dark, vim-dark-soft. | |
| APP_HIDE_THEMES | false | Set to true to hide the themes section so the user cannot change the theme. | |
| IMAGE_CACHE_ENABLED | false | Set to true to enable the image cache. | |
| DISABLE_IMAGE_CACHE_TOGGLE | false | Set to true to prevent the user from changing the image cache setting. | |
| DISABLE_DOWNLOADS | false | Set to true to disable song downloads. | |
| DISABLE_LRCLIB | false | Set to true to disable downloading lyrics from LRCLIB. | |
Notes:
- Automatic Login: To enable automatic login across devices. This should only be used in secure local environments to avoid password compromise.
- Legacy Authentication: Use
APP_AUTH_TYPE=passwordonly if your server does not support token-based authentication.
Recommended IDE Setup
<p align="right">(<a href="#readme-top">back to top</a>)</p> <div id="apple-users"></div>macOS Users: "App cannot be opened" or Crash on Launch
Since this application is not signed and notarized by Apple, macOS Gatekeeper may block it from running to protect your system. You might encounter:
- A message saying the app "is damaged and can't be opened."
- An immediate crash or error window upon launching.
To fix this, please follow these steps:
- Move Aonsoku to your
/Applicationsfolder. - Open your Terminal.
- Run the following commands to repair the permission and signature (you may need to enter your system password):
# 1. Remove the quarantine attribute (Fixes "App is damaged")
sudo xattr -cr /Applications/Aonsoku.app
# 2. Re-sign the application locally (Fixes immediate crashes/library errors)
sudo codesign --force --deep --sign - /Applications/Aonsoku.app
- You can now o
Related Skills
bluebubbles
339.3kUse when you need to send or manage iMessages via BlueBubbles (recommended iMessage integration). Calls go through the generic message tool with channel="bluebubbles".
node-connect
339.3kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
slack
339.3kUse when you need to control Slack from OpenClaw via the slack tool, including reacting to messages or pinning/unpinning items in Slack channels or DMs.
frontend-design
83.9kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
