using MediaBrowser.Model.Plugins;
namespace Jellyfin.Plugin.JellyLMS.Configuration;
///
/// Plugin configuration for JellyLMS.
///
public class PluginConfiguration : BasePluginConfiguration
{
///
/// Initializes a new instance of the class.
///
public PluginConfiguration()
{
LmsServerUrl = "http://localhost:9000";
LmsUsername = string.Empty;
LmsPassword = string.Empty;
JellyfinServerUrl = "http://localhost:8096";
ConnectionTimeoutSeconds = 10;
EnableAutoSync = true;
DefaultPlayerMac = string.Empty;
}
///
/// Gets or sets the LMS server URL (e.g., http://192.168.1.100:9000).
///
public string LmsServerUrl { get; set; }
///
/// Gets or sets the LMS username (if authentication is enabled).
///
public string LmsUsername { get; set; }
///
/// Gets or sets the LMS password (if authentication is enabled).
///
public string LmsPassword { get; set; }
///
/// Gets or sets the Jellyfin server URL that LMS will use to stream audio.
/// This should be accessible from the LMS server.
///
public string JellyfinServerUrl { get; set; }
///
/// Gets or sets the connection timeout in seconds.
///
public int ConnectionTimeoutSeconds { get; set; }
///
/// Gets or sets a value indicating whether to automatically sync players
/// when playing to multiple devices.
///
public bool EnableAutoSync { get; set; }
///
/// Gets or sets the default player MAC address to use when none is specified.
///
public string DefaultPlayerMac { get; set; }
///
/// Gets or sets the Jellyfin API key for authenticating stream requests from LMS.
///
public string JellyfinApiKey { get; set; } = string.Empty;
}