mirror of
https://github.com/LBPUnion/ProjectLighthouse.git
synced 2025-06-23 23:41:27 +00:00
* Initial work for serialization refactor * Experiment with new naming conventions * Mostly implement user and slot serialization. Still needs to be fine tuned to match original implementation Many things are left in a broken state like website features/api endpoints/lbp3 categories * Fix release building * Migrate scores, reviews, and more to new serialization system. Many things are still broken but progress is steadily being made * Fix Api responses and migrate serialization for most types * Make serialization better and fix bugs Fix recursive PrepareSerialization when recursive item is set during root item's PrepareSerialization, items, should be properly indexed in order but it's only tested to 1 level of recursion * Fix review serialization * Fix user serialization producing malformed SQL query * Remove DefaultIfEmpty query * MariaDB doesn't like double nested queries * Fix LBP1 tag counter * Implement lbp3 categories and add better deserialization handling * Implement expression tree caching to speed up reflection and write new serializer tests * Remove Game column from UserEntity and rename DatabaseContextModelSnapshot.cs back to DatabaseModelSnapshot.cs * Make UserEntity username not required * Fix recursive serialization of lists and add relevant unit tests * Actually commit the migration * Fix LocationTests to use new deserialization class * Fix comments not serializing the right author username * Replace all occurrences of StatusCode with their respective ASP.NET named result instead of StatusCode(403) everything is now in the form of Forbid() * Fix SlotBase.ConvertToEntity and LocationTests * Fix compilation error * Give Location a default value in GameUserSlot and GameUser * Reimplement stubbed website functions * Convert grief reports to new serialization system * Update DatabaseModelSnapshot and bump dotnet tool version * Remove unused directives * Fix broken type reference * Fix rated comments on website * Don't include banned users in website comments * Optimize score submission * Fix slot id calculating in in-game comment posting * Move serialization interfaces to types folder and add more documentation * Allow uploading of versus scores
122 lines
No EOL
5 KiB
C#
122 lines
No EOL
5 KiB
C#
using System;
|
|
using System.Diagnostics.CodeAnalysis;
|
|
using System.IO;
|
|
using System.Net.Http;
|
|
using System.Threading.Tasks;
|
|
using System.Xml.Serialization;
|
|
using LBPUnion.ProjectLighthouse.Database;
|
|
using LBPUnion.ProjectLighthouse.Helpers;
|
|
using LBPUnion.ProjectLighthouse.Tickets;
|
|
using LBPUnion.ProjectLighthouse.Types.Entities.Profile;
|
|
using LBPUnion.ProjectLighthouse.Types.Users;
|
|
using Microsoft.AspNetCore.Hosting;
|
|
using Microsoft.AspNetCore.TestHost;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace LBPUnion.ProjectLighthouse.Tests;
|
|
|
|
[SuppressMessage("ReSharper", "UnusedMember.Global")]
|
|
public class LighthouseServerTest<TStartup> where TStartup : class
|
|
{
|
|
public readonly HttpClient Client;
|
|
public readonly TestServer Server;
|
|
|
|
public LighthouseServerTest()
|
|
{
|
|
this.Server = new TestServer(new WebHostBuilder().UseStartup<TStartup>());
|
|
this.Client = this.Server.CreateClient();
|
|
}
|
|
|
|
public async Task<string> CreateRandomUser(int number = -1, bool createUser = true)
|
|
{
|
|
if (number == -1) number = new Random().Next();
|
|
const string username = "unitTestUser";
|
|
|
|
if (createUser)
|
|
{
|
|
await using DatabaseContext database = new();
|
|
if (await database.Users.FirstOrDefaultAsync(u => u.Username == $"{username}{number}") == null)
|
|
{
|
|
UserEntity user = await database.CreateUser($"{username}{number}",
|
|
CryptoHelper.BCryptHash($"unitTestPassword{number}"));
|
|
user.LinkedPsnId = (ulong)number;
|
|
await database.SaveChangesAsync();
|
|
}
|
|
}
|
|
|
|
return $"{username}{number}";
|
|
}
|
|
|
|
public async Task<HttpResponseMessage> AuthenticateResponse(int number = -1, bool createUser = true)
|
|
{
|
|
string username = await this.CreateRandomUser(number, createUser);
|
|
|
|
byte[] ticketData = new TicketBuilder()
|
|
.SetUsername($"{username}{number}")
|
|
.SetUserId((ulong)number)
|
|
.Build();
|
|
|
|
HttpResponseMessage response = await this.Client.PostAsync
|
|
($"/LITTLEBIGPLANETPS3_XML/login?titleID={GameVersionHelper.LittleBigPlanet2TitleIds[0]}", new ByteArrayContent(ticketData));
|
|
return response;
|
|
}
|
|
|
|
public async Task<LoginResult> Authenticate(int number = -1)
|
|
{
|
|
HttpResponseMessage response = await this.AuthenticateResponse(number);
|
|
|
|
string responseContent = await response.Content.ReadAsStringAsync();
|
|
|
|
XmlSerializer serializer = new(typeof(LoginResult));
|
|
return (LoginResult)serializer.Deserialize(new StringReader(responseContent))!;
|
|
}
|
|
|
|
public Task<HttpResponseMessage> AuthenticatedRequest(string endpoint, string mmAuth) => this.AuthenticatedRequest(endpoint, mmAuth, HttpMethod.Get);
|
|
|
|
public Task<HttpResponseMessage> AuthenticatedRequest(string endpoint, string mmAuth, HttpMethod method)
|
|
{
|
|
using HttpRequestMessage requestMessage = new(method, endpoint);
|
|
requestMessage.Headers.Add("Cookie", mmAuth);
|
|
|
|
return this.Client.SendAsync(requestMessage);
|
|
}
|
|
|
|
public async Task<HttpResponseMessage> UploadFileEndpointRequest(string filePath)
|
|
{
|
|
byte[] bytes = await File.ReadAllBytesAsync(filePath);
|
|
string hash = CryptoHelper.Sha1Hash(bytes).ToLower();
|
|
|
|
return await this.Client.PostAsync($"/LITTLEBIGPLANETPS3_XML/upload/{hash}", new ByteArrayContent(bytes));
|
|
}
|
|
|
|
public async Task<HttpResponseMessage> AuthenticatedUploadFileEndpointRequest(string filePath, string mmAuth)
|
|
{
|
|
byte[] bytes = await File.ReadAllBytesAsync(filePath);
|
|
string hash = CryptoHelper.Sha1Hash(bytes).ToLower();
|
|
using HttpRequestMessage requestMessage = new(HttpMethod.Post, $"/LITTLEBIGPLANETPS3_XML/upload/{hash}");
|
|
requestMessage.Headers.Add("Cookie", mmAuth);
|
|
requestMessage.Content = new ByteArrayContent(bytes);
|
|
return await this.Client.SendAsync(requestMessage);
|
|
}
|
|
|
|
public async Task<HttpResponseMessage> UploadFileRequest(string endpoint, string filePath)
|
|
=> await this.Client.PostAsync(endpoint, new StringContent(await File.ReadAllTextAsync(filePath)));
|
|
|
|
public async Task<HttpResponseMessage> UploadDataRequest(string endpoint, byte[] data) => await this.Client.PostAsync(endpoint, new ByteArrayContent(data));
|
|
|
|
public async Task<HttpResponseMessage> AuthenticatedUploadFileRequest(string endpoint, string filePath, string mmAuth)
|
|
{
|
|
using HttpRequestMessage requestMessage = new(HttpMethod.Post, endpoint);
|
|
requestMessage.Headers.Add("Cookie", mmAuth);
|
|
requestMessage.Content = new StringContent(await File.ReadAllTextAsync(filePath));
|
|
return await this.Client.SendAsync(requestMessage);
|
|
}
|
|
|
|
public async Task<HttpResponseMessage> AuthenticatedUploadDataRequest(string endpoint, byte[] data, string mmAuth)
|
|
{
|
|
using HttpRequestMessage requestMessage = new(HttpMethod.Post, endpoint);
|
|
requestMessage.Headers.Add("Cookie", mmAuth);
|
|
requestMessage.Content = new ByteArrayContent(data);
|
|
return await this.Client.SendAsync(requestMessage);
|
|
}
|
|
} |