A Plugin for MusicBee that allows you to control it through the MusicBee Remote Android Application
Application
Help
·
MusicBee Forum
·
Report Bug
·
Request Feature
- About the Project
- Installation
- Getting Started
- Usage
- Contributing
- Building
- Testing
- Formatting
- Releasing
- License
The plugin is an essential part of MusicBee Remote. It acts as a bridge that allows the Android application to communicate with MusicBee. The plugin exposes a socket server (TCP) that listens for incoming connections from the plugin.
It uses a text based protocol that is uses newline separated JSON messages. Those messages are then translated to calls of the MusicBee API.
- Autofac - Dependency Injection
- Newtonsoft.Json - JSON serialization
- NLog - Logging
mbrc-plugin/
├── core/ # Core library - business logic, services, protocol handling
├── plugin/ # MusicBee plugin - API integration, adapters
├── tests/ # Unit tests (xUnit, FluentAssertions, Moq)
├── api-debugger/ # Protocol testing GUI utility
└── firewall-utility/ # Windows firewall configuration tool
The core library is merged into plugin during build using ILRepack, producing a single mb_remote.dll.
Download the latest version from releases.
- Download
musicbee_remote_x.x.x.exe - Run the installer
- The installer will automatically detect your MusicBee installation and install the plugin
- Restart MusicBee if it was running
Note: The installer requires MusicBee 3.1 or later.
Use this method for the Microsoft Store version of MusicBee or if you prefer manual installation:
- Download
musicbee_remote_x.x.x.zip - Extract the contents
- Copy
mb_remote.dllto your MusicBee Plugins folder:- Regular installation:
C:\Program Files (x86)\MusicBee\Plugins\ - Store version:
%LOCALAPPDATA%\Packages\...\LocalCache\Roaming\MusicBee\Plugins\
- Regular installation:
- Optionally copy
firewall-utility.exeif you need to configure Windows Firewall - Restart MusicBee
After installation, the plugin should appear in MusicBee under Edit > Preferences > Plugins.
As a developer there are a few steps you need to follow to get started:
- Visual Studio 2022 Community (or later)
- .NET Framework 4.8 SDK
- MusicBee installed (for testing)
After getting the basic environment setup you just need to clone the project from command line:
git clone https://github.com/musicbeeremote/mbrc-plugin.gitor you could use your visual Git interface to clone the repository.
After cloning the project you can go and open the MBRC.sln solution in Visual Studio. The first
thing you need to do is to restore the NuGet dependencies so that you can start build the solution.
While building and testing the application you need a network interface that will listen for incoming connections. This has to be in the same network as the one where the device you use to test is.
If you are using a Windows Virtual Machine for development as I do, then you have to make sure that the
virtual machine is using a Bridged connection, otherwise you might not be able to connect to the plugin.
Contributions are always welcome. The contribution guide should follow soon.
You can build the application using any of these methods:
Visual Studio:
Open MBRC.sln and build the solution.
Command Line:
dotnet build -c ReleaseBuild Script (Windows):
build.bat # Release build (default)
build.bat Debug # Debug buildThe build process:
- Compiles
coreandpluginprojects - Uses ILRepack to merge
MusicBeeRemote.Core.dllintomb_remote.dll - In Debug mode, copies
mb_remote.dllto MusicBee's Plugins folder
The test project uses xUnit with FluentAssertions and Moq:
dotnet test tests/MusicBeeRemote.Core.Tests.csprojNote: Tests require Windows to run (net48 target framework).
The project uses EditorConfig for consistent code formatting. Most IDEs support EditorConfig natively or via plugins.
Check formatting:
dotnet format --verify-no-changesApply formatting:
dotnet formatKey style rules:
- 4 spaces indentation for C# files
- Braces on new lines (Allman style)
- Sort
Systemusings first - Use explicit types for built-in types,
varwhen type is apparent
Releases are automated via GitHub Actions when a version tag is pushed.
The version is centralized in Directory.Build.props:
<VersionPrefix>1.5.0</VersionPrefix>All projects (plugin, core, firewall-utility, api-debugger) inherit this version automatically.
- Update the version in
Directory.Build.props - Update
CHANGELOG.mdwith release notes - Commit the changes:
git add Directory.Build.props CHANGELOG.md git commit -m "chore: bump version to 1.5.0" git push - Create and push a tag:
git tag v1.5.0 git push origin v1.5.0
The CI pipeline will automatically:
- Build the plugin with the tagged version
- Create the NSIS installer (
musicbee_remote_1.5.0.exe) - Create the ZIP archive (
musicbee_remote_1.5.0.zip) - Generate SHA512 checksums
- Create build provenance attestations
- Publish a GitHub Release with all artifacts
Commits to main branch produce development builds with version suffix:
- Example:
1.5.0-nightly.123(where 123 is the build number)
These are available as workflow artifacts but not published as releases.
The source code of the application is licensed under the GPLv3 license. See LICENSE for more information
MusicBee Remote (Plugin for MusicBee)
Copyright (C) 2011-2026 Konstantinos Paparas
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.