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.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

HttpUtils.cs 2.1KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. using Grpc.Core;
  2. using Grpc.Net.Client;
  3. using GrpcShared.DTO.Db;
  4. using GrpcShared.Interfaces;
  5. using Microsoft.Net.Http.Headers;
  6. using NemAnBlazor.Services.Interfaces;
  7. using Newtonsoft.Json;
  8. namespace SpotifyService.HttpUtils
  9. {
  10. public static class HttpUtils<T> where T : new()
  11. {
  12. public static async Task<T> GetData
  13. (IHttpClientFactory _httpClientFactory,
  14. string url,
  15. string userId,
  16. IIdentityService identityService,
  17. IAuthService authService)
  18. {
  19. try
  20. {
  21. var client = _httpClientFactory.CreateClient("HttpClient");
  22. var userResponse = await identityService.GetTokenByIdAsync(new DbRequestMessage { Id = userId });
  23. //add header
  24. client.DefaultRequestHeaders.Add(HeaderNames.Authorization, "Bearer " + userResponse.Token);
  25. //get request
  26. var req = await client.GetAsync(url);
  27. //read response
  28. var response = JsonConvert.DeserializeObject<T>(await req.Content.ReadAsStringAsync())!;
  29. if (req.StatusCode == System.Net.HttpStatusCode.Unauthorized)
  30. {
  31. await SpotifyHelper.TryRefreshToken(authService, userResponse, identityService);
  32. }
  33. return response;
  34. }
  35. catch (RpcException e)
  36. {
  37. if (e.StatusCode == StatusCode.Cancelled)
  38. {
  39. //vrati message sa status kodom?
  40. return new T();
  41. }
  42. throw;
  43. }
  44. }
  45. public static async Task PutData(HttpClient client, string url, string userId, IIdentityService identityService)
  46. {
  47. var tokenMessage = await identityService.GetTokenByIdAsync(new GrpcShared.DTO.Db.DbRequestMessage { Id = userId });
  48. //add header
  49. client.DefaultRequestHeaders.Add(HeaderNames.Authorization, "Bearer " + tokenMessage.Token);
  50. //get request
  51. await client.PutAsync(url, null);
  52. }
  53. }
  54. }