diff --git a/MediaBrowser.Api/LibraryService.cs b/MediaBrowser.Api/LibraryService.cs index 04774cbe07..151f7016cc 100644 --- a/MediaBrowser.Api/LibraryService.cs +++ b/MediaBrowser.Api/LibraryService.cs @@ -131,9 +131,50 @@ namespace MediaBrowser.Api [Api(("Updates an item"))] public class UpdateItem : BaseItemDto, IReturnVoid { + [ApiMember(Name = "ItemId", Description = "The id of the item", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] public string ItemId { get; set; } } + [Route("/Artists/{ArtistName}", "POST")] + [Api(("Updates an artist"))] + public class UpdateArtist : BaseItemDto, IReturnVoid + { + [ApiMember(Name = "ArtistName", Description = "The name of the item", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] + public string ArtistName { get; set; } + } + + [Route("/Studios/{StudioName}", "POST")] + [Api(("Updates a studio"))] + public class UpdateStudio : BaseItemDto, IReturnVoid + { + [ApiMember(Name = "StudioName", Description = "The name of the item", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] + public string StudioName { get; set; } + } + + [Route("/Persons/{PersonName}", "POST")] + [Api(("Updates a person"))] + public class UpdatePerson : BaseItemDto, IReturnVoid + { + [ApiMember(Name = "PersonName", Description = "The name of the item", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] + public string PersonName { get; set; } + } + + [Route("/MusicGenres/{GenreName}", "POST")] + [Api(("Updates a music genre"))] + public class UpdateMusicGenre : BaseItemDto, IReturnVoid + { + [ApiMember(Name = "GenreName", Description = "The name of the item", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] + public string GenreName { get; set; } + } + + [Route("/Genres/{GenreName}", "POST")] + [Api(("Updates a genre"))] + public class UpdateGenre : BaseItemDto, IReturnVoid + { + [ApiMember(Name = "GenreName", Description = "The name of the item", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] + public string GenreName { get; set; } + } + /// /// Class LibraryService /// @@ -241,6 +282,93 @@ namespace MediaBrowser.Api { var item = DtoBuilder.GetItemByClientId(request.ItemId, _userManager, _libraryManager); + UpdateItem(request, item); + + return _libraryManager.UpdateItem(item, CancellationToken.None); + } + + public void Post(UpdatePerson request) + { + var task = UpdateItem(request); + + Task.WaitAll(task); + } + + private async Task UpdateItem(UpdatePerson request) + { + var item = await _libraryManager.GetPerson(request.PersonName).ConfigureAwait(false); + + UpdateItem(request, item); + + await _libraryManager.UpdateItem(item, CancellationToken.None).ConfigureAwait(false); + } + + public void Post(UpdateArtist request) + { + var task = UpdateItem(request); + + Task.WaitAll(task); + } + + private async Task UpdateItem(UpdateArtist request) + { + var item = await _libraryManager.GetArtist(request.ArtistName).ConfigureAwait(false); + + UpdateItem(request, item); + + await _libraryManager.UpdateItem(item, CancellationToken.None).ConfigureAwait(false); + } + + public void Post(UpdateStudio request) + { + var task = UpdateItem(request); + + Task.WaitAll(task); + } + + private async Task UpdateItem(UpdateStudio request) + { + var item = await _libraryManager.GetStudio(request.StudioName).ConfigureAwait(false); + + UpdateItem(request, item); + + await _libraryManager.UpdateItem(item, CancellationToken.None).ConfigureAwait(false); + } + + public void Post(UpdateMusicGenre request) + { + var task = UpdateItem(request); + + Task.WaitAll(task); + } + + private async Task UpdateItem(UpdateMusicGenre request) + { + var item = await _libraryManager.GetMusicGenre(request.GenreName).ConfigureAwait(false); + + UpdateItem(request, item); + + await _libraryManager.UpdateItem(item, CancellationToken.None).ConfigureAwait(false); + } + + public void Post(UpdateGenre request) + { + var task = UpdateItem(request); + + Task.WaitAll(task); + } + + private async Task UpdateItem(UpdateGenre request) + { + var item = await _libraryManager.GetGenre(request.GenreName).ConfigureAwait(false); + + UpdateItem(request, item); + + await _libraryManager.UpdateItem(item, CancellationToken.None).ConfigureAwait(false); + } + + private void UpdateItem(BaseItemDto request, BaseItem item) + { item.Name = request.Name; item.ForcedSortName = request.SortName; item.DisplayMediaType = request.DisplayMediaType; @@ -255,11 +383,11 @@ namespace MediaBrowser.Api item.Overview = request.Overview; item.Genres = request.Genres; item.Tags = request.Tags; - item.Studios = request.Studios.Select(x=>x.Name).ToList(); - item.People = request.People.Select(x=> new PersonInfo{Name = x.Name,Role = x.Role,Type = x.Type}).ToList(); + item.Studios = request.Studios.Select(x => x.Name).ToList(); + item.People = request.People.Select(x => new PersonInfo { Name = x.Name, Role = x.Role, Type = x.Type }).ToList(); item.EndDate = request.EndDate != default(DateTime) ? request.EndDate : null; - item.PremiereDate = request.PremiereDate != default(DateTime)? request.PremiereDate : null; + item.PremiereDate = request.PremiereDate != default(DateTime) ? request.PremiereDate : null; item.ProductionYear = request.ProductionYear; item.AspectRatio = request.AspectRatio; item.Language = request.Language; @@ -274,7 +402,7 @@ namespace MediaBrowser.Api { item.LockedFields.Clear(); } - + foreach (var pair in request.ProviderIds.ToList()) { if (string.IsNullOrEmpty(pair.Value)) @@ -315,9 +443,8 @@ namespace MediaBrowser.Api series.AirDays = request.AirDays; series.AirTime = request.AirTime; } - return _libraryManager.UpdateItem(item, CancellationToken.None); } - + /// /// Deletes the specified request. /// diff --git a/MediaBrowser.WebDashboard/ApiClient.js b/MediaBrowser.WebDashboard/ApiClient.js index f047501d29..c6234d41bb 100644 --- a/MediaBrowser.WebDashboard/ApiClient.js +++ b/MediaBrowser.WebDashboard/ApiClient.js @@ -1768,6 +1768,86 @@ MediaBrowser.ApiClient = function ($, navigator, JSON, WebSocket, setTimeout) { }); }; + self.updateArtist = function (item) { + + if (!item) { + throw new Error("null item"); + } + + var url = self.getUrl("Artists/" + self.encodeName(item.Name)); + + return self.ajax({ + type: "POST", + url: url, + data: JSON.stringify(item), + contentType: "application/json" + }); + }; + + self.updatePerson = function (item) { + + if (!item) { + throw new Error("null item"); + } + + var url = self.getUrl("Persons/" + self.encodeName(item.Name)); + + return self.ajax({ + type: "POST", + url: url, + data: JSON.stringify(item), + contentType: "application/json" + }); + }; + + self.updateStudio = function (item) { + + if (!item) { + throw new Error("null item"); + } + + var url = self.getUrl("Studios/" + self.encodeName(item.Name)); + + return self.ajax({ + type: "POST", + url: url, + data: JSON.stringify(item), + contentType: "application/json" + }); + }; + + self.updateGenre = function (item) { + + if (!item) { + throw new Error("null item"); + } + + var url = self.getUrl("Genres/" + self.encodeName(item.Name)); + + return self.ajax({ + type: "POST", + url: url, + data: JSON.stringify(item), + contentType: "application/json" + }); + }; + + self.updateMusicGenres = function (item) { + + if (!item) { + throw new Error("null item"); + } + + var url = self.getUrl("MusicGenres/" + self.encodeName(item.Name)); + + return self.ajax({ + type: "POST", + url: url, + data: JSON.stringify(item), + contentType: "application/json" + }); + }; + /** * Updates plugin security info */ diff --git a/MediaBrowser.WebDashboard/packages.config b/MediaBrowser.WebDashboard/packages.config index fa2c717016..980aefd611 100644 --- a/MediaBrowser.WebDashboard/packages.config +++ b/MediaBrowser.WebDashboard/packages.config @@ -1,6 +1,6 @@  - + \ No newline at end of file