163 lines
3.9 KiB
Nix
163 lines
3.9 KiB
Nix
|
{ config, lib, pkgs, ... }:
|
||
|
|
||
|
{
|
||
|
services.mopidy = {
|
||
|
enable = true;
|
||
|
extensionPackages = with pkgs; [
|
||
|
#mopidy-spotify
|
||
|
mopidy-iris
|
||
|
mopidy-local
|
||
|
mopidy-mpd
|
||
|
mopidy-podcast
|
||
|
mopidy-youtube
|
||
|
];
|
||
|
|
||
|
configuration = ''
|
||
|
|
||
|
[mpd]
|
||
|
hostname = ::
|
||
|
|
||
|
[http]
|
||
|
hostname = 0.0.0.0
|
||
|
|
||
|
[local]
|
||
|
enabled = true
|
||
|
media_dir = /media/syncthing/music-library
|
||
|
|
||
|
[file]
|
||
|
enabled = false
|
||
|
media_dirs =
|
||
|
/media/syncthing/music-library|Penis
|
||
|
|
||
|
[iris]
|
||
|
country = de
|
||
|
locale = de_DE
|
||
|
|
||
|
[audio]
|
||
|
output = alsasink
|
||
|
|
||
|
[stream]
|
||
|
enabled = true
|
||
|
timeout = 5000
|
||
|
protocols =
|
||
|
http
|
||
|
https
|
||
|
mms
|
||
|
rtmp
|
||
|
rtmps
|
||
|
rtsp
|
||
|
'';
|
||
|
};
|
||
|
|
||
|
users.groups."syncthing".members = [ "mopidy" ];
|
||
|
|
||
|
sound.enable = true;
|
||
|
|
||
|
networking.firewall.allowedTCPPorts = [
|
||
|
6680 # mopidy
|
||
|
6600 # mpd
|
||
|
1234 # zeroconf
|
||
|
];
|
||
|
|
||
|
users.users."spotifyd" = {
|
||
|
isSystemUser = true;
|
||
|
};
|
||
|
|
||
|
sops.secrets.spotify_pass = {
|
||
|
owner = "spotifyd";
|
||
|
};
|
||
|
sops.secrets.spotify_user = {
|
||
|
owner = "spotifyd";
|
||
|
};
|
||
|
|
||
|
services.spotifyd.enable = true;
|
||
|
services.spotifyd.config = ''
|
||
|
[global]
|
||
|
# Your Spotify account name.
|
||
|
#username = "yolo"
|
||
|
username_cmd = "cat ${config.sops.secrets.spotify_user.path}"
|
||
|
|
||
|
# A command that gets executed and can be used to
|
||
|
# retrieve your password.
|
||
|
# The command should return the password on stdout.
|
||
|
#
|
||
|
# This is an alternative to the `password` field. Both
|
||
|
# can't be used simultaneously.
|
||
|
password_cmd = "cat ${config.sops.secrets.spotify_pass.path}"
|
||
|
|
||
|
# If set to true, `spotifyd` tries to look up your
|
||
|
# password in the system's password storage.
|
||
|
#
|
||
|
# This is an alternative to the `password` field. Both
|
||
|
# can't be used simultaneously.
|
||
|
#use_keyring = true
|
||
|
|
||
|
# If set to true, `spotifyd` tries to bind to the session dbus
|
||
|
# and expose MPRIS controls. When running headless, without a dbus session,
|
||
|
# then set this to false to avoid binding errors
|
||
|
#
|
||
|
#use_mpris = true
|
||
|
|
||
|
# The audio backend used to play the your music. To get
|
||
|
# a list of possible backends, run `spotifyd --help`.
|
||
|
backend = "alsa" # use portaudio for macOS [homebrew]
|
||
|
|
||
|
# The alsa audio device to stream audio to. To get a
|
||
|
# list of valid devices, run `aplay -L`,
|
||
|
#device = "alsa_audio_device" # omit for macOS
|
||
|
|
||
|
# The alsa control device. By default this is the same
|
||
|
# name as the `device` field.
|
||
|
#control = "alsa_audio_device" # omit for macOS
|
||
|
|
||
|
# The alsa mixer used by `spotifyd`.
|
||
|
mixer = "PCM" # omit for macOS
|
||
|
|
||
|
# The volume controller. Each one behaves different to
|
||
|
# volume increases. For possible values, run
|
||
|
# `spotifyd --help`.
|
||
|
volume_controller = "alsa" # use softvol for macOS
|
||
|
|
||
|
# The name that gets displayed under the connect tab on
|
||
|
# official clients. Spaces are not allowed!
|
||
|
device_name = "Pepe"
|
||
|
|
||
|
# The audio bitrate. 96, 160 or 320 kbit/s
|
||
|
bitrate = 160
|
||
|
|
||
|
# The directory used to cache audio data. This setting can save
|
||
|
# a lot of bandwidth when activated, as it will avoid re-downloading
|
||
|
# audio files when replaying them.
|
||
|
#
|
||
|
# Note: The file path does not get expanded. Environment variables and
|
||
|
# shell placeholders like $HOME or ~ don't work!
|
||
|
#cache_path = "cache_directory"
|
||
|
|
||
|
# If set to true, audio data does NOT get cached.
|
||
|
no_audio_cache = true
|
||
|
|
||
|
# Volume on startup between 0 and 100
|
||
|
# NOTE: This variable's type will change in v0.4, to a number (instead of string)
|
||
|
initial_volume = "90"
|
||
|
|
||
|
# If set to true, enables volume normalisation between songs.
|
||
|
volume_normalisation = true
|
||
|
|
||
|
# The normalisation pregain that is applied for each song.
|
||
|
normalisation_pregain = -10
|
||
|
|
||
|
# The port `spotifyd` uses to announce its service over the network.
|
||
|
zeroconf_port = 1234
|
||
|
|
||
|
# The proxy `spotifyd` will use to connect to spotify.
|
||
|
#proxy = "http://proxy.example.org:8080"
|
||
|
|
||
|
# The displayed device type in Spotify clients.
|
||
|
# Can be unknown, computer, tablet, smartphone, speaker, t_v,
|
||
|
# a_v_r (Audio/Video Receiver), s_t_b (Set-Top Box), and audio_dongle.
|
||
|
device_type = "computer"
|
||
|
'';
|
||
|
|
||
|
|
||
|
}
|