Blazor & WASM in combination to get statistics from Spotify API for performing the song analysis. With separate microservices for auth, Spotify, user data tracking, and application, connected through gRPC with Polly.
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

TrackService.cs 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. using Google.Rpc;
  2. using Grpc.Core;
  3. using GrpcShared;
  4. using GrpcShared.DTO.Search;
  5. using GrpcShared.DTO.Track.MultipleTrack;
  6. using GrpcShared.DTO.Track.SaveTracks;
  7. using GrpcShared.DTO.Track.SingleTrack;
  8. using GrpcShared.DTO.TrackByID;
  9. using GrpcShared.Interfaces;
  10. using Microsoft.AspNetCore.Authorization;
  11. using Microsoft.Net.Http.Headers;
  12. using NemAnBlazor.Services;
  13. using Newtonsoft.Json;
  14. using System.Text;
  15. using System.Text.Json;
  16. using System.Web;
  17. using static GrpcShared.DTO.Search.SearchDetails;
  18. namespace SpotifyService.Services
  19. {
  20. public class TrackService : ITrackService
  21. {
  22. private readonly IHttpClientFactory _httpClientFactory;
  23. public TrackService(IHttpClientFactory httpClientFactory)
  24. {
  25. _httpClientFactory = httpClientFactory;
  26. }
  27. public async Task<SearchResponse> ListSearchAsync(SearchRequest request)
  28. {
  29. var client = _httpClientFactory.CreateClient("HttpClient");
  30. string url = $"search?q={request.Query}&type={request.Type}";
  31. return await HttpUtils.HttpUtils<SearchResponse>.GetData(client, url, request.Token!);
  32. }
  33. public async Task<SingleTrackResponse> ListSingleTrackAsync(SingleTrackRequest request)
  34. {
  35. var client = _httpClientFactory.CreateClient("HttpClient");
  36. string url = $"audio-features/{request.Id}";
  37. return await HttpUtils.HttpUtils<SingleTrackResponse>.GetData(client, url, request.Token!);
  38. }
  39. public async Task<MultipleTrackResponse> ListMultipleTrackAsync(MultipleTrackRequest request)
  40. {
  41. var client = _httpClientFactory.CreateClient("HttpClient");
  42. var param = new Dictionary<string, List<string>>();
  43. param["ids"] = request.Ids!;
  44. var query = UriUtil(param);
  45. string url = $"audio-features{query}";
  46. return await HttpUtils.HttpUtils<MultipleTrackResponse>.GetData(client,url,request.Token!);
  47. }
  48. public async Task SaveTracks(SaveTracksRequest request)
  49. {
  50. var client = _httpClientFactory.CreateClient("HttpClient");
  51. var param = new Dictionary<string, List<string>>();
  52. param["ids"] = request.Ids!;
  53. var query = UriUtil(param);
  54. string url = $"me/tracks/{query}";
  55. //the response type has nothing to do with the method, it's there so that the method can be called
  56. await HttpUtils.HttpUtils<MultipleTrackResponse>.PutData(client, url, request.Token!);
  57. }
  58. public static string UriUtil(Dictionary<string, List<string>> param)
  59. {
  60. bool startingQuestionMarkAdded = false;
  61. var sb = new StringBuilder();
  62. foreach (var id in param)
  63. {
  64. sb.Append(startingQuestionMarkAdded ? '&' : '?');
  65. sb.Append(id.Key);
  66. sb.Append('=');
  67. foreach (var Xid in id.Value)
  68. {
  69. sb.Append(Xid);
  70. sb.Append("%2C");
  71. startingQuestionMarkAdded = true;
  72. }
  73. }
  74. sb.Length = sb.Length - 3;
  75. return sb.ToString();
  76. }
  77. public async Task<TrackResponse> GetById(TrackRequest request)
  78. {
  79. var client = _httpClientFactory.CreateClient("HttpClient");
  80. string url = $"tracks/{request.TrackID}";
  81. return await HttpUtils.HttpUtils<TrackResponse>.GetData(client, url, request.Token!);
  82. }
  83. }
  84. }