aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--MediaBrowser.Api/UserLibrary/BaseItemsByNameService.cs25
-rw-r--r--MediaBrowser.Api/UserLibrary/GenresService.cs63
-rw-r--r--MediaBrowser.Api/UserLibrary/PersonsService.cs60
-rw-r--r--MediaBrowser.Api/UserLibrary/StudiosService.cs60
-rw-r--r--MediaBrowser.WebDashboard/Api/DashboardService.cs1
-rw-r--r--MediaBrowser.WebDashboard/ApiClient.js83
-rw-r--r--MediaBrowser.WebDashboard/packages.config2
7 files changed, 289 insertions, 5 deletions
diff --git a/MediaBrowser.Api/UserLibrary/BaseItemsByNameService.cs b/MediaBrowser.Api/UserLibrary/BaseItemsByNameService.cs
index 583f7460d..6801e14f0 100644
--- a/MediaBrowser.Api/UserLibrary/BaseItemsByNameService.cs
+++ b/MediaBrowser.Api/UserLibrary/BaseItemsByNameService.cs
@@ -1,4 +1,5 @@
-using MediaBrowser.Controller.Entities;
+using System.Threading;
+using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Library;
using MediaBrowser.Model.Dto;
using MediaBrowser.Model.Querying;
@@ -196,6 +197,28 @@ namespace MediaBrowser.Api.UserLibrary
return dto;
}
+
+ /// <summary>
+ /// Marks the favorite.
+ /// </summary>
+ /// <param name="getItem">The get item.</param>
+ /// <param name="userId">The user id.</param>
+ /// <param name="isFavorite">if set to <c>true</c> [is favorite].</param>
+ /// <returns>Task.</returns>
+ protected async Task MarkFavorite(Func<Task<TItemType>> getItem, Guid userId, bool isFavorite)
+ {
+ var user = UserManager.GetUserById(userId);
+
+ var item = await getItem().ConfigureAwait(false);
+
+ // Get the user data for this item
+ var data = await UserManager.GetUserData(user.Id, item.UserDataId).ConfigureAwait(false);
+
+ // Set favorite status
+ data.IsFavorite = isFavorite;
+
+ await UserManager.SaveUserData(user.Id, item.UserDataId, data, CancellationToken.None).ConfigureAwait(false);
+ }
}
/// <summary>
diff --git a/MediaBrowser.Api/UserLibrary/GenresService.cs b/MediaBrowser.Api/UserLibrary/GenresService.cs
index 13c441c63..54561f400 100644
--- a/MediaBrowser.Api/UserLibrary/GenresService.cs
+++ b/MediaBrowser.Api/UserLibrary/GenresService.cs
@@ -1,4 +1,5 @@
-using MediaBrowser.Controller.Entities;
+using System.Threading;
+using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Library;
using ServiceStack.ServiceHost;
using System;
@@ -18,6 +19,44 @@ namespace MediaBrowser.Api.UserLibrary
{
}
+ [Route("/Users/{UserId}/FavoriteGenres/{Name}", "POST")]
+ [Api(Description = "Marks a genre as a favorite")]
+ public class MarkFavoriteGenre : IReturnVoid
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")]
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ [ApiMember(Name = "Name", Description = "Name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Name { get; set; }
+ }
+
+ [Route("/Users/{UserId}/FavoriteGenres/{Name}", "DELETE")]
+ [Api(Description = "Unmarks a genre as a favorite")]
+ public class UnmarkFavoriteGenre : IReturnVoid
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ [ApiMember(Name = "Name", Description = "Name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Name { get; set; }
+ }
+
/// <summary>
/// Class GenresService
/// </summary>
@@ -41,6 +80,28 @@ namespace MediaBrowser.Api.UserLibrary
}
/// <summary>
+ /// Posts the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Post(MarkFavoriteGenre request)
+ {
+ var task = MarkFavorite(() => LibraryManager.GetGenre(request.Name), request.UserId, true);
+
+ Task.WaitAll(task);
+ }
+
+ /// <summary>
+ /// Deletes the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Delete(UnmarkFavoriteGenre request)
+ {
+ var task = MarkFavorite(() => LibraryManager.GetGenre(request.Name), request.UserId, false);
+
+ Task.WaitAll(task);
+ }
+
+ /// <summary>
/// Gets all items.
/// </summary>
/// <param name="request">The request.</param>
diff --git a/MediaBrowser.Api/UserLibrary/PersonsService.cs b/MediaBrowser.Api/UserLibrary/PersonsService.cs
index 020c373a0..4253ddc80 100644
--- a/MediaBrowser.Api/UserLibrary/PersonsService.cs
+++ b/MediaBrowser.Api/UserLibrary/PersonsService.cs
@@ -23,6 +23,44 @@ namespace MediaBrowser.Api.UserLibrary
public string PersonTypes { get; set; }
}
+ [Route("/Users/{UserId}/FavoritePersons/{Name}", "POST")]
+ [Api(Description = "Marks a person as a favorite")]
+ public class MarkFavoritePerson : IReturnVoid
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")]
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ [ApiMember(Name = "Name", Description = "Name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Name { get; set; }
+ }
+
+ [Route("/Users/{UserId}/FavoritePersons/{Name}", "DELETE")]
+ [Api(Description = "Unmarks a person as a favorite")]
+ public class UnmarkFavoritePerson : IReturnVoid
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ [ApiMember(Name = "Name", Description = "Name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Name { get; set; }
+ }
+
/// <summary>
/// Class PersonsService
/// </summary>
@@ -46,6 +84,28 @@ namespace MediaBrowser.Api.UserLibrary
}
/// <summary>
+ /// Posts the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Post(MarkFavoritePerson request)
+ {
+ var task = MarkFavorite(() => LibraryManager.GetPerson(request.Name), request.UserId, true);
+
+ Task.WaitAll(task);
+ }
+
+ /// <summary>
+ /// Deletes the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Delete(UnmarkFavoritePerson request)
+ {
+ var task = MarkFavorite(() => LibraryManager.GetPerson(request.Name), request.UserId, false);
+
+ Task.WaitAll(task);
+ }
+
+ /// <summary>
/// Gets all items.
/// </summary>
/// <param name="request">The request.</param>
diff --git a/MediaBrowser.Api/UserLibrary/StudiosService.cs b/MediaBrowser.Api/UserLibrary/StudiosService.cs
index 219475704..24f09c5ef 100644
--- a/MediaBrowser.Api/UserLibrary/StudiosService.cs
+++ b/MediaBrowser.Api/UserLibrary/StudiosService.cs
@@ -18,6 +18,44 @@ namespace MediaBrowser.Api.UserLibrary
{
}
+ [Route("/Users/{UserId}/FavoriteStudios/{Name}", "POST")]
+ [Api(Description = "Marks a studio as a favorite")]
+ public class MarkFavoriteStudio : IReturnVoid
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")]
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ [ApiMember(Name = "Name", Description = "Name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Name { get; set; }
+ }
+
+ [Route("/Users/{UserId}/FavoriteStudios/{Name}", "DELETE")]
+ [Api(Description = "Unmarks a studio as a favorite")]
+ public class UnmarkFavoriteStudio : IReturnVoid
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ [ApiMember(Name = "Name", Description = "Name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
+ public string Name { get; set; }
+ }
+
/// <summary>
/// Class StudiosService
/// </summary>
@@ -41,6 +79,28 @@ namespace MediaBrowser.Api.UserLibrary
}
/// <summary>
+ /// Posts the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Post(MarkFavoriteStudio request)
+ {
+ var task = MarkFavorite(() => LibraryManager.GetStudio(request.Name), request.UserId, true);
+
+ Task.WaitAll(task);
+ }
+
+ /// <summary>
+ /// Deletes the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ public void Delete(UnmarkFavoriteStudio request)
+ {
+ var task = MarkFavorite(() => LibraryManager.GetStudio(request.Name), request.UserId, false);
+
+ Task.WaitAll(task);
+ }
+
+ /// <summary>
/// Gets all items.
/// </summary>
/// <param name="request">The request.</param>
diff --git a/MediaBrowser.WebDashboard/Api/DashboardService.cs b/MediaBrowser.WebDashboard/Api/DashboardService.cs
index f5d4e4147..7756fb5b9 100644
--- a/MediaBrowser.WebDashboard/Api/DashboardService.cs
+++ b/MediaBrowser.WebDashboard/Api/DashboardService.cs
@@ -417,7 +417,6 @@ namespace MediaBrowser.WebDashboard.Api
"http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js",
"http://code.jquery.com/mobile/1.3.0/jquery.mobile-1.3.0.min.js",
"http://vjs.zencdn.net/c/video.js",
- "thirdparty/jplayer/jquery.jplayer.min.js" + versionString,
"scripts/all.js" + versionString
};
diff --git a/MediaBrowser.WebDashboard/ApiClient.js b/MediaBrowser.WebDashboard/ApiClient.js
index be4267d3c..65012f94d 100644
--- a/MediaBrowser.WebDashboard/ApiClient.js
+++ b/MediaBrowser.WebDashboard/ApiClient.js
@@ -1671,7 +1671,7 @@ MediaBrowser.ApiClient = function ($, navigator, JSON, WebSocket, setTimeout) {
};
/**
- * Updates a user's favorite status for an item and returns the updated UserItemData object.
+ * Updates a user's favorite status for an item.
* @param {String} userId
* @param {String} itemId
* @param {Boolean} isFavorite
@@ -1724,6 +1724,87 @@ MediaBrowser.ApiClient = function ($, navigator, JSON, WebSocket, setTimeout) {
};
/**
+ * Updates a user's favorite status for a person.
+ * @param {String} userId
+ * @param {String} name
+ * @param {Boolean} isFavorite
+ */
+ self.updateFavoritePersonStatus = function (userId, name, isFavorite) {
+
+ if (!userId) {
+ throw new Error("null userId");
+ }
+
+ if (!name) {
+ throw new Error("null name");
+ }
+
+ var url = self.getUrl("Users/" + userId + "/FavoritePersons/" + name);
+
+ var method = isFavorite ? "POST" : "DELETE";
+
+ return self.ajax({
+ type: method,
+ url: url,
+ dataType: "json"
+ });
+ };
+
+ /**
+ * Updates a user's favorite status for a genre.
+ * @param {String} userId
+ * @param {String} name
+ * @param {Boolean} isFavorite
+ */
+ self.updateFavoriteGenreStatus = function (userId, name, isFavorite) {
+
+ if (!userId) {
+ throw new Error("null userId");
+ }
+
+ if (!name) {
+ throw new Error("null name");
+ }
+
+ var url = self.getUrl("Users/" + userId + "/FavoriteGenre/" + name);
+
+ var method = isFavorite ? "POST" : "DELETE";
+
+ return self.ajax({
+ type: method,
+ url: url,
+ dataType: "json"
+ });
+ };
+
+ /**
+ * Updates a user's favorite status for a studio.
+ * @param {String} userId
+ * @param {String} name
+ * @param {Boolean} isFavorite
+ */
+ self.updateFavoriteStudioStatus = function (userId, name, isFavorite) {
+
+ if (!userId) {
+ throw new Error("null userId");
+ }
+
+ if (!name) {
+ throw new Error("null name");
+ }
+
+ var url = self.getUrl("Users/" + userId + "/FavoriteStudios/" + name);
+
+ var method = isFavorite ? "POST" : "DELETE";
+
+ return self.ajax({
+ type: method,
+ url: url,
+ dataType: "json"
+ });
+ };
+
+ /**
* Clears a user's personal rating for an item
* @param {String} userId
* @param {String} itemId
diff --git a/MediaBrowser.WebDashboard/packages.config b/MediaBrowser.WebDashboard/packages.config
index 8669c3db3..74c1b370f 100644
--- a/MediaBrowser.WebDashboard/packages.config
+++ b/MediaBrowser.WebDashboard/packages.config
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<packages>
- <package id="MediaBrowser.ApiClient.Javascript" version="3.0.73" targetFramework="net45" />
+ <package id="MediaBrowser.ApiClient.Javascript" version="3.0.74" targetFramework="net45" />
<package id="ServiceStack.Common" version="3.9.43" targetFramework="net45" />
<package id="ServiceStack.Text" version="3.9.43" targetFramework="net45" />
</packages> \ No newline at end of file