aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Api/Library/LibraryService.cs
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2016-01-19 14:03:46 -0500
committerLuke Pulverenti <luke.pulverenti@gmail.com>2016-01-19 14:10:16 -0500
commitb23f9765117820481cce204461df10bcdbc8c466 (patch)
treece4085e9f69a47f732c45f1030526703bc1cc59b /MediaBrowser.Api/Library/LibraryService.cs
parent14fe4ab95cd08745acd2634ac25a57c4977ac1b4 (diff)
add delete to multi-select
Diffstat (limited to 'MediaBrowser.Api/Library/LibraryService.cs')
-rw-r--r--MediaBrowser.Api/Library/LibraryService.cs62
1 files changed, 46 insertions, 16 deletions
diff --git a/MediaBrowser.Api/Library/LibraryService.cs b/MediaBrowser.Api/Library/LibraryService.cs
index 319bc13fd..b7066a36d 100644
--- a/MediaBrowser.Api/Library/LibraryService.cs
+++ b/MediaBrowser.Api/Library/LibraryService.cs
@@ -162,6 +162,14 @@ namespace MediaBrowser.Api.Library
public string Id { get; set; }
}
+ [Route("/Items", "DELETE", Summary = "Deletes an item from the library and file system")]
+ [Authenticated]
+ public class DeleteItems : IReturnVoid
+ {
+ [ApiMember(Name = "Ids", Description = "Ids", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Ids { get; set; }
+ }
+
[Route("/Items/Counts", "GET")]
[Authenticated]
public class GetItemCounts : IReturn<ItemCounts>
@@ -715,27 +723,49 @@ namespace MediaBrowser.Api.Library
/// Deletes the specified request.
/// </summary>
/// <param name="request">The request.</param>
- public void Delete(DeleteItem request)
+ public void Delete(DeleteItems request)
{
- var item = _libraryManager.GetItemById(request.Id);
- var auth = _authContext.GetAuthorizationInfo(Request);
- var user = _userManager.GetUserById(auth.UserId);
+ var ids = string.IsNullOrWhiteSpace(request.Ids)
+ ? new string[] { }
+ : request.Ids.Split(',');
- if (!item.CanDelete(user))
+ var tasks = ids.Select(i =>
{
- throw new SecurityException("Unauthorized access");
- }
+ var item = _libraryManager.GetItemById(i);
+ var auth = _authContext.GetAuthorizationInfo(Request);
+ var user = _userManager.GetUserById(auth.UserId);
- if (item is ILiveTvRecording)
- {
- var task = _liveTv.DeleteRecording(request.Id);
- Task.WaitAll(task);
- }
- else
+ if (!item.CanDelete(user))
+ {
+ if (ids.Length > 1)
+ {
+ throw new SecurityException("Unauthorized access");
+ }
+
+ return Task.FromResult(true);
+ }
+
+ if (item is ILiveTvRecording)
+ {
+ return _liveTv.DeleteRecording(i);
+ }
+
+ return _libraryManager.DeleteItem(item);
+ }).ToArray();
+
+ Task.WaitAll(tasks);
+ }
+
+ /// <summary>
+ /// Deletes the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Delete(DeleteItem request)
+ {
+ Delete(new DeleteItems
{
- var task = _libraryManager.DeleteItem(item);
- Task.WaitAll(task);
- }
+ Ids = request.Id
+ });
}
/// <summary>