diff --git a/ProjectLighthouse.sln.DotSettings b/ProjectLighthouse.sln.DotSettings
index 3c18bfb3..1feed309 100644
--- a/ProjectLighthouse.sln.DotSettings
+++ b/ProjectLighthouse.sln.DotSettings
@@ -1,6 +1,8 @@
True
+ True
True
True
True
+ True
True
\ No newline at end of file
diff --git a/ProjectLighthouse/Controllers/ClientConfigurationController.cs b/ProjectLighthouse/Controllers/ClientConfigurationController.cs
new file mode 100644
index 00000000..6d684d3d
--- /dev/null
+++ b/ProjectLighthouse/Controllers/ClientConfigurationController.cs
@@ -0,0 +1,29 @@
+using Microsoft.AspNetCore.Mvc;
+using ProjectLighthouse.Serialization;
+
+namespace ProjectLighthouse.Controllers {
+ [ApiController]
+ [Route("LITTLEBIGPLANETPS3_XML/")]
+ [Produces("text/plain")]
+ public class ClientConfigurationController : ControllerBase {
+ [HttpGet("network_settings.nws")]
+ public IActionResult NetworkSettings() {
+ return this.Ok("ProbabilityOfPacketDelay 0.0\nMinPacketDelayFrames 0\nMaxPacketDelayFrames 3\nProbabilityOfPacketDrop 0.0\nEnableFakeConditionsForLoopback true\nNumberOfFramesPredictionAllowedForNonLocalPlayer 1000\nEnablePrediction true\nMinPredictedFrames 0\nMaxPredictedFrames 10\nAllowGameRendCameraSplit true\nFramesBeforeAgressiveCatchup 30\nPredictionPadSides 200\nPredictionPadTop 200\nPredictionPadBottom 200\nShowErrorNumbers true\nAllowModeratedLevels true\nAllowModeratedPoppetItems true\nShowLevelBoos true\nTIMEOUT_WAIT_FOR_JOIN_RESPONSE_FROM_PREV_PARTY_HOST 50.0\nTIMEOUT_WAIT_FOR_CHANGE_LEVEL_PARTY_HOST 30.0\nTIMEOUT_WAIT_FOR_CHANGE_LEVEL_PARTY_MEMBER 45.0\nTIMEOUT_WAIT_FOR_REQUEST_JOIN_FRIEND 15.0\nTIMEOUT_WAIT_FOR_CONNECTION_FROM_HOST 30.0\nTIMEOUT_WAIT_FOR_ROOM_ID_TO_JOIN 60.0\nTIMEOUT_WAIT_FOR_GET_NUM_PLAYERS_ONLINE 60.0\nTIMEOUT_WAIT_FOR_SIGNALLING_CONNECTIONS 120.0\nTIMEOUT_WAIT_FOR_PARTY_DATA 60.0\nTIME_TO_WAIT_FOR_LEAVE_MESSAGE_TO_COME_BACK 20.0\nTIME_TO_WAIT_FOR_FOLLOWING_REQUESTS_TO_ARRIVE 30.0\nTIMEOUT_WAIT_FOR_FINISHED_MIGRATING_HOST 30.0\nTIMEOUT_WAIT_FOR_PARTY_LEADER_FINISH_JOINING 45.0\nTIMEOUT_WAIT_FOR_QUICKPLAY_LEVEL 60.0\nTIMEOUT_WAIT_FOR_PLAYERS_TO_JOIN 30.0\nTIMEOUT_WAIT_FOR_DIVE_IN_PLAYERS 120.0\nTIMEOUT_WAIT_FOR_FIND_BEST_ROOM 30.0\nTIMEOUT_DIVE_IN_TOTAL 1000000.0\nTIMEOUT_WAIT_FOR_SOCKET_CONNECTION 120.0\nTIMEOUT_WAIT_FOR_REQUEST_RESOURCE_MESSAGE 120.0\nTIMEOUT_WAIT_FOR_LOCAL_CLIENT_TO_GET_RESOURCE_LIST 120.0\nTIMEOUT_WAIT_FOR_CLIENT_TO_LOAD_RESOURCES 120.0\nTIMEOUT_WAIT_FOR_LOCAL_CLIENT_TO_SAVE_GAME_STATE 30.0\nTIMEOUT_WAIT_FOR_ADD_PLAYERS_TO_TAKE 30.0\nTIMEOUT_WAIT_FOR_UPDATE_FROM_CLIENT 90.0\nTIMEOUT_WAIT_FOR_HOST_TO_GET_RESOURCE_LIST 60.0\nTIMEOUT_WAIT_FOR_HOST_TO_SAVE_GAME_STATE 60.0\nTIMEOUT_WAIT_FOR_HOST_TO_ADD_US 30.0\nTIMEOUT_WAIT_FOR_UPDATE 60.0\nTIMEOUT_WAIT_FOR_REQUEST_JOIN 50.0\nTIMEOUT_WAIT_FOR_AUTOJOIN_PRESENCE 60.0\nTIMEOUT_WAIT_FOR_AUTOJOIN_CONNECTION 120.0\nSECONDS_BETWEEN_PINS_AWARDED_UPLOADS 300.0\nEnableKeepAlive true\nAllowVoIPRecordingPlayback true\nCDNHostName localhost\nTelemetryServer localhost\nOverheatingThresholdDisallowMidgameJoin 0.95\nMaxCatchupFrames 3\nMaxLagBeforeShowLoading 23\nMinLagBeforeHideLoading 30\nLagImprovementInflectionPoint -1.0\nFlickerThreshold 2.0\nClosedDemo2014Version 1\nClosedDemo2014Expired false\nEnablePlayedFilter true\nEnableCommunityDecorations true\nGameStateUpdateRate 10.0\nGameStateUpdateRateWithConsumers 1.0\nDisableDLCPublishCheck false\nEnableDiveIn true\nEnableHackChecks false");
+ }
+
+ [HttpGet("t_conf")]
+ public IActionResult TConf() {
+ return this.Ok();
+ }
+
+ [HttpGet("farc_hashes")]
+ public IActionResult FarcHashes() {
+ return this.Ok();
+ }
+
+ [HttpGet("privacySettings")]
+ public IActionResult PrivacySettings() {
+ return this.Ok();
+ }
+ }
+}
\ No newline at end of file
diff --git a/ProjectLighthouse/Controllers/NetworkSettingsController.cs b/ProjectLighthouse/Controllers/NetworkSettingsController.cs
deleted file mode 100644
index 9329593a..00000000
--- a/ProjectLighthouse/Controllers/NetworkSettingsController.cs
+++ /dev/null
@@ -1,14 +0,0 @@
-using Microsoft.AspNetCore.Mvc;
-using ProjectLighthouse.Serialization;
-
-namespace ProjectLighthouse.Controllers {
- [ApiController]
- [Route("LITTLEBIGPLANETPS3_XML/network_settings.nws")]
- [Produces("text/xml")]
- public class NetworkSettingsController : ControllerBase {
- [HttpGet]
- public IActionResult Get() {
- return this.Ok(LbpSerializer.BlankElement("networkSettings"));
- }
- }
-}
\ No newline at end of file
diff --git a/ProjectLighthouse/Controllers/PublishController.cs b/ProjectLighthouse/Controllers/PublishController.cs
index 9e637321..39cdcae3 100644
--- a/ProjectLighthouse/Controllers/PublishController.cs
+++ b/ProjectLighthouse/Controllers/PublishController.cs
@@ -53,6 +53,20 @@ namespace ProjectLighthouse.Controllers {
return this.Ok(bodyString);
}
+ [HttpPost("unpublish/{id:int}")]
+ public async Task Unpublish(int id) {
+ await using Database database = new();
+
+ Slot slot = await database.Slots.FirstOrDefaultAsync(s => s.SlotId == id);
+
+ database.Locations.Remove(slot.Location);
+ database.Slots.Remove(slot);
+
+ await database.SaveChangesAsync();
+
+ return this.Ok();
+ }
+
public async Task GetSlotFromBody() {
Request.Body.Position = 0;
string bodyString = await new StreamReader(Request.Body).ReadToEndAsync();
diff --git a/ProjectLighthouse/Controllers/SlotsController.cs b/ProjectLighthouse/Controllers/SlotsController.cs
index f2915de3..0378eb3e 100644
--- a/ProjectLighthouse/Controllers/SlotsController.cs
+++ b/ProjectLighthouse/Controllers/SlotsController.cs
@@ -24,5 +24,10 @@ namespace ProjectLighthouse.Controllers {
return this.Ok(slot.Serialize());
}
+
+ [HttpPost("showModerated")]
+ public IActionResult ShowModerated() {
+ return this.Ok();
+ }
}
}
\ No newline at end of file
diff --git a/ProjectLighthouse/Controllers/UserController.cs b/ProjectLighthouse/Controllers/UserController.cs
index 8027a6f3..a60d1a7f 100644
--- a/ProjectLighthouse/Controllers/UserController.cs
+++ b/ProjectLighthouse/Controllers/UserController.cs
@@ -107,5 +107,10 @@ namespace ProjectLighthouse.Controllers {
if(database.ChangeTracker.HasChanges()) await database.SaveChangesAsync(); // save the user to the database if we changed anything
return this.Ok();
}
+
+ [HttpPost("match")]
+ public IActionResult Match() {
+ return this.Ok();
+ }
}
}
\ No newline at end of file
diff --git a/ProjectLighthouse/ProjectLighthouse.csproj b/ProjectLighthouse/ProjectLighthouse.csproj
index b8632c07..02a52bf2 100644
--- a/ProjectLighthouse/ProjectLighthouse.csproj
+++ b/ProjectLighthouse/ProjectLighthouse.csproj
@@ -1,8 +1,8 @@
- net5.0
Linux
+ net5.0;net6.0
diff --git a/ProjectLighthouse/Types/ServerSettings.cs b/ProjectLighthouse/Types/ServerSettings.cs
index 2699ab0c..f1b9cbb4 100644
--- a/ProjectLighthouse/Types/ServerSettings.cs
+++ b/ProjectLighthouse/Types/ServerSettings.cs
@@ -6,7 +6,7 @@ namespace ProjectLighthouse.Types {
///
/// The maximum amount of slots allowed on users' earth
///
- public const int EntitledSlots = 20;
+ public const int EntitledSlots = int.MaxValue;
public const int ListsQuota = 20;
diff --git a/global.json b/global.json
new file mode 100644
index 00000000..f443bd42
--- /dev/null
+++ b/global.json
@@ -0,0 +1,7 @@
+{
+ "sdk": {
+ "version": "6.0",
+ "rollForward": "latestMajor",
+ "allowPrerelease": true
+ }
+}
\ No newline at end of file