diff --git a/Content.Server/Administration/Commands/ChangeCvarCommand.cs b/Content.Server/Administration/Commands/ChangeCvarCommand.cs
new file mode 100644
index 0000000000..984c9c1077
--- /dev/null
+++ b/Content.Server/Administration/Commands/ChangeCvarCommand.cs
@@ -0,0 +1,215 @@
+using System.Linq;
+using Content.Server.Administration.Logs;
+using Content.Server.Administration.Managers;
+using Content.Shared.Administration;
+using Content.Shared.Database;
+using Robust.Shared.Configuration;
+using Robust.Shared.Console;
+
+namespace Content.Server.Administration.Commands;
+
+///
+/// Allows admins to change certain CVars. This is different than the "cvar" command which is host only and can change any CVar.
+///
+///
+/// Possible todo for future, store default values for cvars, and allow resetting to default.
+///
+[AnyCommand]
+public sealed class ChangeCvarCommand : IConsoleCommand
+{
+ [Dependency] private readonly IConfigurationManager _configurationManager = default!;
+ [Dependency] private readonly IAdminLogManager _adminLogManager = default!;
+ [Dependency] private readonly CVarControlManager _cVarControlManager = default!;
+
+ ///
+ /// Searches the list of cvars for a cvar that matches the search string.
+ ///
+ private void SearchCVars(IConsoleShell shell, string argStr, string[] args)
+ {
+ if (args.Length < 2)
+ {
+ shell.WriteLine(Loc.GetString("cmd-changecvar-search-no-arguments"));
+ return;
+ }
+
+ var cvars = _cVarControlManager.GetAllRunnableCvars(shell);
+
+ var matches = cvars
+ .Where(c =>
+ c.Name.Contains(args[1], StringComparison.OrdinalIgnoreCase)
+ || c.ShortHelp?.Contains(args[1], StringComparison.OrdinalIgnoreCase) == true
+ || c.LongHelp?.Contains(args[1], StringComparison.OrdinalIgnoreCase) == true
+ ) // Might be very slow and stupid, but eh.
+ .ToList();
+
+ if (matches.Count == 0)
+ {
+ shell.WriteLine(Loc.GetString("cmd-changecvar-search-no-matches"));
+ return;
+ }
+
+ shell.WriteLine(Loc.GetString("cmd-changecvar-search-matches", ("count", matches.Count)));
+ shell.WriteLine(string.Join("\n", matches.Select(FormatCVarFullHelp)));
+ }
+
+ ///
+ /// Formats a CVar into a string for display.
+ ///
+ private string FormatCVarFullHelp(ChangableCVar cvar)
+ {
+ if (cvar.LongHelp != null && cvar.ShortHelp != null)
+ {
+ return $"{cvar.Name} - {cvar.LongHelp}";
+ }
+
+ // There is no help, no one is coming. We are all doomed.
+ return cvar.Name;
+ }
+
+ public string Command => "changecvar";
+ public string Description { get; } = Loc.GetString("cmd-changecvar-desc");
+ public string Help { get; } = Loc.GetString("cmd-changecvar-help");
+ public void Execute(IConsoleShell shell, string argStr, string[] args)
+ {
+ if (args.Length == 0)
+ {
+ shell.WriteLine(Loc.GetString("cmd-changecvar-no-arguments"));
+ return;
+ }
+
+ var cvars = _cVarControlManager.GetAllRunnableCvars(shell);
+
+ var cvar = args[0];
+ if (cvar == "?")
+ {
+ if (cvars.Count == 0)
+ {
+ shell.WriteLine(Loc.GetString("cmd-changecvar-no-cvars"));
+ return;
+ }
+
+ shell.WriteLine(Loc.GetString("cmd-changecvar-available-cvars"));
+ shell.WriteLine(string.Join("\n", cvars.Select(FormatCVarFullHelp)));
+ return;
+ }
+
+ if (cvar == "search")
+ {
+ SearchCVars(shell, argStr, args);
+ return;
+ }
+
+ if (!_configurationManager.IsCVarRegistered(cvar)) // Might be a redunat check with the if statement below.
+ {
+ shell.WriteLine(Loc.GetString("cmd-changecvar-cvar-not-registered", ("cvar", cvar)));
+ return;
+ }
+
+ if (cvars.All(c => c.Name != cvar))
+ {
+ shell.WriteLine(Loc.GetString("cmd-changecvar-cvar-not-allowed"));
+ return;
+ }
+
+ if (args.Length == 1)
+ {
+ var value = _configurationManager.GetCVar