diff --git a/HorseIsleServer/HISP.sln b/HorseIsleServer/HISP.sln index 31b1ae8..16ec17c 100644 --- a/HorseIsleServer/HISP.sln +++ b/HorseIsleServer/HISP.sln @@ -7,7 +7,12 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "LibHISP", "LibHISP\LibHISP. EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "HISPd", "HISPd\HISPd.csproj", "{DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}" EndProject -Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "N00BS", "N00BS\N00BS.csproj", "{6B45A1E8-0F54-4BF7-AF48-41B9FE676570}" +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "MPN00BS", "MPN00BS\MPN00BS.csproj", "{72EF95FC-03DB-4E61-A696-E0095DD42A4E}" + ProjectSection(ProjectDependencies) = postProject + {C48CBD82-AB30-494A-8FFA-4DE7069B5827} = {C48CBD82-AB30-494A-8FFA-4DE7069B5827} + EndProjectSection +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "N00BS", "N00BS\N00BS.csproj", "{C368A652-31D2-42AE-A3F3-D63A51378BC7}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -36,6 +41,11 @@ Global MacOS|ARM64 = MacOS|ARM64 MacOS|x64 = MacOS|x64 MacOS|x86 = MacOS|x86 + Release|Any CPU = Release|Any CPU + Release|ARM = Release|ARM + Release|ARM64 = Release|ARM64 + Release|x64 = Release|x64 + Release|x86 = Release|x86 Windows|Any CPU = Windows|Any CPU Windows|ARM = Windows|ARM Windows|ARM64 = Windows|ARM64 @@ -92,6 +102,16 @@ Global {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.MacOS|x64.Build.0 = MacOS|x64 {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.MacOS|x86.ActiveCfg = MacOS|x86 {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.MacOS|x86.Build.0 = MacOS|x86 + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|Any CPU.ActiveCfg = Windows|Any CPU + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|Any CPU.Build.0 = Windows|Any CPU + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|ARM.ActiveCfg = Windows|ARM + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|ARM.Build.0 = Windows|ARM + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|ARM64.ActiveCfg = Windows|ARM64 + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|ARM64.Build.0 = Windows|ARM64 + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|x64.ActiveCfg = Windows|x64 + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|x64.Build.0 = Windows|x64 + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|x86.ActiveCfg = Windows|x86 + {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Release|x86.Build.0 = Windows|x86 {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Windows|Any CPU.ActiveCfg = Windows|x64 {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Windows|Any CPU.Build.0 = Windows|x64 {C48CBD82-AB30-494A-8FFA-4DE7069B5827}.Windows|ARM.ActiveCfg = Windows|ARM @@ -151,6 +171,16 @@ Global {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.MacOS|x64.Build.0 = MacOS|x64 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.MacOS|x86.ActiveCfg = MacOS|x86 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.MacOS|x86.Build.0 = MacOS|x86 + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|Any CPU.ActiveCfg = Windows|Any CPU + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|Any CPU.Build.0 = Windows|Any CPU + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|ARM.ActiveCfg = MacOS|ARM + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|ARM.Build.0 = MacOS|ARM + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|ARM64.ActiveCfg = Windows|ARM64 + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|ARM64.Build.0 = Windows|ARM64 + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|x64.ActiveCfg = Windows|x64 + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|x64.Build.0 = Windows|x64 + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|x86.ActiveCfg = Windows|x86 + {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Release|x86.Build.0 = Windows|x86 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Windows|Any CPU.ActiveCfg = Windows|x64 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Windows|Any CPU.Build.0 = Windows|x64 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Windows|ARM.ActiveCfg = Windows|Any CPU @@ -161,44 +191,146 @@ Global {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Windows|x64.Build.0 = Windows|x64 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Windows|x86.ActiveCfg = Windows|x86 {DEAD5CB0-C6B6-4B63-B1FB-A9F649CA1D27}.Windows|x86.Build.0 = Windows|x86 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Android|Any CPU.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Android|Any CPU.Build.0 = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Android|ARM.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Android|ARM64.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Android|x64.ActiveCfg = Windows|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Android|x86.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|Any CPU.Build.0 = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|ARM.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|ARM64.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|x64.ActiveCfg = Debug|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|x64.Build.0 = Debug|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|x86.ActiveCfg = Debug|x86 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Debug|x86.Build.0 = Debug|x86 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.iOS|Any CPU.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.iOS|ARM.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.iOS|ARM64.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.iOS|x64.ActiveCfg = Debug|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.iOS|x86.ActiveCfg = Windows|x86 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Linux|Any CPU.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Linux|Any CPU.Build.0 = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Linux|ARM.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Linux|ARM64.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Linux|x64.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Linux|x86.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.MacOS|Any CPU.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.MacOS|ARM.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.MacOS|ARM64.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.MacOS|x64.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.MacOS|x86.ActiveCfg = Debug|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|Any CPU.ActiveCfg = Windows|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|Any CPU.Build.0 = Windows|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|ARM.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|ARM64.ActiveCfg = Windows|Any CPU - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|x64.ActiveCfg = Windows|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|x64.Build.0 = Windows|x64 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|x86.ActiveCfg = Windows|x86 - {6B45A1E8-0F54-4BF7-AF48-41B9FE676570}.Windows|x86.Build.0 = Windows|x86 + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|Any CPU.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|Any CPU.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|ARM.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|ARM.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|ARM64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|ARM64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|x64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|x64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|x86.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Android|x86.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|ARM.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|ARM.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|ARM64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|ARM64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|x64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|x64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|x86.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Debug|x86.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|Any CPU.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|Any CPU.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|ARM.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|ARM.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|ARM64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|ARM64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|x64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|x64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|x86.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.iOS|x86.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|Any CPU.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|Any CPU.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|ARM.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|ARM.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|ARM64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|ARM64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|x64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|x64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|x86.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Linux|x86.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|Any CPU.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|Any CPU.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|ARM.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|ARM.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|ARM64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|ARM64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|x64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|x64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|x86.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.MacOS|x86.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|Any CPU.ActiveCfg = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|Any CPU.Build.0 = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|ARM.ActiveCfg = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|ARM.Build.0 = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|ARM64.ActiveCfg = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|ARM64.Build.0 = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|x64.ActiveCfg = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|x64.Build.0 = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|x86.ActiveCfg = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Release|x86.Build.0 = Release|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|Any CPU.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|Any CPU.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|ARM.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|ARM.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|ARM64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|ARM64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|x64.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|x64.Build.0 = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|x86.ActiveCfg = Debug|Any CPU + {72EF95FC-03DB-4E61-A696-E0095DD42A4E}.Windows|x86.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|Any CPU.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|Any CPU.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|ARM.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|ARM.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|ARM64.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|ARM64.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|x64.ActiveCfg = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|x64.Build.0 = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|x86.ActiveCfg = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Android|x86.Build.0 = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|ARM.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|ARM.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|ARM64.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|ARM64.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|x64.ActiveCfg = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|x64.Build.0 = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|x86.ActiveCfg = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Debug|x86.Build.0 = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|Any CPU.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|Any CPU.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|ARM.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|ARM.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|ARM64.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|ARM64.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|x64.ActiveCfg = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|x64.Build.0 = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|x86.ActiveCfg = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.iOS|x86.Build.0 = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|Any CPU.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|Any CPU.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|ARM.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|ARM.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|ARM64.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|ARM64.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|x64.ActiveCfg = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|x64.Build.0 = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|x86.ActiveCfg = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Linux|x86.Build.0 = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|Any CPU.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|Any CPU.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|ARM.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|ARM.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|ARM64.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|ARM64.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|x64.ActiveCfg = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|x64.Build.0 = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|x86.ActiveCfg = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.MacOS|x86.Build.0 = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|Any CPU.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|Any CPU.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|ARM.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|ARM.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|ARM64.ActiveCfg = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|ARM64.Build.0 = Debug|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|x64.ActiveCfg = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|x64.Build.0 = Debug|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|x86.ActiveCfg = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Release|x86.Build.0 = Debug|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|Any CPU.ActiveCfg = Windows|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|Any CPU.Build.0 = Windows|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|ARM.ActiveCfg = Windows|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|ARM.Build.0 = Windows|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|ARM64.ActiveCfg = Windows|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|ARM64.Build.0 = Windows|Any CPU + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|x64.ActiveCfg = Windows|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|x64.Build.0 = Windows|x64 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|x86.ActiveCfg = Windows|x86 + {C368A652-31D2-42AE-A3F3-D63A51378BC7}.Windows|x86.Build.0 = Windows|x86 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/HorseIsleServer/HISPd/Resources/DEBIAN/control b/HorseIsleServer/HISPd/Resources/DEBIAN/control index 66f2038..3adcedb 100644 --- a/HorseIsleServer/HISPd/Resources/DEBIAN/control +++ b/HorseIsleServer/HISPd/Resources/DEBIAN/control @@ -1,5 +1,5 @@ Package: hisp -Version: 1.7.99 +Version: 1.7.100 Depends: coreutils,systemd,mariadb-server,libsqlite3-dev,zlib1g-dev,libicu-dev,libkrb5-dev Maintainer: Li Homepage: https://islehorse.com diff --git a/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs b/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs index 5c23c81..0e249a2 100644 --- a/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs +++ b/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs @@ -30,5 +30,5 @@ using System.Runtime.InteropServices; // // You can specify all the values or you can default the Build and Revision Numbers // by using the '*' as shown below: -[assembly: AssemblyVersion("1.7.99.0")] -[assembly: AssemblyFileVersion("1.7.99.0")] +[assembly: AssemblyVersion("1.7.100.0")] +[assembly: AssemblyFileVersion("1.7.100.0")] diff --git a/HorseIsleServer/LibHISP/Server/Entry.cs b/HorseIsleServer/LibHISP/Server/Entry.cs index 9d27d1c..89071ac 100644 --- a/HorseIsleServer/LibHISP/Server/Entry.cs +++ b/HorseIsleServer/LibHISP/Server/Entry.cs @@ -8,8 +8,6 @@ using HISP.Security; using System; using System.Diagnostics; -using System.Threading; -using System.IO; namespace HISP.Server { diff --git a/HorseIsleServer/LibHISP/Server/GameClient.cs b/HorseIsleServer/LibHISP/Server/GameClient.cs index f5c15d5..2e6c273 100644 --- a/HorseIsleServer/LibHISP/Server/GameClient.cs +++ b/HorseIsleServer/LibHISP/Server/GameClient.cs @@ -1,618 +1,618 @@ -using System; -using System.Net.Sockets; -using System.Threading; -using System.Collections.Generic; -using HISP.Player; -using HISP.Game; -using HISP.Game.Horse; -using HISP.Game.Events; -using HISP.Game.Items; - -namespace HISP.Server -{ - public class GameClient - { - private static List connectedClients = new List(); - public static GameClient[] ConnectedClients // Done to prevent Enumerator Changed errors. - { - get - { - return connectedClients.ToArray(); - } - } - - public Socket ClientSocket; - public string RemoteIp; - private bool loggedIn = false; - public bool LoggedIn - { - get - { - bool login = loggedIn; - if (LoggedinUser == null) - return false; - if (LoggedinUser.LoggedinClient == null) - return false; - return login; - } - set - { - loggedIn = value; - } - } - public User LoggedinUser; - - private Timer keepAliveTimer; - private Timer timeoutTimer; - - private Timer warnTimer; - private Timer kickTimer; - private Timer minuteTimer; - - private bool isDisconnecting = false; - - private int timeoutInterval = 95 * 1000; - - private int totalMinutesElapsed = 0; - private int oneMinute = 60 * 1000; - private int warnInterval = GameServer.IdleWarning * 60 * 1000; // Time before showing a idle warning - private int kickInterval = GameServer.IdleTimeout * 60 * 1000; // Time before kicking for inactivity - - private List currentPacket = new List(); - private byte[] workBuffer = new byte[0x8000]; - - public GameClient(Socket clientSocket) - { - clientSocket.SendTimeout = 10 * 1000; // 10sec - clientSocket.ReceiveTimeout = 10 * 1000; // 10sec - - ClientSocket = clientSocket; - RemoteIp = clientSocket.RemoteEndPoint.ToString(); - - if (RemoteIp.Contains(":")) - RemoteIp = RemoteIp.Substring(0, RemoteIp.IndexOf(":")); - - Logger.DebugPrint("Client connected @ " + RemoteIp); - - kickTimer = new Timer(new TimerCallback(kickTimerTick), null, kickInterval, kickInterval); - warnTimer = new Timer(new TimerCallback(warnTimerTick), null, warnInterval, warnInterval); - minuteTimer = new Timer(new TimerCallback(minuteTimerTick), null, oneMinute, oneMinute); - - connectedClients.Add(this); - - SocketAsyncEventArgs evt = new SocketAsyncEventArgs(); - evt.Completed += receivePackets; - evt.SetBuffer(workBuffer, 0, workBuffer.Length); - if (!clientSocket.ReceiveAsync(evt)) - receivePackets(null, evt); - } - - public static void OnShutdown() - { - try - { - foreach (GameClient client in ConnectedClients) - { - - if (client.LoggedIn) - { - for (int i = 0; i < 2; i++) - { - ItemInstance rubyItem = new ItemInstance(Item.Ruby); - client.LoggedinUser.Inventory.AddIgnoringFull(rubyItem); - } - +using System; +using System.Net.Sockets; +using System.Threading; +using System.Collections.Generic; +using HISP.Player; +using HISP.Game; +using HISP.Game.Horse; +using HISP.Game.Events; +using HISP.Game.Items; + +namespace HISP.Server +{ + public class GameClient + { + private static List connectedClients = new List(); + public static GameClient[] ConnectedClients // Done to prevent Enumerator Changed errors. + { + get + { + return connectedClients.ToArray(); + } + } + + public Socket ClientSocket; + public string RemoteIp; + private bool loggedIn = false; + public bool LoggedIn + { + get + { + bool login = loggedIn; + if (LoggedinUser == null) + return false; + if (LoggedinUser.LoggedinClient == null) + return false; + return login; + } + set + { + loggedIn = value; + } + } + public User LoggedinUser; + + private Timer keepAliveTimer; + private Timer timeoutTimer; + + private Timer warnTimer; + private Timer kickTimer; + private Timer minuteTimer; + + private bool isDisconnecting = false; + + private int timeoutInterval = 95 * 1000; + + private int totalMinutesElapsed = 0; + private int oneMinute = 60 * 1000; + private int warnInterval = GameServer.IdleWarning * 60 * 1000; // Time before showing a idle warning + private int kickInterval = GameServer.IdleTimeout * 60 * 1000; // Time before kicking for inactivity + + private List currentPacket = new List(); + private byte[] workBuffer = new byte[0x8000]; + + public GameClient(Socket clientSocket) + { + clientSocket.SendTimeout = 10 * 1000; // 10sec + clientSocket.ReceiveTimeout = 10 * 1000; // 10sec + + ClientSocket = clientSocket; + RemoteIp = clientSocket.RemoteEndPoint.ToString(); + + if (RemoteIp.Contains(":")) + RemoteIp = RemoteIp.Substring(0, RemoteIp.IndexOf(":")); + + Logger.DebugPrint("Client connected @ " + RemoteIp); + + kickTimer = new Timer(new TimerCallback(kickTimerTick), null, kickInterval, kickInterval); + warnTimer = new Timer(new TimerCallback(warnTimerTick), null, warnInterval, warnInterval); + minuteTimer = new Timer(new TimerCallback(minuteTimerTick), null, oneMinute, oneMinute); + + connectedClients.Add(this); + + SocketAsyncEventArgs evt = new SocketAsyncEventArgs(); + evt.Completed += receivePackets; + evt.SetBuffer(workBuffer, 0, workBuffer.Length); + if (!clientSocket.ReceiveAsync(evt)) + receivePackets(null, evt); + } + + public static void OnShutdown() + { + try + { + foreach (GameClient client in ConnectedClients) + { + + if (client.LoggedIn) + { + for (int i = 0; i < 2; i++) + { + ItemInstance rubyItem = new ItemInstance(Item.Ruby); + client.LoggedinUser.Inventory.AddIgnoringFull(rubyItem); + } + client.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.GameUpdates).Count++; - Logger.DebugPrint("Kicking: " + client.LoggedinUser.Username); - } - client.Kick("Server shutdown."); - - } - } - catch (Exception) { }; - } - public static void CreateClient(object sender, SocketAsyncEventArgs e) - { - do - { - Socket eSocket = e.AcceptSocket; - if(eSocket != null) - new GameClient(eSocket); - e.AcceptSocket = null; - } while (!GameServer.ServerSocket.AcceptAsync(e)); - } - private void timeoutTimerTick(object state) - { - if (this.LoggedIn) - { - Disconnect(); - } - } - - public void Disconnect() - { - if (this.isDisconnecting) - return; - this.isDisconnecting = true; - - // Close Socket - if (ClientSocket != null) - { - ClientSocket.Disconnect(false); - ClientSocket.Dispose(); - ClientSocket = null; - } - - - // Stop Timers - if (timeoutTimer != null) - { - timeoutTimer.Dispose(); - timeoutTimer = null; - } - if (keepAliveTimer != null) - { - keepAliveTimer.Dispose(); - keepAliveTimer = null; - } - if (warnTimer != null) - { - warnTimer.Dispose(); - warnTimer = null; - } - if (kickTimer != null) - { - kickTimer.Dispose(); - kickTimer = null; - } - - // Call OnDisconnect - - connectedClients.Remove(this); - GameServer.OnDisconnect(this); - LoggedIn = false; - - } - - - private void receivePackets(object sender, SocketAsyncEventArgs e) - { - do - { - // HI1 Packets are terminates by 0x00 so we have to read until we receive that terminator - - if (isDisconnecting || - ClientSocket == null || - e.BytesTransferred <= 0 || - !ClientSocket.Connected || - e.SocketError != SocketError.Success) - { - Disconnect(); - return; - } - - int availble = e.BytesTransferred; - if (availble >= 1) // More than 1 byte transfered.. - { - - for (int i = 0; i < availble; i++) - { - currentPacket.Add(e.Buffer[i]); - if (e.Buffer[i] == PacketBuilder.PACKET_TERMINATOR) // Read until \0... - { - parsePackets(currentPacket.ToArray()); - currentPacket.Clear(); - } - } - } - - if (availble == 0) - Disconnect(); - - if (isDisconnecting || ClientSocket == null) - return; - - - } while (!ClientSocket.ReceiveAsync(e)); - - } - - private void keepAliveTick(object state) - { - Logger.DebugPrint("Sending keep-alive packet to " + LoggedinUser.Username); - byte[] updatePacket = PacketBuilder.CreateKeepAlive(); - SendPacket(updatePacket); - if(!isDisconnecting && keepAliveTimer != null) // wtf how is this still a problem? - keepAliveTimer.Change(oneMinute, oneMinute); - } - private void minuteTimerTick(object state) - { - totalMinutesElapsed++; - if (LoggedIn) - { - - GameServer.UpdatePlayer(this); - - LoggedinUser.CanUseAdsChat = true; - LoggedinUser.FreeMinutes -= 1; - - GameServer.DoItemPurchases(this); - - if (totalMinutesElapsed % 2 == 0) - { - LoggedinUser.TotalGlobalChatMessages++; - } - - if (LoggedinUser.FreeMinutes <= 0) - { - LoggedinUser.FreeMinutes = 0; - if (!LoggedinUser.Subscribed && !LoggedinUser.Moderator && !LoggedinUser.Administrator) - { - Kick(Messages.KickReasonNoTime); - return; - } - - } - - // Those fun messages when u have been playing for awhile. - if (totalMinutesElapsed % (2 * 60) == 0) - { - string ptMessage = Messages.RngMessages[GameServer.RandomNumberGenerator.Next(0, Messages.RngMessages.Length)]; - byte[] playTimeMessage = PacketBuilder.CreateChat(Messages.FormatPlaytimeMessage(totalMinutesElapsed / 60) + ptMessage, PacketBuilder.CHAT_BOTTOM_RIGHT); - SendPacket(playTimeMessage); - } - - - if (GameServer.RandomNumberGenerator.Next(0, 100) == 59) // RANDOM EVENT HAS OCCURED! - { - RandomEvent.ExecuteRandomEvent(LoggedinUser); - } - - bool gotoPrision = false; - foreach(HorseInstance horse in LoggedinUser.HorseInventory.HorseList) - { - if (totalMinutesElapsed % 2 == 0) - { - horse.BasicStats.Thirst--; - horse.BasicStats.Hunger--; - - if (horse.BasicStats.Thirst <= 0 && horse.BasicStats.Hunger <= 0) - { - horse.BasicStats.Health -= 5; - if(horse.BasicStats.Hunger <= 0) - { - gotoPrision = true; // Goto jail, go directly to jail, do not pass go, do not collect 200$ - - horse.BasicStats.Health = 10; - horse.BasicStats.Hunger = 500; - horse.BasicStats.Thirst = 500; - } - } - } - - - if(horse.Leaser > 0) - { - horse.LeaseTime--; - - if (horse.LeaseTime <= 0) - { - int tpX = 0; - int tpY = 0; - if(horse.Breed.Type == "unicorn" || horse.Breed.Type == "pegasus") - { - foreach (World.SpecialTile tile in World.SpecialTiles) - { - if (tile.Code == null) - continue; - - if (tile.Code.StartsWith("HORSELEASER-")) - { - int id = int.Parse(tile.Code.Split("-")[1]); - if (horse.Leaser == id) - { - string msg = Messages.FormatHorseReturnedToUniter(horse.Breed.Name); - if (horse.Breed.Type == "pegasus") - msg = Messages.HorseLeaserReturnedToUniterPegasus; - - byte[] youWereTeleportedToUniter = PacketBuilder.CreateChat(msg, PacketBuilder.CHAT_BOTTOM_RIGHT); - SendPacket(youWereTeleportedToUniter); - - tpX = tile.X; - tpY = tile.Y; - - if(tile.ExitX != 0 && tile.ExitY != 0) - { - tpX = tile.ExitX; - tpY = tile.ExitY; - } - else - { - tpY++; - } - - } - } - } - - } - - byte[] horseReturned = PacketBuilder.CreateChat(Messages.FormatHorseReturnedToOwner(horse.Name), PacketBuilder.CHAT_BOTTOM_RIGHT); - SendPacket(horseReturned); - - if(tpX != 0 && tpY != 0) - LoggedinUser.Teleport(tpX, tpY); - - - if (LoggedinUser.CurrentlyRidingHorse != null) - { - if(LoggedinUser.CurrentlyRidingHorse.RandomId == horse.RandomId) - { - GameServer.StopRidingHorse(this); - } - - } - - if(LoggedinUser.LastViewedHorse != null) - { - if(LoggedinUser.LastViewedHorse.RandomId == horse.RandomId) - { - LoggedinUser.LastViewedHorse = null; - } - } - - - LoggedinUser.HorseInventory.DeleteHorse(horse); - } - - - } - - } - if(gotoPrision) - { - byte[] sendToPrision = PacketBuilder.CreateChat(Messages.YouWereSentToPrisionIsle, PacketBuilder.CHAT_BOTTOM_RIGHT); - SendPacket(sendToPrision); - LoggedinUser.Teleport(45, 35); - } - - - if (totalMinutesElapsed % 5 == 0) - LoggedinUser.Thirst--; - - if (totalMinutesElapsed % 15 == 0) - LoggedinUser.Hunger--; - - if (totalMinutesElapsed % 15 == 0) - LoggedinUser.Tiredness--; - } - - - - - if (!isDisconnecting) - minuteTimer.Change(oneMinute, oneMinute); - - } - - private void warnTimerTick(object state) - { - Logger.DebugPrint("Sending inactivity warning to: " + RemoteIp); - byte[] chatPacket = PacketBuilder.CreateChat(Messages.FormatIdleWarningMessage(), PacketBuilder.CHAT_BOTTOM_RIGHT); - SendPacket(chatPacket); - if (LoggedIn) - LoggedinUser.Idle = true; - } - - private void kickTimerTick(object state) - { - Kick(Messages.FormatIdleKickMessage()); - } - - public void Login(int id) - { - /* - * Check for duplicate user - * and disconnect them. - */ - foreach (GameClient Client in GameClient.ConnectedClients) - { - if (Client.LoggedIn) - { - if (Client.LoggedinUser.Id == id) - Client.Kick(Messages.KickReasonDuplicateLogin); - } - } - - LoggedinUser = new User(this, id); - LoggedIn = true; - - Database.SetIpAddress(id, RemoteIp); - Database.SetLoginCount(id, Database.GetLoginCount(id) + 1); - - keepAliveTimer = new Timer(new TimerCallback(keepAliveTick), null, oneMinute, oneMinute); - timeoutTimer = new Timer(new TimerCallback(timeoutTimerTick), null, timeoutInterval, timeoutInterval); - } - - private void parsePackets(byte[] Packet) - { - if (Packet.Length < 1) - { - Logger.ErrorPrint("Received an invalid packet (size: "+Packet.Length+")"); - } - byte identifier = Packet[0]; - - /* - * Every time ive tried to fix this properly by just checking if its null or something - * it keeps happening, so now im just going to catch the exception - * and hope it works. - */ - try - { - if (LoggedIn) - { - if (timeoutTimer != null) - timeoutTimer.Change(timeoutInterval, timeoutInterval); // Reset time before timing out - else - return; - - if (keepAliveTimer != null && identifier != PacketBuilder.PACKET_KEEP_ALIVE) - { - if (LoggedIn) - LoggedinUser.Idle = false; - keepAliveTimer.Change(oneMinute, oneMinute); - } - else - { - return; - } - } - - if (kickTimer != null && identifier != PacketBuilder.PACKET_KEEP_ALIVE) - kickTimer.Change(kickInterval, kickInterval); - else - return; - - if (warnTimer != null && identifier != PacketBuilder.PACKET_KEEP_ALIVE) - warnTimer.Change(warnInterval, warnInterval); - else - return; - } - catch (ObjectDisposedException) - { - return; - } - - - /* - * Put packet handling in a try/catch - * this prevents the entire server from crashing - * if theres an error in handling a particular packet. - */ - try - { - if (!LoggedIn) // Must be either login or policy-file-request - { - switch (identifier) - { - case PacketBuilder.PACKET_FLASH_XML_CROSSDOMAIN: - GameServer.OnCrossdomainPolicyRequest(this, Packet); - break; - case PacketBuilder.PACKET_LOGIN: - GameServer.OnLoginRequest(this, Packet); - break; - } - } - else - { - switch (identifier) - { - case PacketBuilder.PACKET_LOGIN: - GameServer.OnUserInfoRequest(this, Packet); - break; - case PacketBuilder.PACKET_MOVE: - GameServer.OnMovementPacket(this, Packet); - break; - case PacketBuilder.PACKET_PLAYERINFO: - GameServer.OnPlayerInfoPacket(this, Packet); - break; - case PacketBuilder.PACKET_PLAYER: - GameServer.OnProfilePacket(this, Packet); - break; - case PacketBuilder.PACKET_CHAT: - GameServer.OnChatPacket(this, Packet); - break; - case PacketBuilder.PACKET_CLICK: - GameServer.OnClickPacket(this, Packet); - break; - case PacketBuilder.PACKET_KEEP_ALIVE: - GameServer.OnKeepAlive(this, Packet); - break; - case PacketBuilder.PACKET_TRANSPORT: - GameServer.OnTransportUsed(this, Packet); - break; - case PacketBuilder.PACKET_INVENTORY: - GameServer.OnInventoryRequested(this, Packet); - break; - case PacketBuilder.PACKET_DYNAMIC_BUTTON: - GameServer.OnDynamicButtonPressed(this, Packet); - break; - case PacketBuilder.PACKET_DYNAMIC_INPUT: - GameServer.OnDynamicInputReceived(this, Packet); - break; - case PacketBuilder.PACKET_ITEM_INTERACTION: - GameServer.OnItemInteraction(this, Packet); - break; - case PacketBuilder.PACKET_ARENA_SCORE: - GameServer.OnArenaScored(this, Packet); - break; - case PacketBuilder.PACKET_QUIT: - GameServer.OnQuitPacket(this, Packet); - break; - case PacketBuilder.PACKET_NPC: - GameServer.OnNpcInteraction(this, Packet); - break; - case PacketBuilder.PACKET_BIRDMAP: - GameServer.OnBirdMapRequested(this, Packet); - break; - case PacketBuilder.PACKET_SWFMODULE: - GameServer.OnSwfModuleCommunication(this, Packet); - break; - case PacketBuilder.PACKET_HORSE: - GameServer.OnHorseInteraction(this, Packet); - break; - case PacketBuilder.PACKET_WISH: - GameServer.OnWish(this, Packet); - break; - case PacketBuilder.PACKET_RANCH: - GameServer.OnRanchPacket(this, Packet); - break; - case PacketBuilder.PACKET_AUCTION: - GameServer.OnAuctionPacket(this, Packet); - break; - case PacketBuilder.PACKET_PLAYER_INTERACTION: - GameServer.OnPlayerInteration(this, Packet); - break; - case PacketBuilder.PACKET_SOCIALS: - GameServer.OnSocialPacket(this, Packet); - break; - default: - Logger.ErrorPrint("Unimplemented Packet: " + BitConverter.ToString(Packet).Replace('-', ' ')); - break; - } - } - - } - catch(Exception e) - { - Logger.ErrorPrint("Unhandled Exception: " + e.ToString() + "\n" + e.Message + "\n" + e.StackTrace); - - Kick("Unhandled Exception: " + e.ToString()); - } - } - - public void Kick(string Reason) - { - byte[] kickPacket = PacketBuilder.CreateKickMessage(Reason); - SendPacket(kickPacket); - Disconnect(); - - Logger.InfoPrint("CLIENT: "+RemoteIp+" KICKED for: "+Reason); - } - - public void SendPacket(byte[] PacketData) - { - try - { - ClientSocket.Send(PacketData); - } - catch (Exception) - { - Disconnect(); - } - } - - } - - -} + Logger.DebugPrint("Kicking: " + client.LoggedinUser.Username); + } + client.Kick("Server shutdown."); + + } + } + catch (Exception) { }; + } + public static void CreateClient(object sender, SocketAsyncEventArgs e) + { + do + { + Socket eSocket = e.AcceptSocket; + if(eSocket != null) + new GameClient(eSocket); + e.AcceptSocket = null; + } while (!GameServer.ServerSocket.AcceptAsync(e)); + } + private void timeoutTimerTick(object state) + { + if (this.LoggedIn) + { + Disconnect(); + } + } + + public void Disconnect() + { + if (this.isDisconnecting) + return; + this.isDisconnecting = true; + + // Close Socket + if (ClientSocket != null) + { + ClientSocket.Disconnect(false); + ClientSocket.Dispose(); + ClientSocket = null; + } + + + // Stop Timers + if (timeoutTimer != null) + { + timeoutTimer.Dispose(); + timeoutTimer = null; + } + if (keepAliveTimer != null) + { + keepAliveTimer.Dispose(); + keepAliveTimer = null; + } + if (warnTimer != null) + { + warnTimer.Dispose(); + warnTimer = null; + } + if (kickTimer != null) + { + kickTimer.Dispose(); + kickTimer = null; + } + + // Call OnDisconnect + + connectedClients.Remove(this); + GameServer.OnDisconnect(this); + LoggedIn = false; + + } + + + private void receivePackets(object sender, SocketAsyncEventArgs e) + { + do + { + // HI1 Packets are terminates by 0x00 so we have to read until we receive that terminator + + if (isDisconnecting || + ClientSocket == null || + e.BytesTransferred <= 0 || + !ClientSocket.Connected || + e.SocketError != SocketError.Success) + { + Disconnect(); + return; + } + + int availble = e.BytesTransferred; + if (availble >= 1) // More than 1 byte transfered.. + { + + for (int i = 0; i < availble; i++) + { + currentPacket.Add(e.Buffer[i]); + if (e.Buffer[i] == PacketBuilder.PACKET_TERMINATOR) // Read until \0... + { + parsePackets(currentPacket.ToArray()); + currentPacket.Clear(); + } + } + } + + if (availble == 0) + Disconnect(); + + if (isDisconnecting || ClientSocket == null) + return; + + + } while (!ClientSocket.ReceiveAsync(e)); + + } + + private void keepAliveTick(object state) + { + Logger.DebugPrint("Sending keep-alive packet to " + LoggedinUser.Username); + byte[] updatePacket = PacketBuilder.CreateKeepAlive(); + SendPacket(updatePacket); + if(!isDisconnecting && keepAliveTimer != null) // wtf how is this still a problem? + keepAliveTimer.Change(oneMinute, oneMinute); + } + private void minuteTimerTick(object state) + { + totalMinutesElapsed++; + if (LoggedIn) + { + + GameServer.UpdatePlayer(this); + + LoggedinUser.CanUseAdsChat = true; + LoggedinUser.FreeMinutes -= 1; + + GameServer.DoItemPurchases(this); + + if (totalMinutesElapsed % 2 == 0) + { + LoggedinUser.TotalGlobalChatMessages++; + } + + if (LoggedinUser.FreeMinutes <= 0) + { + LoggedinUser.FreeMinutes = 0; + if (!LoggedinUser.Subscribed && !LoggedinUser.Moderator && !LoggedinUser.Administrator) + { + Kick(Messages.KickReasonNoTime); + return; + } + + } + + // Those fun messages when u have been playing for awhile. + if (totalMinutesElapsed % (2 * 60) == 0) + { + string ptMessage = Messages.RngMessages[GameServer.RandomNumberGenerator.Next(0, Messages.RngMessages.Length)]; + byte[] playTimeMessage = PacketBuilder.CreateChat(Messages.FormatPlaytimeMessage(totalMinutesElapsed / 60) + ptMessage, PacketBuilder.CHAT_BOTTOM_RIGHT); + SendPacket(playTimeMessage); + } + + + if (GameServer.RandomNumberGenerator.Next(0, 100) == 59) // RANDOM EVENT HAS OCCURED! + { + RandomEvent.ExecuteRandomEvent(LoggedinUser); + } + + bool gotoPrision = false; + foreach(HorseInstance horse in LoggedinUser.HorseInventory.HorseList) + { + if (totalMinutesElapsed % 2 == 0) + { + horse.BasicStats.Thirst--; + horse.BasicStats.Hunger--; + + if (horse.BasicStats.Thirst <= 0 && horse.BasicStats.Hunger <= 0) + { + horse.BasicStats.Health -= 5; + if(horse.BasicStats.Hunger <= 0) + { + gotoPrision = true; // Goto jail, go directly to jail, do not pass go, do not collect 200$ + + horse.BasicStats.Health = 10; + horse.BasicStats.Hunger = 500; + horse.BasicStats.Thirst = 500; + } + } + } + + + if(horse.Leaser > 0) + { + horse.LeaseTime--; + + if (horse.LeaseTime <= 0) + { + int tpX = 0; + int tpY = 0; + if(horse.Breed.Type == "unicorn" || horse.Breed.Type == "pegasus") + { + foreach (World.SpecialTile tile in World.SpecialTiles) + { + if (tile.Code == null) + continue; + + if (tile.Code.StartsWith("HORSELEASER-")) + { + int id = int.Parse(tile.Code.Split("-")[1]); + if (horse.Leaser == id) + { + string msg = Messages.FormatHorseReturnedToUniter(horse.Breed.Name); + if (horse.Breed.Type == "pegasus") + msg = Messages.HorseLeaserReturnedToUniterPegasus; + + byte[] youWereTeleportedToUniter = PacketBuilder.CreateChat(msg, PacketBuilder.CHAT_BOTTOM_RIGHT); + SendPacket(youWereTeleportedToUniter); + + tpX = tile.X; + tpY = tile.Y; + + if(tile.ExitX != 0 && tile.ExitY != 0) + { + tpX = tile.ExitX; + tpY = tile.ExitY; + } + else + { + tpY++; + } + + } + } + } + + } + + byte[] horseReturned = PacketBuilder.CreateChat(Messages.FormatHorseReturnedToOwner(horse.Name), PacketBuilder.CHAT_BOTTOM_RIGHT); + SendPacket(horseReturned); + + if(tpX != 0 && tpY != 0) + LoggedinUser.Teleport(tpX, tpY); + + + if (LoggedinUser.CurrentlyRidingHorse != null) + { + if(LoggedinUser.CurrentlyRidingHorse.RandomId == horse.RandomId) + { + GameServer.StopRidingHorse(this); + } + + } + + if(LoggedinUser.LastViewedHorse != null) + { + if(LoggedinUser.LastViewedHorse.RandomId == horse.RandomId) + { + LoggedinUser.LastViewedHorse = null; + } + } + + + LoggedinUser.HorseInventory.DeleteHorse(horse); + } + + + } + + } + if(gotoPrision) + { + byte[] sendToPrision = PacketBuilder.CreateChat(Messages.YouWereSentToPrisionIsle, PacketBuilder.CHAT_BOTTOM_RIGHT); + SendPacket(sendToPrision); + LoggedinUser.Teleport(45, 35); + } + + + if (totalMinutesElapsed % 5 == 0) + LoggedinUser.Thirst--; + + if (totalMinutesElapsed % 15 == 0) + LoggedinUser.Hunger--; + + if (totalMinutesElapsed % 15 == 0) + LoggedinUser.Tiredness--; + } + + + + + if (!isDisconnecting) + minuteTimer.Change(oneMinute, oneMinute); + + } + + private void warnTimerTick(object state) + { + Logger.DebugPrint("Sending inactivity warning to: " + RemoteIp); + byte[] chatPacket = PacketBuilder.CreateChat(Messages.FormatIdleWarningMessage(), PacketBuilder.CHAT_BOTTOM_RIGHT); + SendPacket(chatPacket); + if (LoggedIn) + LoggedinUser.Idle = true; + } + + private void kickTimerTick(object state) + { + Kick(Messages.FormatIdleKickMessage()); + } + + public void Login(int id) + { + /* + * Check for duplicate user + * and disconnect them. + */ + foreach (GameClient Client in GameClient.ConnectedClients) + { + if (Client.LoggedIn) + { + if (Client.LoggedinUser.Id == id) + Client.Kick(Messages.KickReasonDuplicateLogin); + } + } + + LoggedinUser = new User(this, id); + LoggedIn = true; + + Database.SetIpAddress(id, RemoteIp); + Database.SetLoginCount(id, Database.GetLoginCount(id) + 1); + + keepAliveTimer = new Timer(new TimerCallback(keepAliveTick), null, oneMinute, oneMinute); + timeoutTimer = new Timer(new TimerCallback(timeoutTimerTick), null, timeoutInterval, timeoutInterval); + } + + private void parsePackets(byte[] Packet) + { + if (Packet.Length < 1) + { + Logger.ErrorPrint("Received an invalid packet (size: "+Packet.Length+")"); + } + byte identifier = Packet[0]; + + /* + * Every time ive tried to fix this properly by just checking if its null or something + * it keeps happening, so now im just going to catch the exception + * and hope it works. + */ + try + { + if (LoggedIn) + { + if (timeoutTimer != null) + timeoutTimer.Change(timeoutInterval, timeoutInterval); // Reset time before timing out + else + return; + + if (keepAliveTimer != null && identifier != PacketBuilder.PACKET_KEEP_ALIVE) + { + if (LoggedIn) + LoggedinUser.Idle = false; + keepAliveTimer.Change(oneMinute, oneMinute); + } + else + { + return; + } + } + + if (kickTimer != null && identifier != PacketBuilder.PACKET_KEEP_ALIVE) + kickTimer.Change(kickInterval, kickInterval); + else + return; + + if (warnTimer != null && identifier != PacketBuilder.PACKET_KEEP_ALIVE) + warnTimer.Change(warnInterval, warnInterval); + else + return; + } + catch (ObjectDisposedException) + { + return; + } + + + /* + * Put packet handling in a try/catch + * this prevents the entire server from crashing + * if theres an error in handling a particular packet. + */ + try + { + if (!LoggedIn) // Must be either login or policy-file-request + { + switch (identifier) + { + case PacketBuilder.PACKET_FLASH_XML_CROSSDOMAIN: + GameServer.OnCrossdomainPolicyRequest(this, Packet); + break; + case PacketBuilder.PACKET_LOGIN: + GameServer.OnLoginRequest(this, Packet); + break; + } + } + else + { + switch (identifier) + { + case PacketBuilder.PACKET_LOGIN: + GameServer.OnUserInfoRequest(this, Packet); + break; + case PacketBuilder.PACKET_MOVE: + GameServer.OnMovementPacket(this, Packet); + break; + case PacketBuilder.PACKET_PLAYERINFO: + GameServer.OnPlayerInfoPacket(this, Packet); + break; + case PacketBuilder.PACKET_PLAYER: + GameServer.OnProfilePacket(this, Packet); + break; + case PacketBuilder.PACKET_CHAT: + GameServer.OnChatPacket(this, Packet); + break; + case PacketBuilder.PACKET_CLICK: + GameServer.OnClickPacket(this, Packet); + break; + case PacketBuilder.PACKET_KEEP_ALIVE: + GameServer.OnKeepAlive(this, Packet); + break; + case PacketBuilder.PACKET_TRANSPORT: + GameServer.OnTransportUsed(this, Packet); + break; + case PacketBuilder.PACKET_INVENTORY: + GameServer.OnInventoryRequested(this, Packet); + break; + case PacketBuilder.PACKET_DYNAMIC_BUTTON: + GameServer.OnDynamicButtonPressed(this, Packet); + break; + case PacketBuilder.PACKET_DYNAMIC_INPUT: + GameServer.OnDynamicInputReceived(this, Packet); + break; + case PacketBuilder.PACKET_ITEM_INTERACTION: + GameServer.OnItemInteraction(this, Packet); + break; + case PacketBuilder.PACKET_ARENA_SCORE: + GameServer.OnArenaScored(this, Packet); + break; + case PacketBuilder.PACKET_QUIT: + GameServer.OnQuitPacket(this, Packet); + break; + case PacketBuilder.PACKET_NPC: + GameServer.OnNpcInteraction(this, Packet); + break; + case PacketBuilder.PACKET_BIRDMAP: + GameServer.OnBirdMapRequested(this, Packet); + break; + case PacketBuilder.PACKET_SWFMODULE: + GameServer.OnSwfModuleCommunication(this, Packet); + break; + case PacketBuilder.PACKET_HORSE: + GameServer.OnHorseInteraction(this, Packet); + break; + case PacketBuilder.PACKET_WISH: + GameServer.OnWish(this, Packet); + break; + case PacketBuilder.PACKET_RANCH: + GameServer.OnRanchPacket(this, Packet); + break; + case PacketBuilder.PACKET_AUCTION: + GameServer.OnAuctionPacket(this, Packet); + break; + case PacketBuilder.PACKET_PLAYER_INTERACTION: + GameServer.OnPlayerInteration(this, Packet); + break; + case PacketBuilder.PACKET_SOCIALS: + GameServer.OnSocialPacket(this, Packet); + break; + default: + Logger.ErrorPrint("Unimplemented Packet: " + BitConverter.ToString(Packet).Replace('-', ' ')); + break; + } + } + + } + catch(Exception e) + { + Logger.ErrorPrint("Unhandled Exception: " + e.ToString() + "\n" + e.Message + "\n" + e.StackTrace); + + Kick("Unhandled Exception: " + e.ToString()); + } + } + + public void Kick(string Reason) + { + byte[] kickPacket = PacketBuilder.CreateKickMessage(Reason); + SendPacket(kickPacket); + Disconnect(); + + Logger.InfoPrint("CLIENT: "+RemoteIp+" KICKED for: "+Reason); + } + + public void SendPacket(byte[] PacketData) + { + try + { + ClientSocket.Send(PacketData); + } + catch (Exception) + { + Disconnect(); + } + } + + } + + +} diff --git a/HorseIsleServer/MPN00BS/.gitignore b/HorseIsleServer/MPN00BS/.gitignore new file mode 100644 index 0000000..48cc008 --- /dev/null +++ b/HorseIsleServer/MPN00BS/.gitignore @@ -0,0 +1,454 @@ +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. +## +## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore + +# User-specific files +*.rsuser +*.suo +*.user +*.userosscache +*.sln.docstates + +# User-specific files (MonoDevelop/Xamarin Studio) +*.userprefs + +# Mono auto generated files +mono_crash.* + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +x64/ +x86/ +[Ww][Ii][Nn]32/ +[Aa][Rr][Mm]/ +[Aa][Rr][Mm]64/ +bld/ +[Bb]in/ +[Oo]bj/ +[Ll]og/ +[Ll]ogs/ + +# Visual Studio 2015/2017 cache/options directory +.vs/ +# Uncomment if you have tasks that create the project's static files in wwwroot +#wwwroot/ + +# Visual Studio 2017 auto generated files +Generated\ Files/ + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +# NUnit +*.VisualState.xml +TestResult.xml +nunit-*.xml + +# Build Results of an ATL Project +[Dd]ebugPS/ +[Rr]eleasePS/ +dlldata.c + +# Benchmark Results +BenchmarkDotNet.Artifacts/ + +# .NET Core +project.lock.json +project.fragment.lock.json +artifacts/ + +# Tye +.tye/ + +# ASP.NET Scaffolding +ScaffoldingReadMe.txt + +# StyleCop +StyleCopReport.xml + +# Files built by Visual Studio +*_i.c +*_p.c +*_h.h +*.ilk +*.meta +*.obj +*.iobj +*.pch +*.pdb +*.ipdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*_wpftmp.csproj +*.log +*.vspscc +*.vssscc +.builds +*.pidb +*.svclog +*.scc + +# Chutzpah Test files +_Chutzpah* + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opendb +*.opensdf +*.sdf +*.cachefile +*.VC.db +*.VC.VC.opendb + +# Visual Studio profiler +*.psess +*.vsp +*.vspx +*.sap + +# Visual Studio Trace Files +*.e2e + +# TFS 2012 Local Workspace +$tf/ + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper +*.DotSettings.user + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# AxoCover is a Code Coverage Tool +.axoCover/* +!.axoCover/settings.json + +# Coverlet is a free, cross platform Code Coverage Tool +coverage*.json +coverage*.xml +coverage*.info + +# Visual Studio code coverage results +*.coverage +*.coveragexml + +# NCrunch +_NCrunch_* +.*crunch*.local.xml +nCrunchTemp_* + +# MightyMoose +*.mm.* +AutoTest.Net/ + +# Web workbench (sass) +.sass-cache/ + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.[Pp]ublish.xml +*.azurePubxml +# Note: Comment the next line if you want to checkin your web deploy settings, +# but database connection strings (with potential passwords) will be unencrypted +*.pubxml +*.publishproj + +# Microsoft Azure Web App publish settings. Comment the next line if you want to +# checkin your Azure Web App publish settings, but sensitive information contained +# in these scripts will be unencrypted +PublishScripts/ + +# NuGet Packages +*.nupkg +# NuGet Symbol Packages +*.snupkg +# The packages folder can be ignored because of Package Restore +**/[Pp]ackages/* +# except build/, which is used as an MSBuild target. +!**/[Pp]ackages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/[Pp]ackages/repositories.config +# NuGet v3's project.json files produces more ignorable files +*.nuget.props +*.nuget.targets + +# Microsoft Azure Build Output +csx/ +*.build.csdef + +# Microsoft Azure Emulator +ecf/ +rcf/ + +# Windows Store app package directories and files +AppPackages/ +BundleArtifacts/ +Package.StoreAssociation.xml +_pkginfo.txt +*.appx +*.appxbundle +*.appxupload + +# Visual Studio cache files +# files ending in .cache can be ignored +*.[Cc]ache +# but keep track of directories ending in .cache +!?*.[Cc]ache/ + +# Others +ClientBin/ +~$* +*~ +*.dbmdl +*.dbproj.schemaview +*.jfm +*.pfx +*.publishsettings +orleans.codegen.cs + +# Including strong name files can present a security risk +# (https://github.com/github/gitignore/pull/2483#issue-259490424) +#*.snk + +# Since there are multiple workflows, uncomment next line to ignore bower_components +# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) +#bower_components/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file +# to a newer Visual Studio version. Backup files are not needed, +# because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm +ServiceFabricBackup/ +*.rptproj.bak + +# SQL Server files +*.mdf +*.ldf +*.ndf + +# Business Intelligence projects +*.rdl.data +*.bim.layout +*.bim_*.settings +*.rptproj.rsuser +*- [Bb]ackup.rdl +*- [Bb]ackup ([0-9]).rdl +*- [Bb]ackup ([0-9][0-9]).rdl + +# Microsoft Fakes +FakesAssemblies/ + +# GhostDoc plugin setting file +*.GhostDoc.xml + +# Node.js Tools for Visual Studio +.ntvs_analysis.dat +node_modules/ + +# Visual Studio 6 build log +*.plg + +# Visual Studio 6 workspace options file +*.opt + +# Visual Studio 6 auto-generated workspace file (contains which files were open etc.) +*.vbw + +# Visual Studio LightSwitch build output +**/*.HTMLClient/GeneratedArtifacts +**/*.DesktopClient/GeneratedArtifacts +**/*.DesktopClient/ModelManifest.xml +**/*.Server/GeneratedArtifacts +**/*.Server/ModelManifest.xml +_Pvt_Extensions + +# Paket dependency manager +.paket/paket.exe +paket-files/ + +# FAKE - F# Make +.fake/ + +# CodeRush personal settings +.cr/personal + +# Python Tools for Visual Studio (PTVS) +__pycache__/ +*.pyc + +# Cake - Uncomment if you are using it +# tools/** +# !tools/packages.config + +# Tabs Studio +*.tss + +# Telerik's JustMock configuration file +*.jmconfig + +# BizTalk build output +*.btp.cs +*.btm.cs +*.odx.cs +*.xsd.cs + +# OpenCover UI analysis results +OpenCover/ + +# Azure Stream Analytics local run output +ASALocalRun/ + +# MSBuild Binary and Structured Log +*.binlog + +# NVidia Nsight GPU debugger configuration file +*.nvuser + +# MFractors (Xamarin productivity tool) working folder +.mfractor/ + +# Local History for Visual Studio +.localhistory/ + +# BeatPulse healthcheck temp database +healthchecksdb + +# Backup folder for Package Reference Convert tool in Visual Studio 2017 +MigrationBackup/ + +# Ionide (cross platform F# VS Code tools) working folder +.ionide/ + +# Fody - auto-generated XML schema +FodyWeavers.xsd + +## +## Visual studio for Mac +## + + +# globs +Makefile.in +*.userprefs +*.usertasks +config.make +config.status +aclocal.m4 +install-sh +autom4te.cache/ +*.tar.gz +tarballs/ +test-results/ + +# Mac bundle stuff +*.dmg +*.app + +# content below from: https://github.com/github/gitignore/blob/master/Global/macOS.gitignore +# General +.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + + +# Thumbnails +._* + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.Spotlight-V100 +.TemporaryItems +.Trashes +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# content below from: https://github.com/github/gitignore/blob/master/Global/Windows.gitignore +# Windows thumbnail cache files +Thumbs.db +ehthumbs.db +ehthumbs_vista.db + +# Dump file +*.stackdump + +# Folder config file +[Dd]esktop.ini + +# Recycle Bin used on file shares +$RECYCLE.BIN/ + +# Windows Installer files +*.cab +*.msi +*.msix +*.msm +*.msp + +# Windows shortcuts +*.lnk + +# JetBrains Rider +.idea/ +*.sln.iml + +## +## Visual Studio Code +## +.vscode/* +!.vscode/settings.json +!.vscode/tasks.json +!.vscode/launch.json +!.vscode/extensions.json diff --git a/HorseIsleServer/MPN00BS/App.axaml b/HorseIsleServer/MPN00BS/App.axaml new file mode 100644 index 0000000..a9c8702 --- /dev/null +++ b/HorseIsleServer/MPN00BS/App.axaml @@ -0,0 +1,7 @@ + + + + + diff --git a/HorseIsleServer/MPN00BS/App.axaml.cs b/HorseIsleServer/MPN00BS/App.axaml.cs new file mode 100644 index 0000000..7486978 --- /dev/null +++ b/HorseIsleServer/MPN00BS/App.axaml.cs @@ -0,0 +1,24 @@ +using Avalonia; +using Avalonia.Controls.ApplicationLifetimes; +using Avalonia.Markup.Xaml; + +namespace MPN00BS +{ + public partial class App : Application + { + public override void Initialize() + { + AvaloniaXamlLoader.Load(this); + } + + public override void OnFrameworkInitializationCompleted() + { + if (ApplicationLifetime is IClassicDesktopStyleApplicationLifetime desktop) + { + desktop.MainWindow = new MpOrSp(); + } + + base.OnFrameworkInitializationCompleted(); + } + } +} diff --git a/HorseIsleServer/MPN00BS/HTTP/ContentServer.cs b/HorseIsleServer/MPN00BS/HTTP/ContentServer.cs new file mode 100644 index 0000000..5640781 --- /dev/null +++ b/HorseIsleServer/MPN00BS/HTTP/ContentServer.cs @@ -0,0 +1,296 @@ +using System; +using System.Collections.Generic; +using System.IO; +using System.Net; +using System.Net.Sockets; +using System.Text; + +namespace HTTP +{ + class ContentItem + { + + public String name; + public String filePath; + public ContentItem(string Name,string FilePath) + { + if(File.Exists(FilePath)) + { + filePath = FilePath; + name = Name; + } + else + { + throw new FileNotFoundException(); + } + } + + } + + class ContentClient + { + + public ContentClient(ContentServer Server, Socket ClientSocket) + { + clientSock = ClientSocket; + baseServ = Server; + baseServ.WriteDebugOutput("Client Connected @ " + clientSock.RemoteEndPoint.ToString()); + ProcessRequests(); + clientSock.Close(); + + } + + private ContentServer baseServ; + private Socket clientSock; + + + private byte[] ReadData() + { + while (clientSock.Available < 1) { } + byte[] by = new byte[clientSock.Available]; + clientSock.Receive(by); + return by; + } + + private void SendString(string str) + { + byte[] response = Encoding.UTF8.GetBytes(str); + clientSock.Send(response); + } + + private string GenerateHeaders(string path, long content_length = 0) + { + string headers = ""; + + if (path == "/") + { + headers += "HTTP/1.1 200 OK\r\n"; + headers += "Content-Type: text/html\r\n"; + headers += "Accept-Ranges: bytes\r\n"; + headers += "Server: ContentServer\r\n"; + headers += "Content-Length: " + content_length + "\r\n"; + headers += "Cache-Control: max-age=0\r\n"; + headers += "Connection: keep-alive\r\n"; + headers += "\r\n"; + } + else if (File.Exists(path)) + { + FileInfo info = new FileInfo(path); + long length = info.Length; + + if (content_length != 0) + length = content_length; + + + headers += "HTTP/1.1 200 OK\r\n"; + headers += "Content-Type: application/x-shockwave-flash\r\n"; + headers += "Accept-Ranges: bytes\r\n"; + headers += "Server: ContentServer\r\n"; + headers += "Content-Length: " + length + "\r\n"; + headers += "Cache-Control: max-age=0\r\n"; + headers += "Connection: keep-alive\r\n"; + headers += "\r\n"; + } + else + { + headers += "HTTP/1.1 404 Not Found\r\n"; + headers += "Content-Type: text/plain\r\n"; + headers += "Accept-Ranges: bytes\r\n"; + headers += "Server: ContentServer\r\n"; + headers += "Content-Length: " + content_length + "\r\n"; + headers += "Cache-Control: max-age=3600\r\n"; + headers += "Connection: keep-alive\r\n"; + headers += "\r\n"; + } + return headers; + } + + private void RespondGet(string name) + { + baseServ.WriteDebugOutput("GET " + name); + + if (ContentItemExists(name)) + { + ContentItem ci = GetContentItem(name); + FileStream fs = File.OpenRead(ci.filePath); + try + { + string requestStr = GenerateHeaders(ci.filePath, fs.Length - fs.Position); + + SendString(requestStr); + + while(fs.Position < fs.Length) + { + int BUFFER_SIZE = 0x8500000; + if(fs.Position + BUFFER_SIZE <= fs.Length) + { + byte[] buffer = new byte[BUFFER_SIZE]; + fs.Read(buffer, 0x00, BUFFER_SIZE); + clientSock.Send(buffer); + } + else + { + byte[] buffer = new byte[fs.Length - fs.Position]; + fs.Read(buffer, 0x00, buffer.Length); + clientSock.Send(buffer); + } + + } + } + catch (Exception) { + fs.Close(); + }; + + } + else + { + string body = GeneratePage(name); + string requestStr = GenerateHeaders(name, body.Length); + requestStr += body; + + SendString(requestStr); + } + + } + + private void RespondHead(string path) + { + string name = Path.GetFileName(path); + baseServ.WriteDebugOutput("HEAD " + path); + + if (ContentItemExists(name)) + { + ContentItem ci = GetContentItem(name); + string requestStr = GenerateHeaders(ci.filePath); + SendString(requestStr); + } + else + { + string body = GeneratePage(path); + string requestStr = GenerateHeaders(path, body.Length); + SendString(requestStr); + } + + } + + private bool ContentItemExists(string name) + { + bool exists = false; + + + foreach (ContentItem ci in baseServ.Contents) + { + if (ci.name == name) + { + exists = true; + } + } + return exists; + } + + private ContentItem GetContentItem(string name) + { + + foreach (ContentItem ci in baseServ.Contents) + { + if (ci.name == name) + { + return ci; + } + } + throw new FileNotFoundException(); + } + + private string GeneratePage(string path) + { + if (path == "/") + { + string body = "Horse Isle Web Server..
Fork of SilicaAndPina's \"Content Server\""; + return body; + } + else + { + string body = "File not found."; + return body; + } + } + + private string ExtractPath(string relativeUri) + { + int questionIndex = relativeUri.IndexOf("?"); + if (questionIndex != -1) + return relativeUri.Substring(0, questionIndex); + else + return relativeUri; + } + private string ExtractRelativeUrl(string header) + { + return header.Split(' ')[1]; + } + private void ProcessRequests() + { + byte[] data = ReadData(); + + // Parse Request + + string curReq = Encoding.UTF8.GetString(data); + + curReq = curReq.Replace("\r\n", "\n"); + string[] reqLines = curReq.Split('\n'); + foreach (string line in reqLines) + { + if (line.StartsWith("GET")) + { + string relUrl = ExtractRelativeUrl(line); + string path = ExtractPath(relUrl); + //Dictionary query = ExtractQuery(relUrl); + RespondGet(path); + return; + } + else if (line.StartsWith("HEAD")) + { + string relUrl = ExtractRelativeUrl(line); + string path = ExtractPath(relUrl); + RespondHead(path); + return; + } + } + + } + } + class ContentServer + { + public List Contents = new List(); + public Socket ServerSocket; + public void WriteDebugOutput(string txt) + { + Console.WriteLine("[HTTP] " + txt); + } + + public void CreateClient(object sender, SocketAsyncEventArgs e) + { + do + { + Socket eSocket = e.AcceptSocket; + if (eSocket != null) + new ContentClient(this, eSocket); + e.AcceptSocket = null; + } while (!ServerSocket.AcceptAsync(e)); + } + public ContentServer(string ip) + { + + WriteDebugOutput("Listening for connections on port 80."); + IPEndPoint ep = new IPEndPoint(IPAddress.Parse(ip), 80); + ServerSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); + ServerSocket.Bind(ep); + ServerSocket.Listen(0x7fffffff); + + SocketAsyncEventArgs e = new SocketAsyncEventArgs(); + e.Completed += CreateClient; + CreateClient(this, e); + } + + + } +} diff --git a/HorseIsleServer/MPN00BS/HispLogo.gif b/HorseIsleServer/MPN00BS/HispLogo.gif new file mode 100644 index 0000000..c14afbf Binary files /dev/null and b/HorseIsleServer/MPN00BS/HispLogo.gif differ diff --git a/HorseIsleServer/MPN00BS/LoadingWindow.axaml b/HorseIsleServer/MPN00BS/LoadingWindow.axaml new file mode 100644 index 0000000..b288381 --- /dev/null +++ b/HorseIsleServer/MPN00BS/LoadingWindow.axaml @@ -0,0 +1,19 @@ + + + + + + + + + + diff --git a/HorseIsleServer/MPN00BS/LoadingWindow.axaml.cs b/HorseIsleServer/MPN00BS/LoadingWindow.axaml.cs new file mode 100644 index 0000000..afe54f4 --- /dev/null +++ b/HorseIsleServer/MPN00BS/LoadingWindow.axaml.cs @@ -0,0 +1,49 @@ +using Avalonia; +using Avalonia.Controls; +using Avalonia.Markup.Xaml; +using Avalonia.Threading; +using System.Threading.Tasks; + +namespace MPN00BS +{ + public partial class LoadingWindow : Window + { + + private void OnClientExit() + { + Dispatcher.UIThread.InvokeAsync(() => + { + this.Close(); + }); + } + + public void ProgressUpdate() + { + Dispatcher.UIThread.InvokeAsync(() => + { + startupProgress.Value++; + if (startupProgress.Value >= startupProgress.Maximum) + { + this.Hide(); + ServerStarter.StartHorseIsleClient(OnClientExit, "127.0.0.1", 12321); + } + }); + } + public LoadingWindow() + { + InitializeComponent(); +#if DEBUG + this.AttachDevTools(); +#endif + + ServerStarter.StartHttpServer(); + new Task( () => ServerStarter.StartHispServer(ProgressUpdate) ).Start(); + } + + private void InitializeComponent() + { + AvaloniaXamlLoader.Load(this); + startupProgress = this.FindControl("startupProgress"); + } + } +} diff --git a/HorseIsleServer/MPN00BS/MPN00BS.csproj b/HorseIsleServer/MPN00BS/MPN00BS.csproj new file mode 100644 index 0000000..110852c --- /dev/null +++ b/HorseIsleServer/MPN00BS/MPN00BS.csproj @@ -0,0 +1,92 @@ + + + WinExe + net7.0 + enable + + copyused + true + + + + + + + + + + + + + + + + + + + + MpOrSp.axaml + + + + + + PreserveNewest + client\%(Filename)%(Extension) + + + + + + PreserveNewest + client\map750.png + + + + + + PreserveNewest + client\mod\%(Filename)%(Extension) + + + + + + PreserveNewest + client\tack\%(Filename)%(Extension) + + + + + + + PreserveNewest + client\breed\%(Filename)%(Extension) + + + + + + PreserveNewest + client\resource\%(Filename)%(Extension) + + + + + + Never + + + + + + + + + + PreserveNewest + + + diff --git a/HorseIsleServer/MPN00BS/MessageBox.axaml b/HorseIsleServer/MPN00BS/MessageBox.axaml new file mode 100644 index 0000000..99c59cc --- /dev/null +++ b/HorseIsleServer/MPN00BS/MessageBox.axaml @@ -0,0 +1,17 @@ + + + + + + + + + + diff --git a/HorseIsleServer/MPN00BS/MessageBox.axaml.cs b/HorseIsleServer/MPN00BS/MessageBox.axaml.cs new file mode 100644 index 0000000..c51f3bd --- /dev/null +++ b/HorseIsleServer/MPN00BS/MessageBox.axaml.cs @@ -0,0 +1,76 @@ +using System.Threading.Tasks; +using Avalonia.Controls; +using Avalonia.Markup.Xaml; + +namespace MPN00BS +{ + public partial class MessageBox : Window + { + public enum MessageBoxButtons + { + Ok, + OkCancel, + YesNo, + YesNoCancel + } + + public enum MessageBoxResult + { + Ok, + Cancel, + Yes, + No + } + + public MessageBox() + { + AvaloniaXamlLoader.Load(this); + } + + public static Task Show(Window parent, string text, string title, MessageBoxButtons buttons) + { + var msgbox = new MessageBox() + { + Title = title + }; + msgbox.FindControl("Text").Text = text; + var buttonPanel = msgbox.FindControl("Buttons"); + + var res = MessageBoxResult.Ok; + + void AddButton(string caption, MessageBoxResult r, bool def = false) + { + var btn = new Button { Content = caption }; + btn.Click += (_, __) => { + res = r; + msgbox.Close(); + }; + buttonPanel.Children.Add(btn); + if (def) + res = r; + } + + if (buttons == MessageBoxButtons.Ok || buttons == MessageBoxButtons.OkCancel) + AddButton("Ok", MessageBoxResult.Ok, true); + if (buttons == MessageBoxButtons.YesNo || buttons == MessageBoxButtons.YesNoCancel) + { + AddButton("Yes", MessageBoxResult.Yes); + AddButton("No", MessageBoxResult.No, true); + } + + if (buttons == MessageBoxButtons.OkCancel || buttons == MessageBoxButtons.YesNoCancel) + AddButton("Cancel", MessageBoxResult.Cancel, true); + + + var tcs = new TaskCompletionSource(); + msgbox.Closed += delegate { tcs.TrySetResult(res); }; + if (parent != null) + msgbox.ShowDialog(parent); + else msgbox.Show(); + return tcs.Task; + } + + + } + +} \ No newline at end of file diff --git a/HorseIsleServer/MPN00BS/MpOrSp.axaml b/HorseIsleServer/MPN00BS/MpOrSp.axaml new file mode 100644 index 0000000..21a300e --- /dev/null +++ b/HorseIsleServer/MPN00BS/MpOrSp.axaml @@ -0,0 +1,21 @@ + + + + + + +