From 4fe8d3d509a8c8daa91d14569e5ef5b0d856a261 Mon Sep 17 00:00:00 2001 From: Andrey Ushakov <10843461+Werzet@users.noreply.github.com> Date: Sun, 17 Dec 2023 23:25:50 +1000 Subject: [PATCH] remove spawn access for mentors (#592) --- .../Administration/Systems/AdminVerbSystem.cs | 72 ++++++++++--------- 1 file changed, 39 insertions(+), 33 deletions(-) diff --git a/Content.Server/Administration/Systems/AdminVerbSystem.cs b/Content.Server/Administration/Systems/AdminVerbSystem.cs index 136ce22dac29..dff1dfb33172 100644 --- a/Content.Server/Administration/Systems/AdminVerbSystem.cs +++ b/Content.Server/Administration/Systems/AdminVerbSystem.cs @@ -136,7 +136,7 @@ private void AddAdminVerbs(GetVerbsEvent args) ? Loc.GetString("admin-verbs-unfreeze") : Loc.GetString("admin-verbs-freeze"), Category = VerbCategory.Admin, - Icon = new SpriteSpecifier.Texture(new ("/Textures/Interface/VerbIcons/snow.svg.192dpi.png")), + Icon = new SpriteSpecifier.Texture(new("/Textures/Interface/VerbIcons/snow.svg.192dpi.png")), Act = () => { if (frozen) @@ -165,49 +165,55 @@ private void AddAdminVerbs(GetVerbsEvent args) }); } - // Respawn - args.Verbs.Add(new Verb() + // Respawn + if (_adminManager.HasAdminFlag(player, AdminFlags.Ban)) // SS220 Mentor buttons restrict { - Text = Loc.GetString("admin-player-actions-respawn"), - Category = VerbCategory.Admin, - Act = () => + args.Verbs.Add(new Verb() { - _console.ExecuteCommand(player, $"respawn {targetActor.PlayerSession.Name}"); - }, - ConfirmationPopup = true, - // No logimpact as the command does it internally. - }); + Text = Loc.GetString("admin-player-actions-respawn"), + Category = VerbCategory.Admin, + Act = () => + { + _console.ExecuteCommand(player, $"respawn {targetActor.PlayerSession.Name}"); + }, + ConfirmationPopup = true, + // No logimpact as the command does it internally. + }); + } // Spawn - Like respawn but on the spot. - args.Verbs.Add(new Verb() + if (_adminManager.HasAdminFlag(player, AdminFlags.Ban)) // SS220 Mentor buttons restrict { - Text = Loc.GetString("admin-player-actions-spawn"), - Category = VerbCategory.Admin, - Act = () => + args.Verbs.Add(new Verb() { - if (!_transformSystem.TryGetMapOrGridCoordinates(args.Target, out var coords)) + Text = Loc.GetString("admin-player-actions-spawn"), + Category = VerbCategory.Admin, + Act = () => { - _popup.PopupEntity(Loc.GetString("admin-player-spawn-failed"), args.User, args.User); - return; - } + if (!_transformSystem.TryGetMapOrGridCoordinates(args.Target, out var coords)) + { + _popup.PopupEntity(Loc.GetString("admin-player-spawn-failed"), args.User, args.User); + return; + } - var stationUid = _stations.GetOwningStation(args.Target); + var stationUid = _stations.GetOwningStation(args.Target); - var profile = _ticker.GetPlayerProfile(targetActor.PlayerSession); - var mobUid = _spawning.SpawnPlayerMob(coords.Value, null, profile, stationUid); - var targetMind = _mindSystem.GetMind(args.Target); + var profile = _ticker.GetPlayerProfile(targetActor.PlayerSession); + var mobUid = _spawning.SpawnPlayerMob(coords.Value, null, profile, stationUid); + var targetMind = _mindSystem.GetMind(args.Target); - if (targetMind != null) - { - _mindSystem.TransferTo(targetMind.Value, mobUid); - } - }, - ConfirmationPopup = true, - Impact = LogImpact.High, - }); + if (targetMind != null) + { + _mindSystem.TransferTo(targetMind.Value, mobUid); + } + }, + ConfirmationPopup = true, + Impact = LogImpact.High, + }); + } // Clone - Spawn but without the mind transfer, also spawns at the user's coordinates not the target's - if (_adminManager.HasAdminFlag(player, AdminFlags.Ban)) + if (_adminManager.HasAdminFlag(player, AdminFlags.Ban)) // SS220 Mentor buttons restrict { args.Verbs.Add(new Verb() { @@ -233,7 +239,7 @@ private void AddAdminVerbs(GetVerbsEvent args) } // Admin Logs - if (_adminManager.HasAdminFlag(player, AdminFlags.Logs)) // SS220 Mentor buttons restrict + if (_adminManager.HasAdminFlag(player, AdminFlags.Logs)) { Verb logsVerbEntity = new() {