Compare commits
	
		
			28 Commits
		
	
	
		
			d5d3eef5f8
			...
			ui-updates
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9ca6931bb8 | |||
| f22eff1f72 | |||
| 11e097d696 | |||
| f7ecb45774 | |||
| 00a7328e3a | |||
| c39229a28b | |||
| 00c56b0888 | |||
| 15898d54c2 | |||
| 6d5ed42e60 | |||
| 92a8e224ef | |||
| 669ceed2a9 | |||
| 778d30ae26 | |||
| d2212da456 | |||
| a3dfe35df6 | |||
| da6623741c | |||
| abea8f0856 | |||
| 1624a84cf1 | |||
| ba852831aa | |||
| 5de9ad3a54 | |||
| 4c8ce23e8a | |||
| 2be5f5d320 | |||
| c428f306ca | |||
| 3dde713c91 | |||
| 3280446c7e | |||
| a408e22a68 | |||
| 1b71cda403 | |||
| eb8dbbd7f9 | |||
| abc361faf0 | 
							
								
								
									
										52
									
								
								.gitea/workflows/build.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								.gitea/workflows/build.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | name: .NET Build and Publish to Gitea | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: '*' | ||||||
|  |   pull_request: | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |     runs-on: dotnet | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout repository | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  |         with: | ||||||
|  |           submodules: true | ||||||
|  |       - name: Restore dependencies | ||||||
|  |         run: dotnet restore | ||||||
|  |  | ||||||
|  |       - name: Download Dalamud | ||||||
|  |         run: | | ||||||
|  |           mkdir -p $HOME/.xlcore/dalamud/Hooks/dev/ | ||||||
|  |           curl -L https://goatcorp.github.io/dalamud-distrib/stg/latest.zip -o latest.zip | ||||||
|  |           unzip -o latest.zip -d $HOME/.xlcore/dalamud/Hooks/dev/ | ||||||
|  |  | ||||||
|  |       - name: Build project | ||||||
|  |         run: dotnet build --no-restore --configuration Release --nologo | ||||||
|  |  | ||||||
|  |       - name: Publish Windows executable | ||||||
|  |         run: dotnet publish -c Release -r win-x64 --self-contained true -o ./publish | ||||||
|  |  | ||||||
|  |       - name: Archive published files | ||||||
|  |         run: zip -r SnowcloakClient.zip ./publish/* | ||||||
|  |  | ||||||
|  |       - name: Create Gitea release | ||||||
|  |         env: | ||||||
|  |           GITEA_TOKEN: ${{ secrets.BUILD_SNOWCLOAK_CLIENT  }} | ||||||
|  |         run: | | ||||||
|  |           API_URL="https://git.snowcloak-sync.com/api/v1/repos/Eauldane/SnowcloakClient/releases" | ||||||
|  |           TAG="v$(date +%Y%m%d%H%M)" | ||||||
|  |           # Create release | ||||||
|  |           RELEASE_ID=$(curl -s -X POST \ | ||||||
|  |             -H "Content-Type: application/json" \ | ||||||
|  |             -H "Authorization: token $GITEA_TOKEN" \ | ||||||
|  |             -d "{\"tag_name\":\"$TAG\",\"name\":\"Automated Build $TAG\",\"body\":\"Automated build artifact\"}" \ | ||||||
|  |             $API_URL | jq -r '.id') | ||||||
|  |           echo "Release ID: $RELEASE_ID" | ||||||
|  |           # Upload asset | ||||||
|  |           curl -s -X POST \ | ||||||
|  |             -H "Authorization: token $GITEA_TOKEN" \ | ||||||
|  |             -F "name=SnowcloakClient.zip" \ | ||||||
|  |             -F "attachment=@SnowcloakClient.zip" \ | ||||||
|  |             "$API_URL/$RELEASE_ID/assets" | ||||||
| @@ -27,9 +27,9 @@ public sealed class IpcCallerMoodles : IIpcCaller | |||||||
|  |  | ||||||
|         _moodlesApiVersion = pi.GetIpcSubscriber<int>("Moodles.Version"); |         _moodlesApiVersion = pi.GetIpcSubscriber<int>("Moodles.Version"); | ||||||
|         _moodlesOnChange = pi.GetIpcSubscriber<IPlayerCharacter, object>("Moodles.StatusManagerModified"); |         _moodlesOnChange = pi.GetIpcSubscriber<IPlayerCharacter, object>("Moodles.StatusManagerModified"); | ||||||
|         _moodlesGetStatus = pi.GetIpcSubscriber<nint, string>("Moodles.GetStatusManagerByPtr"); |         _moodlesGetStatus = pi.GetIpcSubscriber<nint, string>("Moodles.GetStatusManagerByPtrV2"); | ||||||
|         _moodlesSetStatus = pi.GetIpcSubscriber<nint, string, object>("Moodles.SetStatusManagerByPtr"); |         _moodlesSetStatus = pi.GetIpcSubscriber<nint, string, object>("Moodles.SetStatusManagerByPtrV2"); | ||||||
|         _moodlesRevertStatus = pi.GetIpcSubscriber<nint, object>("Moodles.ClearStatusManagerByPtr"); |         _moodlesRevertStatus = pi.GetIpcSubscriber<nint, object>("Moodles.ClearStatusManagerByPtrV2"); | ||||||
|  |  | ||||||
|         _moodlesOnChange.Subscribe(OnMoodlesChange); |         _moodlesOnChange.Subscribe(OnMoodlesChange); | ||||||
|  |  | ||||||
| @@ -47,7 +47,7 @@ public sealed class IpcCallerMoodles : IIpcCaller | |||||||
|     { |     { | ||||||
|         try |         try | ||||||
|         { |         { | ||||||
|             APIAvailable = _moodlesApiVersion.InvokeFunc() == 1; |             APIAvailable = _moodlesApiVersion.InvokeFunc() == 3; | ||||||
|         } |         } | ||||||
|         catch |         catch | ||||||
|         { |         { | ||||||
|   | |||||||
| @@ -30,12 +30,12 @@ public sealed class IpcCallerPetNames : IIpcCaller | |||||||
|         _dalamudUtil = dalamudUtil; |         _dalamudUtil = dalamudUtil; | ||||||
|         _mareMediator = mareMediator; |         _mareMediator = mareMediator; | ||||||
|  |  | ||||||
|         _petnamesReady = pi.GetIpcSubscriber<object>("PetRenamer.Ready"); |         _petnamesReady = pi.GetIpcSubscriber<object>("PetRenamer.OnReady"); | ||||||
|         _petnamesDisposing = pi.GetIpcSubscriber<object>("PetRenamer.Disposing"); |         _petnamesDisposing = pi.GetIpcSubscriber<object>("PetRenamer.OnDisposing"); | ||||||
|         _apiVersion = pi.GetIpcSubscriber<(uint, uint)>("PetRenamer.ApiVersion"); |         _apiVersion = pi.GetIpcSubscriber<(uint, uint)>("PetRenamer.ApiVersion"); | ||||||
|         _enabled = pi.GetIpcSubscriber<bool>("PetRenamer.Enabled"); |         _enabled = pi.GetIpcSubscriber<bool>("PetRenamer.IsEnabled"); | ||||||
|  |  | ||||||
|         _playerDataChanged = pi.GetIpcSubscriber<string, object>("PetRenamer.PlayerDataChanged"); |         _playerDataChanged = pi.GetIpcSubscriber<string, object>("PetRenamer.OnPlayerDataChanged"); | ||||||
|         _getPlayerData = pi.GetIpcSubscriber<string>("PetRenamer.GetPlayerData"); |         _getPlayerData = pi.GetIpcSubscriber<string>("PetRenamer.GetPlayerData"); | ||||||
|         _setPlayerData = pi.GetIpcSubscriber<string, object>("PetRenamer.SetPlayerData"); |         _setPlayerData = pi.GetIpcSubscriber<string, object>("PetRenamer.SetPlayerData"); | ||||||
|         _clearPlayerData = pi.GetIpcSubscriber<ushort, object>("PetRenamer.ClearPlayerData"); |         _clearPlayerData = pi.GetIpcSubscriber<ushort, object>("PetRenamer.ClearPlayerData"); | ||||||
| @@ -56,7 +56,7 @@ public sealed class IpcCallerPetNames : IIpcCaller | |||||||
|             APIAvailable = _enabled?.InvokeFunc() ?? false; |             APIAvailable = _enabled?.InvokeFunc() ?? false; | ||||||
|             if (APIAvailable) |             if (APIAvailable) | ||||||
|             { |             { | ||||||
|                 APIAvailable = _apiVersion?.InvokeFunc() is { Item1: 3, Item2: >= 1 }; |                 APIAvailable = _apiVersion?.InvokeFunc() is { Item1: 4, Item2: >= 0 }; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         catch |         catch | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ namespace MareSynchronos.MareConfiguration.Configurations; | |||||||
| [Serializable] | [Serializable] | ||||||
| public class MareConfig : IMareConfiguration | public class MareConfig : IMareConfiguration | ||||||
| { | { | ||||||
|  |     public bool SortSyncshellsByVRAM { get; set; } = false; | ||||||
|     public int ExpectedTOSVersion = 2; |     public int ExpectedTOSVersion = 2; | ||||||
|     public int AcceptedTOSVersion { get; set; } = 0; |     public int AcceptedTOSVersion { get; set; } = 0; | ||||||
|     public bool AcceptedAgreement { get; set; } = false; |     public bool AcceptedAgreement { get; set; } = false; | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| <Project Sdk="Dalamud.NET.Sdk/13.0.0"> | <Project Sdk="Dalamud.NET.Sdk/13.0.0"> | ||||||
|   <PropertyGroup> |   <PropertyGroup> | ||||||
|     <AssemblyName>Snowcloak</AssemblyName> |     <AssemblyName>Snowcloak</AssemblyName> | ||||||
|     <Version>0.2.0.2</Version> |     <Version>0.2.1</Version> | ||||||
|     <PackageProjectUrl>https://github.com/Eauldane/SnowcloakClient/</PackageProjectUrl> |     <PackageProjectUrl>https://github.com/Eauldane/SnowcloakClient/</PackageProjectUrl> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  |  | ||||||
| @@ -14,10 +14,12 @@ | |||||||
|  |  | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="Chaos.NaCl.Standard" Version="1.0.0" /> |     <PackageReference Include="Chaos.NaCl.Standard" Version="1.0.0" /> | ||||||
|     <PackageReference Include="Downloader" Version="3.3.4" /> |     <PackageReference Include="Downloader" Version="4.0.3" /> | ||||||
|     <PackageReference Include="K4os.Compression.LZ4.Legacy" Version="1.3.8" /> |     <PackageReference Include="K4os.Compression.LZ4.Legacy" Version="1.3.8" /> | ||||||
|     <PackageReference Include="K4os.Compression.LZ4.Streams" Version="1.3.8" /> |     <PackageReference Include="K4os.Compression.LZ4.Streams" Version="1.3.8" /> | ||||||
|     <PackageReference Include="Meziantou.Analyzer" Version="2.0.212"> |     <PackageReference Include="MessagePack" Version="3.1.4" /> | ||||||
|  |     <PackageReference Include="MessagePack.Annotations" Version="3.1.4" /> | ||||||
|  |     <PackageReference Include="Meziantou.Analyzer" Version="2.0.213"> | ||||||
|       <PrivateAssets>all</PrivateAssets> |       <PrivateAssets>all</PrivateAssets> | ||||||
|       <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> |       <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> | ||||||
|     </PackageReference> |     </PackageReference> | ||||||
| @@ -29,6 +31,8 @@ | |||||||
|       <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> |       <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> | ||||||
|     </PackageReference> |     </PackageReference> | ||||||
|     <PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="8.14.0" /> |     <PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="8.14.0" /> | ||||||
|  |     <PackageReference Update="DalamudPackager" Version="13.1.0" /> | ||||||
|  |     <PackageReference Include="System.IO.Pipelines" Version="9.0.8" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|  |  | ||||||
|   <ItemGroup Condition="Exists('.\Penumbra.Api\Penumbra.Api.csproj')"> |   <ItemGroup Condition="Exists('.\Penumbra.Api\Penumbra.Api.csproj')"> | ||||||
|   | |||||||
| @@ -9,6 +9,6 @@ | |||||||
|     "customization" |     "customization" | ||||||
|   ], |   ], | ||||||
|   "IconUrl": "https://raw.githubusercontent.com/Eauldane/SnowcloakClient/refs/heads/main/MareSynchronos/images/logo.png", |   "IconUrl": "https://raw.githubusercontent.com/Eauldane/SnowcloakClient/refs/heads/main/MareSynchronos/images/logo.png", | ||||||
|   "RepoUrl": "https://github.com/Eauldane/SnowcloakClient", |   "RepoUrl": "https://git.snowcloak-sync.com/Eauldane/SnowcloakClient", | ||||||
|   "CanUnloadAsync": true |   "CanUnloadAsync": true | ||||||
| } | } | ||||||
|   | |||||||
| @@ -387,7 +387,7 @@ public class CompactUi : WindowMediatorSubscriberBase | |||||||
|         { |         { | ||||||
|             ImGui.SetCursorPosX((ImGui.GetWindowContentRegionMin().X + UiSharedService.GetWindowContentRegionWidth()) / 2 - (userSize.X + textSize.X) / 2 - ImGui.GetStyle().ItemSpacing.X / 2); |             ImGui.SetCursorPosX((ImGui.GetWindowContentRegionMin().X + UiSharedService.GetWindowContentRegionWidth()) / 2 - (userSize.X + textSize.X) / 2 - ImGui.GetStyle().ItemSpacing.X / 2); | ||||||
|             if (!printShard) ImGui.AlignTextToFramePadding(); |             if (!printShard) ImGui.AlignTextToFramePadding(); | ||||||
|             ImGui.TextColored(ImGuiColors.ParsedGreen, userCount); |             ImGui.TextColored(new Vector4(0.675f, 0.985f, 1f, 1f), userCount); | ||||||
|             ImGui.SameLine(); |             ImGui.SameLine(); | ||||||
|             if (!printShard) ImGui.AlignTextToFramePadding(); |             if (!printShard) ImGui.AlignTextToFramePadding(); | ||||||
|             ImGui.TextUnformatted("Users Online"); |             ImGui.TextUnformatted("Users Online"); | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ public class DrawGroupPair : DrawPairBase | |||||||
|     private readonly GroupPairFullInfoDto _fullInfoDto; |     private readonly GroupPairFullInfoDto _fullInfoDto; | ||||||
|     private readonly GroupFullInfoDto _group; |     private readonly GroupFullInfoDto _group; | ||||||
|     private readonly CharaDataManager _charaDataManager; |     private readonly CharaDataManager _charaDataManager; | ||||||
|  |     public long VramUsage { get; set; } | ||||||
|  |  | ||||||
|     public DrawGroupPair(string id, Pair entry, ApiController apiController, |     public DrawGroupPair(string id, Pair entry, ApiController apiController, | ||||||
|         MareMediator mareMediator, GroupFullInfoDto group, GroupPairFullInfoDto fullInfoDto, |         MareMediator mareMediator, GroupFullInfoDto group, GroupPairFullInfoDto fullInfoDto, | ||||||
| @@ -80,11 +81,13 @@ public class DrawGroupPair : DrawPairBase | |||||||
|             } |             } | ||||||
|             if (_pair.LastAppliedDataBytes >= 0) |             if (_pair.LastAppliedDataBytes >= 0) | ||||||
|             { |             { | ||||||
|  |  | ||||||
|                 presenceText += UiSharedService.TooltipSeparator; |                 presenceText += UiSharedService.TooltipSeparator; | ||||||
|                 presenceText += ((!_pair.IsVisible) ? "(Last) " : string.Empty) + "Mods Info" + Environment.NewLine; |                 presenceText += ((!_pair.IsVisible) ? "(Last) " : string.Empty) + "Mods Info" + Environment.NewLine; | ||||||
|                 presenceText += "Files Size: " + UiSharedService.ByteToString(_pair.LastAppliedDataBytes, true); |                 presenceText += "Files Size: " + UiSharedService.ByteToString(_pair.LastAppliedDataBytes, true); | ||||||
|                 if (_pair.LastAppliedApproximateVRAMBytes >= 0) |                 if (_pair.LastAppliedApproximateVRAMBytes >= 0) | ||||||
|                 { |                 { | ||||||
|  |                     VramUsage = _pair.LastAppliedApproximateVRAMBytes; | ||||||
|                     presenceText += Environment.NewLine + "Approx. VRAM Usage: " + UiSharedService.ByteToString(_pair.LastAppliedApproximateVRAMBytes, true); |                     presenceText += Environment.NewLine + "Approx. VRAM Usage: " + UiSharedService.ByteToString(_pair.LastAppliedApproximateVRAMBytes, true); | ||||||
|                 } |                 } | ||||||
|                 if (_pair.LastAppliedDataTris >= 0) |                 if (_pair.LastAppliedDataTris >= 0) | ||||||
| @@ -127,6 +130,9 @@ public class DrawGroupPair : DrawPairBase | |||||||
|  |  | ||||||
|     protected override float DrawRightSide(float textPosY, float originalY) |     protected override float DrawRightSide(float textPosY, float originalY) | ||||||
|     { |     { | ||||||
|  |         var pauseIcon = _fullInfoDto.GroupUserPermissions.IsPaused() ? FontAwesomeIcon.Play : FontAwesomeIcon.Pause; | ||||||
|  |         var pauseIconSize = _uiSharedService.GetIconButtonSize(pauseIcon); | ||||||
|  |         var spacingX = ImGui.GetStyle().ItemSpacing.X; | ||||||
|         var entryUID = _fullInfoDto.UserAliasOrUID; |         var entryUID = _fullInfoDto.UserAliasOrUID; | ||||||
|         var entryIsMod = _fullInfoDto.GroupPairStatusInfo.IsModerator(); |         var entryIsMod = _fullInfoDto.GroupPairStatusInfo.IsModerator(); | ||||||
|         var entryIsOwner = string.Equals(_pair.UserData.UID, _group.OwnerUID, StringComparison.Ordinal); |         var entryIsOwner = string.Equals(_pair.UserData.UID, _group.OwnerUID, StringComparison.Ordinal); | ||||||
| @@ -145,19 +151,27 @@ public class DrawGroupPair : DrawPairBase | |||||||
|         bool showInfo = (individualAnimDisabled || individualSoundsDisabled || animDisabled || soundsDisabled); |         bool showInfo = (individualAnimDisabled || individualSoundsDisabled || animDisabled || soundsDisabled); | ||||||
|         bool showPlus = _pair.UserPair == null; |         bool showPlus = _pair.UserPair == null; | ||||||
|         bool showBars = (userIsOwner || (userIsModerator && !entryIsMod && !entryIsOwner)) || !_pair.IsPaused; |         bool showBars = (userIsOwner || (userIsModerator && !entryIsMod && !entryIsOwner)) || !_pair.IsPaused; | ||||||
|  |         bool showPause = true;  | ||||||
|         var spacing = ImGui.GetStyle().ItemSpacing.X; |         var spacing = ImGui.GetStyle().ItemSpacing.X; | ||||||
|         var permIcon = (individualAnimDisabled || individualSoundsDisabled || individualVFXDisabled) ? FontAwesomeIcon.ExclamationTriangle |         var permIcon = (individualAnimDisabled || individualSoundsDisabled || individualVFXDisabled) ? FontAwesomeIcon.ExclamationTriangle | ||||||
|             : ((soundsDisabled || animDisabled || vfxDisabled) ? FontAwesomeIcon.InfoCircle : FontAwesomeIcon.None); |             : ((soundsDisabled || animDisabled || vfxDisabled) ? FontAwesomeIcon.InfoCircle : FontAwesomeIcon.None); | ||||||
|         var runningIconWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Running).X; |         var runningIconWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Running).X; | ||||||
|         var infoIconWidth = UiSharedService.GetIconSize(permIcon).X; |         var infoIconWidth = UiSharedService.GetIconSize(permIcon).X; | ||||||
|         var plusButtonWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Plus).X; |         var plusButtonWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Plus).X; | ||||||
|  |         var pauseButtonWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Plus).X; | ||||||
|  |  | ||||||
|         var barButtonWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Bars).X; |         var barButtonWidth = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Bars).X; | ||||||
|  |         var barButtonSize = _uiSharedService.GetIconButtonSize(FontAwesomeIcon.Bars); | ||||||
|  |  | ||||||
|  |         var windowEndX = ImGui.GetWindowContentRegionMin().X + UiSharedService.GetWindowContentRegionWidth(); | ||||||
|  |         var rightSidePos = windowEndX - barButtonSize.X; | ||||||
|  |  | ||||||
|  |  | ||||||
|         var pos = ImGui.GetWindowContentRegionMin().X + UiSharedService.GetWindowContentRegionWidth() + spacing |         var pos = ImGui.GetWindowContentRegionMin().X + UiSharedService.GetWindowContentRegionWidth() + spacing | ||||||
|             - (showShared ? (runningIconWidth + spacing) : 0) |             - (showShared ? (runningIconWidth + spacing) : 0) | ||||||
|             - (showInfo ? (infoIconWidth + spacing) : 0) |             - (showInfo ? (infoIconWidth + spacing) : 0) | ||||||
|             - (showPlus ? (plusButtonWidth + spacing) : 0) |             - (showPlus ? (plusButtonWidth + spacing) : 0) | ||||||
|  |             - (showPause ? (pauseButtonWidth + spacing) : 0) | ||||||
|             - (showBars ? (barButtonWidth + spacing) : 0); |             - (showBars ? (barButtonWidth + spacing) : 0); | ||||||
|  |  | ||||||
|         ImGui.SameLine(pos); |         ImGui.SameLine(pos); | ||||||
| @@ -264,6 +278,7 @@ public class DrawGroupPair : DrawPairBase | |||||||
|             ImGui.SameLine(); |             ImGui.SameLine(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|         if (showPlus) |         if (showPlus) | ||||||
|         { |         { | ||||||
|             ImGui.SetCursorPosY(originalY); |             ImGui.SetCursorPosY(originalY); | ||||||
| @@ -275,7 +290,24 @@ public class DrawGroupPair : DrawPairBase | |||||||
|             UiSharedService.AttachToolTip("Pair with " + entryUID + " individually"); |             UiSharedService.AttachToolTip("Pair with " + entryUID + " individually"); | ||||||
|             ImGui.SameLine(); |             ImGui.SameLine(); | ||||||
|         } |         } | ||||||
|  |         if (showPause) | ||||||
|  |         { | ||||||
|  |             //rightSidePos -= pauseIconSize.X + spacingX; | ||||||
|  |             ImGui.SetCursorPosY(originalY); | ||||||
|  |  | ||||||
|  |             if (_uiSharedService.IconButton(pauseIcon)) | ||||||
|  |             { | ||||||
|  |                 var perm = _fullInfoDto.GroupUserPermissions; | ||||||
|  |                 var newPaused = !perm.IsPaused(); | ||||||
|  |                 perm.SetPaused(newPaused); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             UiSharedService.AttachToolTip(!_fullInfoDto.GroupUserPermissions.IsPaused() | ||||||
|  |                 ? "Pause pairing with " + entryUID | ||||||
|  |                 : "Resume pairing with " + entryUID); | ||||||
|  |             ImGui.SameLine(); | ||||||
|  |  | ||||||
|  |         } | ||||||
|         if (showBars) |         if (showBars) | ||||||
|         { |         { | ||||||
|             ImGui.SetCursorPosY(originalY); |             ImGui.SetCursorPosY(originalY); | ||||||
| @@ -285,7 +317,6 @@ public class DrawGroupPair : DrawPairBase | |||||||
|                 ImGui.OpenPopup("Popup"); |                 ImGui.OpenPopup("Popup"); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (ImGui.BeginPopup("Popup")) |         if (ImGui.BeginPopup("Popup")) | ||||||
|         { |         { | ||||||
|             if ((userIsModerator || userIsOwner) && !(entryIsMod || entryIsOwner)) |             if ((userIsModerator || userIsOwner) && !(entryIsMod || entryIsOwner)) | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ public class DrawUserPair : DrawPairBase | |||||||
|     protected readonly MareMediator _mediator; |     protected readonly MareMediator _mediator; | ||||||
|     private readonly SelectGroupForPairUi _selectGroupForPairUi; |     private readonly SelectGroupForPairUi _selectGroupForPairUi; | ||||||
|     private readonly CharaDataManager _charaDataManager; |     private readonly CharaDataManager _charaDataManager; | ||||||
|  |     public long VramUsage { get; set; } | ||||||
|  |  | ||||||
|     public DrawUserPair(string id, Pair entry, UidDisplayHandler displayHandler, ApiController apiController, |     public DrawUserPair(string id, Pair entry, UidDisplayHandler displayHandler, ApiController apiController, | ||||||
|         MareMediator mareMediator, SelectGroupForPairUi selectGroupForPairUi, |         MareMediator mareMediator, SelectGroupForPairUi selectGroupForPairUi, | ||||||
| @@ -84,6 +85,7 @@ public class DrawUserPair : DrawPairBase | |||||||
|                 visibleTooltip += "Files Size: " + UiSharedService.ByteToString(_pair.LastAppliedDataBytes, true); |                 visibleTooltip += "Files Size: " + UiSharedService.ByteToString(_pair.LastAppliedDataBytes, true); | ||||||
|                 if (_pair.LastAppliedApproximateVRAMBytes >= 0) |                 if (_pair.LastAppliedApproximateVRAMBytes >= 0) | ||||||
|                 { |                 { | ||||||
|  |                     VramUsage = _pair.LastAppliedApproximateVRAMBytes; | ||||||
|                     visibleTooltip += Environment.NewLine + "Approx. VRAM Usage: " + UiSharedService.ByteToString(_pair.LastAppliedApproximateVRAMBytes, true); |                     visibleTooltip += Environment.NewLine + "Approx. VRAM Usage: " + UiSharedService.ByteToString(_pair.LastAppliedApproximateVRAMBytes, true); | ||||||
|                 } |                 } | ||||||
|                 if (_pair.LastAppliedDataTris >= 0) |                 if (_pair.LastAppliedDataTris >= 0) | ||||||
| @@ -97,6 +99,8 @@ public class DrawUserPair : DrawPairBase | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     protected override float DrawRightSide(float textPosY, float originalY) |     protected override float DrawRightSide(float textPosY, float originalY) | ||||||
|     { |     { | ||||||
|         var pauseIcon = _pair.UserPair!.OwnPermissions.IsPaused() ? FontAwesomeIcon.Play : FontAwesomeIcon.Pause; |         var pauseIcon = _pair.UserPair!.OwnPermissions.IsPaused() ? FontAwesomeIcon.Play : FontAwesomeIcon.Pause; | ||||||
|   | |||||||
| @@ -452,7 +452,16 @@ internal sealed class GroupPanel | |||||||
|             { |             { | ||||||
|                 ImGui.TextUnformatted("Visible"); |                 ImGui.TextUnformatted("Visible"); | ||||||
|                 ImGui.Separator(); |                 ImGui.Separator(); | ||||||
|  |                 if (_mareConfig.Current.SortSyncshellsByVRAM) | ||||||
|  |                 { | ||||||
|  |                     List<DrawGroupPair> sortedVisibleUsers = visibleUsers.OrderBy(o=>o.VramUsage).ToList(); | ||||||
|  |                     _uidDisplayHandler.RenderPairList(sortedVisibleUsers); | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|                     _uidDisplayHandler.RenderPairList(visibleUsers); |                     _uidDisplayHandler.RenderPairList(visibleUsers); | ||||||
|  |  | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (onlineUsers.Count > 0) |             if (onlineUsers.Count > 0) | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ using Dalamud.Interface.Colors; | |||||||
| using Dalamud.Interface.ImGuiFileDialog; | using Dalamud.Interface.ImGuiFileDialog; | ||||||
| using Dalamud.Interface.Textures.TextureWraps; | using Dalamud.Interface.Textures.TextureWraps; | ||||||
| using Dalamud.Interface.Utility; | using Dalamud.Interface.Utility; | ||||||
|  | using Dalamud.Utility; | ||||||
| using MareSynchronos.API.Data; | using MareSynchronos.API.Data; | ||||||
| using MareSynchronos.API.Dto.User; | using MareSynchronos.API.Dto.User; | ||||||
| using MareSynchronos.Services; | using MareSynchronos.Services; | ||||||
| @@ -28,14 +29,14 @@ public class EditProfileUi : WindowMediatorSubscriberBase | |||||||
|     private IDalamudTextureWrap? _pfpTextureWrap; |     private IDalamudTextureWrap? _pfpTextureWrap; | ||||||
|     private string _profileDescription = string.Empty; |     private string _profileDescription = string.Empty; | ||||||
|     private byte[] _profileImage = []; |     private byte[] _profileImage = []; | ||||||
|     private bool _showFileDialogError = false; |     private string _showFileDialogError = string.Empty; | ||||||
|     private bool _wasOpen; |     private bool _wasOpen; | ||||||
|  |  | ||||||
|     public EditProfileUi(ILogger<EditProfileUi> logger, MareMediator mediator, |     public EditProfileUi(ILogger<EditProfileUi> logger, MareMediator mediator, | ||||||
|         ApiController apiController, UiSharedService uiSharedService, FileDialogManager fileDialogManager, |         ApiController apiController, UiSharedService uiSharedService, FileDialogManager fileDialogManager, | ||||||
|         ServerConfigurationManager serverConfigurationManager, |         ServerConfigurationManager serverConfigurationManager, | ||||||
|         MareProfileManager mareProfileManager, PerformanceCollectorService performanceCollectorService) |         MareProfileManager mareProfileManager, PerformanceCollectorService performanceCollectorService) | ||||||
|         : base(logger, mediator, "Snowcloak Edit Profile###SnowcloakSyncEditProfileUI", performanceCollectorService) |         : base(logger, mediator, "Snowcloak Profile Editor###SnowcloakSyncEditProfileUI", performanceCollectorService) | ||||||
|     { |     { | ||||||
|         IsOpen = false; |         IsOpen = false; | ||||||
|         this.SizeConstraints = new() |         this.SizeConstraints = new() | ||||||
| @@ -92,20 +93,13 @@ public class EditProfileUi : WindowMediatorSubscriberBase | |||||||
|             ImGui.Image(_pfpTextureWrap.Handle, ImGuiHelpers.ScaledVector2(_pfpTextureWrap.Width, _pfpTextureWrap.Height)); |             ImGui.Image(_pfpTextureWrap.Handle, ImGuiHelpers.ScaledVector2(_pfpTextureWrap.Width, _pfpTextureWrap.Height)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         var spacing = ImGui.GetStyle().ItemSpacing.X; |         var spacing = ImGui.GetStyle().ItemSpacing.X + 200; | ||||||
|         ImGuiHelpers.ScaledRelativeSameLine(256, spacing); |         ImGuiHelpers.ScaledRelativeSameLine(256, spacing); | ||||||
|         using (_uiSharedService.GameFont.Push()) |         using (_uiSharedService.GameFont.Push()) | ||||||
|         { |         { | ||||||
|             var descriptionTextSize = ImGui.CalcTextSize(profile.Description, hideTextAfterDoubleHash: false, 256f); |             var descriptionTextSize = ImGui.CalcTextSize(profile.Description, hideTextAfterDoubleHash: false, 256f); | ||||||
|             var childFrame = ImGuiHelpers.ScaledVector2(256 + ImGui.GetStyle().WindowPadding.X + ImGui.GetStyle().WindowBorderSize, 256); |             var childFrame = ImGuiHelpers.ScaledVector2(256 + ImGui.GetStyle().WindowPadding.X + ImGui.GetStyle().WindowBorderSize, 256); | ||||||
|             if (descriptionTextSize.Y > childFrame.Y) |             _adjustedForScollBarsOnlineProfile = (descriptionTextSize.Y > childFrame.Y); | ||||||
|             { |  | ||||||
|                 _adjustedForScollBarsOnlineProfile = true; |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 _adjustedForScollBarsOnlineProfile = false; |  | ||||||
|             } |  | ||||||
|             childFrame = childFrame with |             childFrame = childFrame with | ||||||
|             { |             { | ||||||
|                 X = childFrame.X + (_adjustedForScollBarsOnlineProfile ? ImGui.GetStyle().ScrollbarSize : 0), |                 X = childFrame.X + (_adjustedForScollBarsOnlineProfile ? ImGui.GetStyle().ScrollbarSize : 0), | ||||||
| @@ -122,9 +116,18 @@ public class EditProfileUi : WindowMediatorSubscriberBase | |||||||
|         ImGui.Checkbox("Is NSFW", ref nsfw); |         ImGui.Checkbox("Is NSFW", ref nsfw); | ||||||
|         ImGui.EndDisabled(); |         ImGui.EndDisabled(); | ||||||
|  |  | ||||||
|  |         ImGui.Separator(); | ||||||
|  |         _uiSharedService.BigText("Rules and Guidelines"); | ||||||
|  |         UiSharedService.ColorTextWrapped("Users that are paired with you (not paused) will be able to see your profile picture and description.", ImGuiColors.DalamudWhite); | ||||||
|  |         UiSharedService.ColorTextWrapped("All users have the capability to report your profile if it violates the rules.", ImGuiColors.DalamudGrey); | ||||||
|  |         UiSharedService.ColorTextWrapped(" - Please do NOT upload anything that can be considered highly illegal or obscene (beastiality, sexual acts depicting minors or anything representing a minor (including Lalafel), etc.)", ImGuiColors.DalamudRed); | ||||||
|  |         UiSharedService.ColorTextWrapped(" - Please avoid the use of slurs, hate speech, threatening behaviour, etc.", ImGuiColors.DalamudRed); | ||||||
|  |         UiSharedService.ColorTextWrapped(" - In the event we receive a report of an offensive profile, we may disable your profile forever or terminate your Snowcloak service account.", ImGuiColors.DalamudRed); | ||||||
|  |         UiSharedService.ColorTextWrapped(" - You may not appeal any bans of your profile and or Snowcloak service account.", ImGuiColors.DalamudRed); | ||||||
|  |         UiSharedService.ColorTextWrapped("Users who wish to mark their profile as NSFW should enable the toggle below.", ImGuiColors.DalamudWhite); | ||||||
|         ImGui.Separator(); |         ImGui.Separator(); | ||||||
|         _uiSharedService.BigText("Profile Settings"); |         _uiSharedService.BigText("Profile Settings"); | ||||||
|  |         UiSharedService.ColorTextWrapped("Profile pictures must be cropped to 256x256px and have a file size of 250KiB or smaller.", ImGuiColors.DalamudGrey); | ||||||
|         if (_uiSharedService.IconTextButton(FontAwesomeIcon.FileUpload, "Upload new profile picture")) |         if (_uiSharedService.IconTextButton(FontAwesomeIcon.FileUpload, "Upload new profile picture")) | ||||||
|         { |         { | ||||||
|             _fileDialogManager.OpenFileDialog("Select new Profile picture", ".png", (success, file) => |             _fileDialogManager.OpenFileDialog("Select new Profile picture", ".png", (success, file) => | ||||||
| @@ -138,11 +141,10 @@ public class EditProfileUi : WindowMediatorSubscriberBase | |||||||
|  |  | ||||||
|                     if (format.Width > 256 || format.Height > 256 || (fileContent.Length > 250 * 1024)) |                     if (format.Width > 256 || format.Height > 256 || (fileContent.Length > 250 * 1024)) | ||||||
|                     { |                     { | ||||||
|                         _showFileDialogError = true; |                         _showFileDialogError = format.Width > 256 || format.Height > 256 ? "ERROR: Image dimensions must be 256x256px or smaller." : fileContent.Length > 250 * 1024 ? "ERROR: File size was bigger than 250KiB" : "ERROR: An unknown error has occured."; | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|  |                     _showFileDialogError = string.Empty; | ||||||
|                     _showFileDialogError = false; |  | ||||||
|                     await _apiController.UserSetProfile(new UserProfileDto(new UserData(_apiController.UID), Disabled: false, IsNSFW: null, Convert.ToBase64String(fileContent), Description: null)) |                     await _apiController.UserSetProfile(new UserProfileDto(new UserData(_apiController.UID), Disabled: false, IsNSFW: null, Convert.ToBase64String(fileContent), Description: null)) | ||||||
|                         .ConfigureAwait(false); |                         .ConfigureAwait(false); | ||||||
|                 }); |                 }); | ||||||
| @@ -155,9 +157,9 @@ public class EditProfileUi : WindowMediatorSubscriberBase | |||||||
|             _ = _apiController.UserSetProfile(new UserProfileDto(new UserData(_apiController.UID), Disabled: false, IsNSFW: null, "", Description: null)); |             _ = _apiController.UserSetProfile(new UserProfileDto(new UserData(_apiController.UID), Disabled: false, IsNSFW: null, "", Description: null)); | ||||||
|         } |         } | ||||||
|         UiSharedService.AttachToolTip("Clear your currently uploaded profile picture"); |         UiSharedService.AttachToolTip("Clear your currently uploaded profile picture"); | ||||||
|         if (_showFileDialogError) |         if (!_showFileDialogError.IsNullOrEmpty()) | ||||||
|         { |         { | ||||||
|             UiSharedService.ColorTextWrapped("The profile picture must be a PNG file with a maximum height and width of 256px and 250KiB size", ImGuiColors.DalamudRed); |             UiSharedService.ColorTextWrapped(_showFileDialogError, ImGuiColors.DalamudRed); | ||||||
|         } |         } | ||||||
|         var isNsfw = profile.IsNSFW; |         var isNsfw = profile.IsNSFW; | ||||||
|         if (ImGui.Checkbox("Profile is NSFW", ref isNsfw)) |         if (ImGui.Checkbox("Profile is NSFW", ref isNsfw)) | ||||||
|   | |||||||
| @@ -956,6 +956,7 @@ public class SettingsUi : WindowMediatorSubscriberBase | |||||||
|         _uiShared.BigText("UI"); |         _uiShared.BigText("UI"); | ||||||
|         var showCharacterNames = _configService.Current.ShowCharacterNames; |         var showCharacterNames = _configService.Current.ShowCharacterNames; | ||||||
|         var showVisibleSeparate = _configService.Current.ShowVisibleUsersSeparately; |         var showVisibleSeparate = _configService.Current.ShowVisibleUsersSeparately; | ||||||
|  |         var sortSyncshellByVRAM = _configService.Current.SortSyncshellsByVRAM; | ||||||
|         var showOfflineSeparate = _configService.Current.ShowOfflineUsersSeparately; |         var showOfflineSeparate = _configService.Current.ShowOfflineUsersSeparately; | ||||||
|         var showProfiles = _configService.Current.ProfilesShow; |         var showProfiles = _configService.Current.ProfilesShow; | ||||||
|         var showNsfwProfiles = _configService.Current.ProfilesAllowNsfw; |         var showNsfwProfiles = _configService.Current.ProfilesAllowNsfw; | ||||||
| @@ -1074,7 +1075,14 @@ public class SettingsUi : WindowMediatorSubscriberBase | |||||||
|             _configService.Save(); |             _configService.Save(); | ||||||
|         } |         } | ||||||
|         _uiShared.DrawHelpText("This will show all currently visible users in a special 'Visible' group in the main UI."); |         _uiShared.DrawHelpText("This will show all currently visible users in a special 'Visible' group in the main UI."); | ||||||
|  |         if (ImGui.Checkbox("Sort visible syncshell users by VRAM usage", ref sortSyncshellByVRAM)) | ||||||
|  |         { | ||||||
|  |             _configService.Current.SortSyncshellsByVRAM = sortSyncshellByVRAM; | ||||||
|  |             _logger.LogWarning("Changing value: {sortSyncshellsByVRAM}", sortSyncshellByVRAM); | ||||||
|  |  | ||||||
|  |             _configService.Save(); | ||||||
|  |         } | ||||||
|  |         _uiShared.DrawHelpText("This will put users using the most VRAM in a syncshell at the top of the list."); | ||||||
|         if (ImGui.Checkbox("Show separate Offline group", ref showOfflineSeparate)) |         if (ImGui.Checkbox("Show separate Offline group", ref showOfflineSeparate)) | ||||||
|         { |         { | ||||||
|             _configService.Current.ShowOfflineUsersSeparately = showOfflineSeparate; |             _configService.Current.ShowOfflineUsersSeparately = showOfflineSeparate; | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ public class PngHdr | |||||||
|  |  | ||||||
| 			stream.ReadExactly(buffer[..8]); | 			stream.ReadExactly(buffer[..8]); | ||||||
|  |  | ||||||
| 			uint ihdrLength = BitConverter.ToUInt32(buffer); | 			uint ihdrLength = ReadBigEndianUInt32(buffer[..4]); | ||||||
|  |  | ||||||
| 			// The next four bytes will be the length of the IHDR section (it should be 13 bytes but we only need 8) | 			// The next four bytes will be the length of the IHDR section (it should be 13 bytes but we only need 8) | ||||||
| 			if (ihdrLength < 8) | 			if (ihdrLength < 8) | ||||||
| @@ -32,8 +32,8 @@ public class PngHdr | |||||||
|  |  | ||||||
| 			stream.ReadExactly(buffer[..8]); | 			stream.ReadExactly(buffer[..8]); | ||||||
|  |  | ||||||
| 			uint width = BitConverter.ToUInt32(buffer); | 			uint width = ReadBigEndianUInt32(buffer[..4]); | ||||||
| 			uint height = BitConverter.ToUInt32(buffer[4..]); | 			uint height = ReadBigEndianUInt32(buffer[4..8]); | ||||||
|  |  | ||||||
| 			// Validate the width/height are non-negative and... that's all we care about! | 			// Validate the width/height are non-negative and... that's all we care about! | ||||||
| 			if (width > int.MaxValue || height > int.MaxValue) | 			if (width > int.MaxValue || height > int.MaxValue) | ||||||
| @@ -46,4 +46,12 @@ public class PngHdr | |||||||
| 			return InvalidSize; | 			return InvalidSize; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |     // Minimal helper for big-endian conversion | ||||||
|  |     private static uint ReadBigEndianUInt32(ReadOnlySpan<byte> bytes) | ||||||
|  |     { | ||||||
|  |         return ((uint)bytes[0] << 24) | | ||||||
|  |                ((uint)bytes[1] << 16) | | ||||||
|  |                ((uint)bytes[2] << 8) | | ||||||
|  |                bytes[3]; | ||||||
|  |     } | ||||||
| } | } | ||||||
| @@ -121,7 +121,7 @@ public sealed partial class ApiController : DisposableMediatorSubscriberBase, IM | |||||||
|         { |         { | ||||||
|             Logger.LogWarning("Multiple secret keys for current character"); |             Logger.LogWarning("Multiple secret keys for current character"); | ||||||
|             _connectionDto = null; |             _connectionDto = null; | ||||||
|             Mediator.Publish(new NotificationMessage("Multiple Identical Characters detected", "Your Service configuration has multiple characters with the same name and world set up. Delete the duplicates in the character management to be able to connect to Mare.", |             Mediator.Publish(new NotificationMessage("Multiple Identical Characters detected", "Your Service configuration has multiple characters with the same name and world set up. Delete the duplicates in the character management to be able to connect.", | ||||||
|                 NotificationType.Error)); |                 NotificationType.Error)); | ||||||
|             await StopConnection(ServerState.MultiChara).ConfigureAwait(false); |             await StopConnection(ServerState.MultiChara).ConfigureAwait(false); | ||||||
|             _connectionCancellationTokenSource?.Cancel(); |             _connectionCancellationTokenSource?.Cancel(); | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								MareSynchronos/images/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								MareSynchronos/images/logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 68 KiB | 
| @@ -10,9 +10,9 @@ | |||||||
|       }, |       }, | ||||||
|       "DalamudPackager": { |       "DalamudPackager": { | ||||||
|         "type": "Direct", |         "type": "Direct", | ||||||
|         "requested": "[13.0.0, )", |         "requested": "[13.1.0, )", | ||||||
|         "resolved": "13.0.0", |         "resolved": "13.1.0", | ||||||
|         "contentHash": "Mb3cUDSK/vDPQ8gQIeuCw03EMYrej1B4J44a1AvIJ9C759p9XeqdU9Hg4WgOmlnlPe0G7ILTD32PKSUpkQNa8w==" |         "contentHash": "XdoNhJGyFby5M/sdcRhnc5xTop9PHy+H50PTWpzLhJugjB19EDBiHD/AsiDF66RETM+0qKUdJBZrNuebn7qswQ==" | ||||||
|       }, |       }, | ||||||
|       "DotNet.ReproducibleBuilds": { |       "DotNet.ReproducibleBuilds": { | ||||||
|         "type": "Direct", |         "type": "Direct", | ||||||
| @@ -22,11 +22,11 @@ | |||||||
|       }, |       }, | ||||||
|       "Downloader": { |       "Downloader": { | ||||||
|         "type": "Direct", |         "type": "Direct", | ||||||
|         "requested": "[3.3.4, )", |         "requested": "[4.0.3, )", | ||||||
|         "resolved": "3.3.4", |         "resolved": "4.0.3", | ||||||
|         "contentHash": "/M/c80e1L0WW1XrLSSiQhgFxk8rrfbpWiWDn2CeBg1tPD393Neo+v184yG/ThyhE9rrNp36yCrugiCmEbRf+VQ==", |         "contentHash": "Vg1+UqPDstpMw2CKXV9XvB8jKHC95KQfbqPxQXvOMRMFnTov4Ixvvw6GZV5DXLnKuL2sfnmVYX9CaQtcURia1Q==", | ||||||
|         "dependencies": { |         "dependencies": { | ||||||
|           "Microsoft.Extensions.Logging.Abstractions": "8.0.1" |           "Microsoft.Extensions.Logging.Abstractions": "8.0.3" | ||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|       "Glamourer.Api": { |       "Glamourer.Api": { | ||||||
| @@ -55,11 +55,28 @@ | |||||||
|           "System.IO.Pipelines": "6.0.3" |           "System.IO.Pipelines": "6.0.3" | ||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|  |       "MessagePack": { | ||||||
|  |         "type": "Direct", | ||||||
|  |         "requested": "[3.1.4, )", | ||||||
|  |         "resolved": "3.1.4", | ||||||
|  |         "contentHash": "BH0wlHWmVoZpbAPyyt2Awbq30C+ZsS3eHSkYdnyUAbqVJ22fAJDzn2xTieBeoT5QlcBzp61vHcv878YJGfi3mg==", | ||||||
|  |         "dependencies": { | ||||||
|  |           "MessagePack.Annotations": "3.1.4", | ||||||
|  |           "MessagePackAnalyzer": "3.1.4", | ||||||
|  |           "Microsoft.NET.StringTools": "17.11.4" | ||||||
|  |         } | ||||||
|  |       }, | ||||||
|  |       "MessagePack.Annotations": { | ||||||
|  |         "type": "Direct", | ||||||
|  |         "requested": "[3.1.4, )", | ||||||
|  |         "resolved": "3.1.4", | ||||||
|  |         "contentHash": "aVWrDAkCdqxwQsz/q0ldPh2EFn48M99YUzE9OvZjMq2RNLKz4o2z88iGFvSvbMqOWRweRvKPHBJZe22PRqzslQ==" | ||||||
|  |       }, | ||||||
|       "Meziantou.Analyzer": { |       "Meziantou.Analyzer": { | ||||||
|         "type": "Direct", |         "type": "Direct", | ||||||
|         "requested": "[2.0.212, )", |         "requested": "[2.0.213, )", | ||||||
|         "resolved": "2.0.212", |         "resolved": "2.0.213", | ||||||
|         "contentHash": "U91ktjjTRTccUs3Lk+hrLD9vW+2+lhnsOf4G1GpRSJi1pLn3uK5CU6wGP9Bmz1KlJs6Oz1GGoMhxQBoqQsmAuQ==" |         "contentHash": "LHnFGBqhlBjbf8Uo4OIzGM0llRxFrIMuo/hP9oHq+aldS+28G4LqG12LK0co9b+S0yj1Vbf0rclDHN0Ji2DTkA==" | ||||||
|       }, |       }, | ||||||
|       "Microsoft.AspNetCore.SignalR.Client": { |       "Microsoft.AspNetCore.SignalR.Client": { | ||||||
|         "type": "Direct", |         "type": "Direct", | ||||||
| @@ -133,6 +150,12 @@ | |||||||
|           "Microsoft.IdentityModel.Tokens": "8.14.0" |           "Microsoft.IdentityModel.Tokens": "8.14.0" | ||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|  |       "System.IO.Pipelines": { | ||||||
|  |         "type": "Direct", | ||||||
|  |         "requested": "[9.0.8, )", | ||||||
|  |         "resolved": "9.0.8", | ||||||
|  |         "contentHash": "6vPmJt73mgUo1gzc/OcXlJvClz/2jxZ4TQPRfriVaLoGRH2mye530D9WHJYbFQRNMxF3PWCoeofsFdCyN7fLzA==" | ||||||
|  |       }, | ||||||
|       "K4os.Compression.LZ4": { |       "K4os.Compression.LZ4": { | ||||||
|         "type": "Transitive", |         "type": "Transitive", | ||||||
|         "resolved": "1.3.8", |         "resolved": "1.3.8", | ||||||
| @@ -143,19 +166,10 @@ | |||||||
|         "resolved": "1.0.8", |         "resolved": "1.0.8", | ||||||
|         "contentHash": "Wp2F7BamQ2Q/7Hk834nV9vRQapgcr8kgv9Jvfm8J3D0IhDqZMMl+a2yxUq5ltJitvXvQfB8W6K4F4fCbw/P6YQ==" |         "contentHash": "Wp2F7BamQ2Q/7Hk834nV9vRQapgcr8kgv9Jvfm8J3D0IhDqZMMl+a2yxUq5ltJitvXvQfB8W6K4F4fCbw/P6YQ==" | ||||||
|       }, |       }, | ||||||
|       "MessagePack": { |       "MessagePackAnalyzer": { | ||||||
|         "type": "Transitive", |         "type": "Transitive", | ||||||
|         "resolved": "2.5.187", |         "resolved": "3.1.4", | ||||||
|         "contentHash": "uW4j8m4Nc+2Mk5n6arOChavJ9bLjkis0qWASOj2h2OwmfINuzYv+mjCHUymrYhmyyKTu3N+ObtTXAY4uQ7jIhg==", |         "contentHash": "CTaSsN/liJ7MhLCAB7Z4ZLBNuVGCq9lt2BT/cbrc9vzGv89yK3CqIA+z9T19a11eQYl9etZHL6MQJgCqECRVpg==" | ||||||
|         "dependencies": { |  | ||||||
|           "MessagePack.Annotations": "2.5.187", |  | ||||||
|           "Microsoft.NET.StringTools": "17.6.3" |  | ||||||
|         } |  | ||||||
|       }, |  | ||||||
|       "MessagePack.Annotations": { |  | ||||||
|         "type": "Transitive", |  | ||||||
|         "resolved": "2.5.198", |  | ||||||
|         "contentHash": "3U9OvqQGTra+Mz1k1zfNAScSdNHobnqtQ51qdMGUZppkNDZJl0X/igq6Qz5zDBLEZoYqZrFtZwFx6wBJHHI8BA==" |  | ||||||
|       }, |       }, | ||||||
|       "Microsoft.AspNetCore.Connections.Abstractions": { |       "Microsoft.AspNetCore.Connections.Abstractions": { | ||||||
|         "type": "Transitive", |         "type": "Transitive", | ||||||
| @@ -499,19 +513,14 @@ | |||||||
|       }, |       }, | ||||||
|       "Microsoft.NET.StringTools": { |       "Microsoft.NET.StringTools": { | ||||||
|         "type": "Transitive", |         "type": "Transitive", | ||||||
|         "resolved": "17.6.3", |         "resolved": "17.11.4", | ||||||
|         "contentHash": "N0ZIanl1QCgvUumEL1laasU0a7sOE5ZwLZVTn0pAePnfhq8P7SvTjF8Axq+CnavuQkmdQpGNXQ1efZtu5kDFbA==" |         "contentHash": "mudqUHhNpeqIdJoUx2YDWZO/I9uEDYVowan89R6wsomfnUJQk6HteoQTlNjZDixhT2B4IXMkMtgZtoceIjLRmA==" | ||||||
|       }, |       }, | ||||||
|       "System.Diagnostics.EventLog": { |       "System.Diagnostics.EventLog": { | ||||||
|         "type": "Transitive", |         "type": "Transitive", | ||||||
|         "resolved": "9.0.8", |         "resolved": "9.0.8", | ||||||
|         "contentHash": "gebRF3JLLJ76jz1CQpvwezNapZUjFq20JQsaGHzBH0DzlkHBLpdhwkOei9usiOkIGMwU/L0ALWpNe1JE+5/itw==" |         "contentHash": "gebRF3JLLJ76jz1CQpvwezNapZUjFq20JQsaGHzBH0DzlkHBLpdhwkOei9usiOkIGMwU/L0ALWpNe1JE+5/itw==" | ||||||
|       }, |       }, | ||||||
|       "System.IO.Pipelines": { |  | ||||||
|         "type": "Transitive", |  | ||||||
|         "resolved": "6.0.3", |  | ||||||
|         "contentHash": "ryTgF+iFkpGZY1vRQhfCzX0xTdlV3pyaTTqRu2ETbEv+HlV7O6y7hyQURnghNIXvctl5DuZ//Dpks6HdL/Txgw==" |  | ||||||
|       }, |  | ||||||
|       "System.Net.ServerSentEvents": { |       "System.Net.ServerSentEvents": { | ||||||
|         "type": "Transitive", |         "type": "Transitive", | ||||||
|         "resolved": "9.0.8", |         "resolved": "9.0.8", | ||||||
| @@ -525,7 +534,7 @@ | |||||||
|       "maresynchronos.api": { |       "maresynchronos.api": { | ||||||
|         "type": "Project", |         "type": "Project", | ||||||
|         "dependencies": { |         "dependencies": { | ||||||
|           "MessagePack.Annotations": "[2.5.198, )" |           "MessagePack.Annotations": "[2.5.129, )" | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user