| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 | 
							- using System;
 
- using System.Net;
 
- using System.Net.Http;
 
- using System.Net.Http.Headers;
 
- using System.Net.Http.Json;
 
- using System.Text.Json;
 
- using System.Threading.Tasks;
 
- using Jellyfin.Api.Models.StartupDtos;
 
- using Jellyfin.Api.Models.UserDtos;
 
- using Jellyfin.Extensions;
 
- using Jellyfin.Extensions.Json;
 
- using MediaBrowser.Model.Dto;
 
- using Xunit;
 
- namespace Jellyfin.Server.Integration.Tests
 
- {
 
-     public static class AuthHelper
 
-     {
 
-         public const string AuthHeaderName = "Authorization";
 
-         public const string DummyAuthHeader = "MediaBrowser Client=\"Jellyfin.Server%20Integration%20Tests\", DeviceId=\"69420\", Device=\"Apple%20II\", Version=\"10.8.0\"";
 
-         public static async Task<string> CompleteStartupAsync(HttpClient client)
 
-         {
 
-             var jsonOptions = JsonDefaults.Options;
 
-             var userResponse = await client.GetByteArrayAsync("/Startup/User");
 
-             var user = JsonSerializer.Deserialize<StartupUserDto>(userResponse, jsonOptions);
 
-             using var completeResponse = await client.PostAsync("/Startup/Complete", new ByteArrayContent(Array.Empty<byte>()));
 
-             Assert.Equal(HttpStatusCode.NoContent, completeResponse.StatusCode);
 
-             using var httpRequest = new HttpRequestMessage(HttpMethod.Post, "/Users/AuthenticateByName");
 
-             httpRequest.Headers.TryAddWithoutValidation(AuthHeaderName, DummyAuthHeader);
 
-             httpRequest.Content = JsonContent.Create(
 
-                 new AuthenticateUserByName()
 
-                 {
 
-                     Username = user!.Name,
 
-                     Pw = user.Password,
 
-                 },
 
-                 options: jsonOptions);
 
-             using var authResponse = await client.SendAsync(httpRequest);
 
-             authResponse.EnsureSuccessStatusCode();
 
-             var auth = await authResponse.Content.ReadFromJsonAsync<AuthenticationResultDto>(jsonOptions);
 
-             return auth!.AccessToken;
 
-         }
 
-         public static async Task<UserDto> GetUserDtoAsync(HttpClient client)
 
-         {
 
-             using var response = await client.GetAsync("Users/Me");
 
-             Assert.Equal(HttpStatusCode.OK, response.StatusCode);
 
-             var userDto = await response.Content.ReadFromJsonAsync<UserDto>(JsonDefaults.Options);
 
-             Assert.NotNull(userDto);
 
-             return userDto;
 
-         }
 
-         public static async Task<BaseItemDto> GetRootFolderDtoAsync(HttpClient client, Guid userId = default)
 
-         {
 
-             if (userId.IsEmpty())
 
-             {
 
-                 var userDto = await GetUserDtoAsync(client);
 
-                 userId = userDto.Id;
 
-             }
 
-             var response = await client.GetAsync($"Users/{userId}/Items/Root");
 
-             Assert.Equal(HttpStatusCode.OK, response.StatusCode);
 
-             var rootDto = await response.Content.ReadFromJsonAsync<BaseItemDto>(JsonDefaults.Options);
 
-             Assert.NotNull(rootDto);
 
-             return rootDto;
 
-         }
 
-         public static void AddAuthHeader(this HttpHeaders headers, string accessToken)
 
-         {
 
-             headers.Add(AuthHeaderName, DummyAuthHeader + $", Token={accessToken}");
 
-         }
 
-         private sealed class AuthenticationResultDto
 
-         {
 
-             public string AccessToken { get; set; } = string.Empty;
 
-             public string ServerId { get; set; } = string.Empty;
 
-         }
 
-     }
 
- }
 
 
  |