AuthHelper.cs 3.3 KB

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