mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-04 03:27:21 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			133 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System.Collections.Generic;
 | 
						|
using System.ComponentModel.DataAnnotations;
 | 
						|
using Jellyfin.Api.Constants;
 | 
						|
using MediaBrowser.Controller.Dlna;
 | 
						|
using MediaBrowser.Model.Dlna;
 | 
						|
using Microsoft.AspNetCore.Authorization;
 | 
						|
using Microsoft.AspNetCore.Http;
 | 
						|
using Microsoft.AspNetCore.Mvc;
 | 
						|
 | 
						|
namespace Jellyfin.Api.Controllers;
 | 
						|
 | 
						|
/// <summary>
 | 
						|
/// Dlna Controller.
 | 
						|
/// </summary>
 | 
						|
[Authorize(Policy = Policies.RequiresElevation)]
 | 
						|
public class DlnaController : BaseJellyfinApiController
 | 
						|
{
 | 
						|
    private readonly IDlnaManager _dlnaManager;
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Initializes a new instance of the <see cref="DlnaController"/> class.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="dlnaManager">Instance of the <see cref="IDlnaManager"/> interface.</param>
 | 
						|
    public DlnaController(IDlnaManager dlnaManager)
 | 
						|
    {
 | 
						|
        _dlnaManager = dlnaManager;
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Get profile infos.
 | 
						|
    /// </summary>
 | 
						|
    /// <response code="200">Device profile infos returned.</response>
 | 
						|
    /// <returns>An <see cref="OkResult"/> containing the device profile infos.</returns>
 | 
						|
    [HttpGet("ProfileInfos")]
 | 
						|
    [ProducesResponseType(StatusCodes.Status200OK)]
 | 
						|
    public ActionResult<IEnumerable<DeviceProfileInfo>> GetProfileInfos()
 | 
						|
    {
 | 
						|
        return Ok(_dlnaManager.GetProfileInfos());
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets the default profile.
 | 
						|
    /// </summary>
 | 
						|
    /// <response code="200">Default device profile returned.</response>
 | 
						|
    /// <returns>An <see cref="OkResult"/> containing the default profile.</returns>
 | 
						|
    [HttpGet("Profiles/Default")]
 | 
						|
    [ProducesResponseType(StatusCodes.Status200OK)]
 | 
						|
    public ActionResult<DeviceProfile> GetDefaultProfile()
 | 
						|
    {
 | 
						|
        return _dlnaManager.GetDefaultProfile();
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets a single profile.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="profileId">Profile Id.</param>
 | 
						|
    /// <response code="200">Device profile returned.</response>
 | 
						|
    /// <response code="404">Device profile not found.</response>
 | 
						|
    /// <returns>An <see cref="OkResult"/> containing the profile on success, or a <see cref="NotFoundResult"/> if device profile not found.</returns>
 | 
						|
    [HttpGet("Profiles/{profileId}")]
 | 
						|
    [ProducesResponseType(StatusCodes.Status200OK)]
 | 
						|
    [ProducesResponseType(StatusCodes.Status404NotFound)]
 | 
						|
    public ActionResult<DeviceProfile> GetProfile([FromRoute, Required] string profileId)
 | 
						|
    {
 | 
						|
        var profile = _dlnaManager.GetProfile(profileId);
 | 
						|
        if (profile is null)
 | 
						|
        {
 | 
						|
            return NotFound();
 | 
						|
        }
 | 
						|
 | 
						|
        return profile;
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Deletes a profile.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="profileId">Profile id.</param>
 | 
						|
    /// <response code="204">Device profile deleted.</response>
 | 
						|
    /// <response code="404">Device profile not found.</response>
 | 
						|
    /// <returns>A <see cref="NoContentResult"/> on success, or a <see cref="NotFoundResult"/> if profile not found.</returns>
 | 
						|
    [HttpDelete("Profiles/{profileId}")]
 | 
						|
    [ProducesResponseType(StatusCodes.Status204NoContent)]
 | 
						|
    [ProducesResponseType(StatusCodes.Status404NotFound)]
 | 
						|
    public ActionResult DeleteProfile([FromRoute, Required] string profileId)
 | 
						|
    {
 | 
						|
        var existingDeviceProfile = _dlnaManager.GetProfile(profileId);
 | 
						|
        if (existingDeviceProfile is null)
 | 
						|
        {
 | 
						|
            return NotFound();
 | 
						|
        }
 | 
						|
 | 
						|
        _dlnaManager.DeleteProfile(profileId);
 | 
						|
        return NoContent();
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Creates a profile.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="deviceProfile">Device profile.</param>
 | 
						|
    /// <response code="204">Device profile created.</response>
 | 
						|
    /// <returns>A <see cref="NoContentResult"/>.</returns>
 | 
						|
    [HttpPost("Profiles")]
 | 
						|
    [ProducesResponseType(StatusCodes.Status204NoContent)]
 | 
						|
    public ActionResult CreateProfile([FromBody] DeviceProfile deviceProfile)
 | 
						|
    {
 | 
						|
        _dlnaManager.CreateProfile(deviceProfile);
 | 
						|
        return NoContent();
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Updates a profile.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="profileId">Profile id.</param>
 | 
						|
    /// <param name="deviceProfile">Device profile.</param>
 | 
						|
    /// <response code="204">Device profile updated.</response>
 | 
						|
    /// <response code="404">Device profile not found.</response>
 | 
						|
    /// <returns>A <see cref="NoContentResult"/> on success, or a <see cref="NotFoundResult"/> if profile not found.</returns>
 | 
						|
    [HttpPost("Profiles/{profileId}")]
 | 
						|
    [ProducesResponseType(StatusCodes.Status204NoContent)]
 | 
						|
    [ProducesResponseType(StatusCodes.Status404NotFound)]
 | 
						|
    public ActionResult UpdateProfile([FromRoute, Required] string profileId, [FromBody] DeviceProfile deviceProfile)
 | 
						|
    {
 | 
						|
        var existingDeviceProfile = _dlnaManager.GetProfile(profileId);
 | 
						|
        if (existingDeviceProfile is null)
 | 
						|
        {
 | 
						|
            return NotFound();
 | 
						|
        }
 | 
						|
 | 
						|
        _dlnaManager.UpdateProfile(profileId, deviceProfile);
 | 
						|
        return NoContent();
 | 
						|
    }
 | 
						|
}
 |