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:03:46 -0500
commita2a620a4c4d5dd36c50aa8786ce7fae220665ab9 (patch)
treebb7d3cf733598455e2de5dd31b2d4e828411e1f0 /MediaBrowser.Api/Library/LibraryService.cs
parenta04f4421bd389caff1036e6e11a6eeb6821781e5 (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 80076d073..0563727d9 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>
@@ -759,27 +767,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>