AuthHelper.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. using System;
  2. using System.Net;
  3. using System.Net.Http;
  4. using System.Net.Http.Headers;
  5. using System.Net.Http.Json;
  6. using System.Text.Json;
  7. using System.Threading.Tasks;
  8. using Jellyfin.Api.Models.StartupDtos;
  9. using Jellyfin.Api.Models.UserDtos;
  10. using Jellyfin.Extensions.Json;
  11. using MediaBrowser.Model.Dto;
  12. using Xunit;
  13. namespace Jellyfin.Server.Integration.Tests
  14. {
  15. public static class AuthHelper
  16. {
  17. public const string AuthHeaderName = "Authorization";
  18. public const string DummyAuthHeader = "MediaBrowser Client=\"Jellyfin.Server%20Integration%20Tests\", DeviceId=\"69420\", Device=\"Apple%20II\", Version=\"10.8.0\"";
  19. public static async Task<string> CompleteStartupAsync(HttpClient client)
  20. {
  21. var jsonOptions = JsonDefaults.Options;
  22. var userResponse = await client.GetByteArrayAsync("/Startup/User");
  23. var user = JsonSerializer.Deserialize<StartupUserDto>(userResponse, jsonOptions);
  24. using var completeResponse = await client.PostAsync("/Startup/Complete", new ByteArrayContent(Array.Empty<byte>()));
  25. Assert.Equal(HttpStatusCode.NoContent, completeResponse.StatusCode);
  26. using var httpRequest = new HttpRequestMessage(HttpMethod.Post, "/Users/AuthenticateByName");
  27. httpRequest.Headers.TryAddWithoutValidation(AuthHeaderName, DummyAuthHeader);
  28. httpRequest.Content = JsonContent.Create(
  29. new AuthenticateUserByName()
  30. {
  31. Username = user!.Name,
  32. Pw = user.Password,
  33. },
  34. options: jsonOptions);
  35. using var authResponse = await client.SendAsync(httpRequest);
  36. authResponse.EnsureSuccessStatusCode();
  37. var auth = await authResponse.Content.ReadFromJsonAsync<AuthenticationResultDto>(jsonOptions);
  38. return auth!.AccessToken;
  39. }
  40. public static async Task<UserDto> GetUserDtoAsync(HttpClient client)
  41. {
  42. using var response = await client.GetAsync("Users/Me");
  43. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  44. var userDto = await response.Content.ReadFromJsonAsync<UserDto>(JsonDefaults.Options);
  45. Assert.NotNull(userDto);
  46. return userDto;
  47. }
  48. public static async Task<BaseItemDto> GetRootFolderDtoAsync(HttpClient client, Guid userId = default)
  49. {
  50. if (userId.Equals(default))
  51. {
  52. var userDto = await GetUserDtoAsync(client);
  53. userId = userDto.Id;
  54. }
  55. var response = await client.GetAsync($"Users/{userId}/Items/Root");
  56. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  57. var rootDto = await response.Content.ReadFromJsonAsync<BaseItemDto>(JsonDefaults.Options);
  58. Assert.NotNull(rootDto);
  59. return rootDto;
  60. }
  61. public static void AddAuthHeader(this HttpHeaders headers, string accessToken)
  62. {
  63. headers.Add(AuthHeaderName, DummyAuthHeader + $", Token={accessToken}");
  64. }
  65. private sealed class AuthenticationResultDto
  66. {
  67. public string AccessToken { get; set; } = string.Empty;
  68. public string ServerId { get; set; } = string.Empty;
  69. }
  70. }
  71. }