diff --git a/Application/IW4MServer.cs b/Application/IW4MServer.cs index 7e2265336..6dfcd4f02 100644 --- a/Application/IW4MServer.cs +++ b/Application/IW4MServer.cs @@ -1304,7 +1304,7 @@ await this.SetDvarAsync("sv_sayname", Manager.GetApplicationSettings().Configura this.MaxClients = maxplayers; this.FSGame = game.Value; this.Gametype = gametype; - this.IP = ip.Value == "localhost" ? ServerConfig.IPAddress : ip.Value ?? ServerConfig.IPAddress; + this.IP = ip.Value is "localhost" or "0.0.0.0" ? ServerConfig.IPAddress : ip.Value ?? ServerConfig.IPAddress; this.GamePassword = gamePassword.Value; UpdateMap(mapname); diff --git a/Application/Misc/ScriptPlugin.cs b/Application/Misc/ScriptPlugin.cs index 5a19c4d58..964d0e951 100644 --- a/Application/Misc/ScriptPlugin.cs +++ b/Application/Misc/ScriptPlugin.cs @@ -112,6 +112,7 @@ public async Task Initialize(IManager manager, IScriptCommandFactory scriptComma } } + _scriptEngine?.Dispose(); _scriptEngine = new Engine(cfg => cfg.AddExtensionMethods(typeof(Utilities), typeof(Enumerable), typeof(Queryable), typeof(ScriptPluginExtensions)) @@ -247,9 +248,12 @@ public async Task OnEventAsync(GameEvent gameEvent, Server server) return; } + var shouldRelease = false; + try { await _onProcessing.WaitAsync(); + shouldRelease = true; WrapJavaScriptErrorHandling(() => { _scriptEngine.SetValue("_gameEvent", gameEvent); @@ -260,7 +264,7 @@ public async Task OnEventAsync(GameEvent gameEvent, Server server) } finally { - if (_onProcessing.CurrentCount == 0) + if (_onProcessing.CurrentCount == 0 && shouldRelease) { _onProcessing.Release(1); } @@ -268,7 +272,7 @@ public async Task OnEventAsync(GameEvent gameEvent, Server server) } - public Task OnLoadAsync(IManager manager) + public Task OnLoadAsync(IManager manager) { _logger.LogDebug("OnLoad executing for {Name}", Name); @@ -320,11 +324,14 @@ public async Task OnUnloadAsync() public T ExecuteAction(Delegate action, CancellationToken token, params object[] param) { + var shouldRelease = false; + try { using var forceTimeout = new CancellationTokenSource(5000); using var combined = CancellationTokenSource.CreateLinkedTokenSource(forceTimeout.Token, token); _onProcessing.Wait(combined.Token); + shouldRelease = true; _logger.LogDebug("Executing action for {Name}", Name); @@ -343,7 +350,7 @@ public T ExecuteAction(Delegate action, CancellationToken token, params objec } finally { - if (_onProcessing.CurrentCount == 0) + if (_onProcessing.CurrentCount == 0 && shouldRelease) { _onProcessing.Release(1); } @@ -352,11 +359,14 @@ public T ExecuteAction(Delegate action, CancellationToken token, params objec public T WrapDelegate(Delegate act, CancellationToken token, params object[] args) { + var shouldRelease = false; + try { using var forceTimeout = new CancellationTokenSource(5000); using var combined = CancellationTokenSource.CreateLinkedTokenSource(forceTimeout.Token, token); _onProcessing.Wait(combined.Token); + shouldRelease = true; _logger.LogDebug("Wrapping delegate action for {Name}", Name); @@ -373,7 +383,7 @@ public T WrapDelegate(Delegate act, CancellationToken token, params object[] } finally { - if (_onProcessing.CurrentCount == 0) + if (_onProcessing.CurrentCount == 0 && shouldRelease) { _onProcessing.Release(1); }