|
9 | 9 | using Sandbox.Game.Entities; |
10 | 10 | using Sandbox.Game.Entities.Cube; |
11 | 11 | using Sandbox.Game.Replication; |
| 12 | + using Sandbox.Game.Replication.StateGroups; |
12 | 13 | using Sandbox.Game.World; |
13 | 14 | using Sandbox.ModAPI; |
14 | 15 | using Settings; |
@@ -99,81 +100,81 @@ public override bool Handle( ulong remoteUserId, CallSite site, BitStream stream |
99 | 100 | return false; |
100 | 101 | } |
101 | 102 |
|
102 | | - bool found = false; |
103 | | - foreach ( ProtectedItem item in PluginSettings.Instance.ProtectedItems ) |
104 | | - { |
105 | | - if ( !item.Enabled ) |
106 | | - continue; |
107 | | - |
108 | | - if ( item.EntityId != grid.EntityId ) |
109 | | - continue; |
110 | | - |
111 | | - if ( !item.ProtectionSettingsDict.Dictionary.ContainsKey( ProtectedItem.ProtectionModeEnum.BlockSettings ) ) |
112 | | - continue; |
113 | | - |
114 | | - ProtectedItem.ProtectionSettings settings = item.ProtectionSettingsDict[ProtectedItem.ProtectionModeEnum.BlockSettings]; |
115 | | - |
116 | | - if ( Protection.Instance.CheckPlayerExempt( settings, grid, remoteUserId ) ) |
117 | | - continue; |
118 | | - |
119 | | - if ( item.LogOnly ) |
120 | | - { |
121 | | - Essentials.Log.Info( $"Recieved block settings change request from user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )}:{remoteUserId} for block {entity.CustomName} on grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
122 | | - continue; |
123 | | - } |
124 | | - |
125 | | - if ( !string.IsNullOrEmpty( settings.PrivateWarningMessage ) ) |
126 | | - Communication.Notification( remoteUserId, MyFontEnum.Red, 5000, settings.PrivateWarningMessage ); |
127 | | - |
128 | | - if ( !string.IsNullOrEmpty( settings.PublicWarningMessage ) ) |
129 | | - Communication.SendPublicInformation( settings.PublicWarningMessage.Replace( "%player%", PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId ) ) ); |
130 | | - |
131 | | - if ( settings.BroadcastGPS ) |
132 | | - { |
133 | | - MyPlayer player = MySession.Static.Players.GetPlayerById( new MyPlayer.PlayerId( remoteUserId, 0 ) ); |
134 | | - Vector3D pos = player.GetPosition( ); |
135 | | - MyAPIGateway.Utilities.SendMessage( $"GPS:{player.DisplayName}:{pos.X}:{pos.Y}:{pos.Z}:" ); |
136 | | - } |
137 | | - |
138 | | - Essentials.Log.Info($"Intercepted block settings change request from user {PlayerMap.Instance.GetFastPlayerNameFromSteamId(remoteUserId)}:{remoteUserId} for block {entity.CustomName} on grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
139 | | - |
140 | | - switch ( settings.PunishmentType ) |
141 | | - { |
142 | | - case ProtectedItem.PunishmentEnum.Kick: |
143 | | - _kickTimer.Elapsed += ( sender, e ) => |
144 | | - { |
145 | | - Essentials.Log.Info( $"Kicked user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )}:{remoteUserId} for changing block settings on protected grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
146 | | - MyMultiplayer.Static.KickClient( remoteUserId ); |
147 | | - }; |
148 | | - _kickTimer.AutoReset = false; |
149 | | - _kickTimer.Start( ); |
150 | | - break; |
151 | | - case ProtectedItem.PunishmentEnum.Ban: |
152 | | - _kickTimer.Elapsed += ( sender, e ) => |
153 | | - { |
154 | | - Essentials.Log.Info( $"Banned user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )}:{remoteUserId} for changing block settings on protected grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
155 | | - MyMultiplayer.Static.BanClient( remoteUserId, true ); |
156 | | - }; |
157 | | - _kickTimer.AutoReset = false; |
158 | | - _kickTimer.Start( ); |
159 | | - break; |
160 | | - case ProtectedItem.PunishmentEnum.Speed: |
161 | | - Task.Run( ( ) => |
162 | | - { |
163 | | - lock ( ProcessSpeed.SpeedPlayers ) |
164 | | - { |
165 | | - long playerId = PlayerMap.Instance.GetFastPlayerIdFromSteamId( remoteUserId ); |
166 | | - ProcessSpeed.SpeedPlayers[playerId] = new Tuple<float, DateTime>( (float)settings.SpeedLimit, DateTime.Now + TimeSpan.FromMinutes( settings.SpeedTime ) ); |
167 | | - } |
168 | | - } ); |
169 | | - Essentials.Log.Info( $"Limited user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )} to {settings.SpeedLimit}m/s for {settings.SpeedTime} minutes" ); |
170 | | - break; |
171 | | - } |
172 | | - |
173 | | - found = true; |
174 | | - } |
175 | | - |
176 | | - return found; |
| 103 | + //bool found = false; |
| 104 | + //foreach ( ProtectedItem item in PluginSettings.Instance.ProtectedItems ) |
| 105 | + //{ |
| 106 | + // if ( !item.Enabled ) |
| 107 | + // continue; |
| 108 | + |
| 109 | + // if ( item.EntityId != grid.EntityId ) |
| 110 | + // continue; |
| 111 | + |
| 112 | + // if ( !item.ProtectionSettingsDict.Dictionary.ContainsKey( ProtectedItem.ProtectionModeEnum.BlockSettings ) ) |
| 113 | + // continue; |
| 114 | + |
| 115 | + // ProtectedItem.ProtectionSettings settings = item.ProtectionSettingsDict[ProtectedItem.ProtectionModeEnum.BlockSettings]; |
| 116 | + |
| 117 | + // if ( Protection.Instance.CheckPlayerExempt( settings, grid, remoteUserId ) ) |
| 118 | + // continue; |
| 119 | + |
| 120 | + // if ( item.LogOnly ) |
| 121 | + // { |
| 122 | + // Essentials.Log.Info( $"Recieved block settings change request from user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )}:{remoteUserId} for block {entity.CustomName} on grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
| 123 | + // continue; |
| 124 | + // } |
| 125 | + |
| 126 | + // if ( !string.IsNullOrEmpty( settings.PrivateWarningMessage ) ) |
| 127 | + // Communication.Notification( remoteUserId, MyFontEnum.Red, 5000, settings.PrivateWarningMessage ); |
| 128 | + |
| 129 | + // if ( !string.IsNullOrEmpty( settings.PublicWarningMessage ) ) |
| 130 | + // Communication.SendPublicInformation( settings.PublicWarningMessage.Replace( "%player%", PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId ) ) ); |
| 131 | + |
| 132 | + // if ( settings.BroadcastGPS ) |
| 133 | + // { |
| 134 | + // MyPlayer player = MySession.Static.Players.GetPlayerById( new MyPlayer.PlayerId( remoteUserId, 0 ) ); |
| 135 | + // Vector3D pos = player.GetPosition( ); |
| 136 | + // MyAPIGateway.Utilities.SendMessage( $"GPS:{player.DisplayName}:{pos.X}:{pos.Y}:{pos.Z}:" ); |
| 137 | + // } |
| 138 | + |
| 139 | + // Essentials.Log.Info($"Intercepted block settings change request from user {PlayerMap.Instance.GetFastPlayerNameFromSteamId(remoteUserId)}:{remoteUserId} for block {entity.CustomName} on grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
| 140 | + |
| 141 | + // switch ( settings.PunishmentType ) |
| 142 | + // { |
| 143 | + // case ProtectedItem.PunishmentEnum.Kick: |
| 144 | + // _kickTimer.Elapsed += ( sender, e ) => |
| 145 | + // { |
| 146 | + // Essentials.Log.Info( $"Kicked user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )}:{remoteUserId} for changing block settings on protected grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
| 147 | + // MyMultiplayer.Static.KickClient( remoteUserId ); |
| 148 | + // }; |
| 149 | + // _kickTimer.AutoReset = false; |
| 150 | + // _kickTimer.Start( ); |
| 151 | + // break; |
| 152 | + // case ProtectedItem.PunishmentEnum.Ban: |
| 153 | + // _kickTimer.Elapsed += ( sender, e ) => |
| 154 | + // { |
| 155 | + // Essentials.Log.Info( $"Banned user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )}:{remoteUserId} for changing block settings on protected grid {grid.DisplayNameText ?? "ID"}:{item.EntityId}" ); |
| 156 | + // MyMultiplayer.Static.BanClient( remoteUserId, true ); |
| 157 | + // }; |
| 158 | + // _kickTimer.AutoReset = false; |
| 159 | + // _kickTimer.Start( ); |
| 160 | + // break; |
| 161 | + // case ProtectedItem.PunishmentEnum.Speed: |
| 162 | + // Task.Run( ( ) => |
| 163 | + // { |
| 164 | + // lock ( ProcessSpeed.SpeedPlayers ) |
| 165 | + // { |
| 166 | + // long playerId = PlayerMap.Instance.GetFastPlayerIdFromSteamId( remoteUserId ); |
| 167 | + // ProcessSpeed.SpeedPlayers[playerId] = new Tuple<float, DateTime>( (float)settings.SpeedLimit, DateTime.Now + TimeSpan.FromMinutes( settings.SpeedTime ) ); |
| 168 | + // } |
| 169 | + // } ); |
| 170 | + // Essentials.Log.Info( $"Limited user {PlayerMap.Instance.GetFastPlayerNameFromSteamId( remoteUserId )} to {settings.SpeedLimit}m/s for {settings.SpeedTime} minutes" ); |
| 171 | + // break; |
| 172 | + // } |
| 173 | + |
| 174 | + // found = true; |
| 175 | + //} |
| 176 | + |
| 177 | + //return found; |
177 | 178 | } |
178 | 179 | } |
179 | 180 | } |
0 commit comments