RequestHelpers.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using MediaBrowser.Model.Entities;
  5. using MediaBrowser.Model.Querying;
  6. namespace Jellyfin.Api.Helpers
  7. {
  8. /// <summary>
  9. /// Request Extensions.
  10. /// </summary>
  11. public static class RequestHelpers
  12. {
  13. /// <summary>
  14. /// Get Order By.
  15. /// </summary>
  16. /// <param name="sortBy">Sort By. Comma delimited string.</param>
  17. /// <param name="requestedSortOrder">Sort Order. Comma delimited string.</param>
  18. /// <returns>Order By.</returns>
  19. public static ValueTuple<string, SortOrder>[] GetOrderBy(string? sortBy, string? requestedSortOrder)
  20. {
  21. var val = sortBy;
  22. if (string.IsNullOrEmpty(val))
  23. {
  24. return Array.Empty<ValueTuple<string, SortOrder>>();
  25. }
  26. var vals = val.Split(',');
  27. if (string.IsNullOrWhiteSpace(requestedSortOrder))
  28. {
  29. requestedSortOrder = "Ascending";
  30. }
  31. var sortOrders = requestedSortOrder.Split(',');
  32. var result = new ValueTuple<string, SortOrder>[vals.Length];
  33. for (var i = 0; i < vals.Length; i++)
  34. {
  35. var sortOrderIndex = sortOrders.Length > i ? i : 0;
  36. var sortOrderValue = sortOrders.Length > sortOrderIndex ? sortOrders[sortOrderIndex] : null;
  37. var sortOrder = string.Equals(sortOrderValue, "Descending", StringComparison.OrdinalIgnoreCase)
  38. ? SortOrder.Descending
  39. : SortOrder.Ascending;
  40. result[i] = new ValueTuple<string, SortOrder>(vals[i], sortOrder);
  41. }
  42. return result;
  43. }
  44. /// <summary>
  45. /// Gets the item fields.
  46. /// </summary>
  47. /// <param name="fields">The fields.</param>
  48. /// <returns>IEnumerable{ItemFields}.</returns>
  49. public static ItemFields[] GetItemFields(string? fields)
  50. {
  51. if (string.IsNullOrEmpty(fields))
  52. {
  53. return Array.Empty<ItemFields>();
  54. }
  55. return fields.Split(',').Select(v =>
  56. {
  57. if (Enum.TryParse(v, true, out ItemFields value))
  58. {
  59. return (ItemFields?)value;
  60. }
  61. return null;
  62. }).Where(i => i.HasValue).Select(i => i!.Value).ToArray();
  63. }
  64. /// <summary>
  65. /// Get parsed filters.
  66. /// </summary>
  67. /// <param name="filters">The filters.</param>
  68. /// <returns>Item filters.</returns>
  69. public static IEnumerable<ItemFilter> GetFilters(string? filters)
  70. {
  71. return string.IsNullOrEmpty(filters)
  72. ? Array.Empty<ItemFilter>()
  73. : filters.Split(',').Select(v => Enum.Parse<ItemFilter>(v, true));
  74. }
  75. /// <summary>
  76. /// Splits a string at a separating character into an array of substrings.
  77. /// </summary>
  78. /// <param name="value">The string to split.</param>
  79. /// <param name="separator">The char that separates the substrings.</param>
  80. /// <param name="removeEmpty">Option to remove empty substrings from the array.</param>
  81. /// <returns>An array of the substrings.</returns>
  82. internal static string[] Split(string value, char separator, bool removeEmpty)
  83. {
  84. if (string.IsNullOrWhiteSpace(value))
  85. {
  86. return Array.Empty<string>();
  87. }
  88. return removeEmpty
  89. ? value.Split(new[] { separator }, StringSplitOptions.RemoveEmptyEntries)
  90. : value.Split(separator);
  91. }
  92. }
  93. }