From b58fdb6b42829b57349602e0dad45dd903a8aa55 Mon Sep 17 00:00:00 2001 From: HiFiBerry Date: Wed, 26 Feb 2020 09:56:22 +0100 Subject: [PATCH] Update architecture.md --- doc/architecture.md | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/doc/architecture.md b/doc/architecture.md index 22ed4c6e..f945341f 100644 --- a/doc/architecture.md +++ b/doc/architecture.md @@ -14,6 +14,26 @@ Adding a services requires two steps: 2. Add the player module to the GUI. The simplest GUI would be just a UI that can only enable/disable the service. You might add more options (e.g. configuration parameters that the user should be able to set) + +## Dos and don'ts + +### Automatic configuration + +A player service should configure itself automatically. The user should not have to deal with device names, mixer controls or stuff like this. There might be services that might require some configuration (e.g. a server name), but try to keep this as minimal as possible. If a server can be automatically discovered using mDNS or similar mechanisms, you should use these and not provide a configuration for the IP address in the UI. + +### Volume control + +Volume control should be handled via ALSA. A service should not change the volume if it isn't active. It should also not change it when it starts or shuts down. The ALSA mixer device can vary between different sound cards. Therefore, use the control from /etc/hifiberry.state + +### Systemd + +All services need to be started by systemd. Use the correct dependencies and use restart, but make sure that a service that immediately crashes doesn't get restarted too fast. + + +~~~~ +Restart=always +RestartSec=5 +~~~~