1dc0f5a240
refactor some of the main application code to have a cleaner code flow add enviroment flag to opt out of .net core telemetry in start script fixed "a moment" missing the "ago" fixed case sensitive client searches on postgresql clean up command code flow Add missing map "mp_cairo" to default settings
136 lines
4.4 KiB
C#
136 lines
4.4 KiB
C#
using SharedLibraryCore.Database.Models;
|
|
using SharedLibraryCore.Interfaces;
|
|
using System;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace SharedLibraryCore
|
|
{
|
|
class ScriptPlugin : IPlugin
|
|
{
|
|
public string Name { get; set; }
|
|
|
|
public float Version { get; set; }
|
|
|
|
public string Author { get; set; }
|
|
|
|
private Jint.Engine ScriptEngine;
|
|
private readonly string FileName;
|
|
private IManager Manager;
|
|
|
|
public ScriptPlugin(string fileName)
|
|
{
|
|
FileName = fileName;
|
|
var watcher = new FileSystemWatcher()
|
|
{
|
|
Path = $"{Utilities.OperatingDirectory}Plugins{Path.DirectorySeparatorChar}",
|
|
NotifyFilter = NotifyFilters.Size,
|
|
Filter = fileName.Split(Path.DirectorySeparatorChar).Last()
|
|
};
|
|
|
|
watcher.Changed += Watcher_Changed;
|
|
watcher.EnableRaisingEvents = true;
|
|
}
|
|
|
|
private async void Watcher_Changed(object sender, FileSystemEventArgs e)
|
|
{
|
|
try
|
|
{
|
|
await Initialize(Manager);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
Manager.GetLogger(0).WriteError(Utilities.CurrentLocalization.LocalizationIndex["PLUGIN_IMPORTER_ERROR"].FormatExt(Name));
|
|
Manager.GetLogger(0).WriteDebug(ex.Message);
|
|
}
|
|
}
|
|
|
|
public async Task Initialize(IManager mgr)
|
|
{
|
|
bool firstRun = ScriptEngine == null;
|
|
// it's been loaded before so we need to call the unload event
|
|
if (!firstRun)
|
|
{
|
|
await OnUnloadAsync();
|
|
}
|
|
|
|
Manager = mgr;
|
|
string script;
|
|
|
|
using (var stream = new FileStream(FileName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
|
|
{
|
|
using (var reader = new StreamReader(stream, Encoding.Default))
|
|
{
|
|
script = await reader.ReadToEndAsync();
|
|
}
|
|
}
|
|
|
|
ScriptEngine = new Jint.Engine(cfg =>
|
|
cfg.AllowClr(new[]
|
|
{
|
|
typeof(System.Net.Http.HttpClient).Assembly,
|
|
typeof(EFClient).Assembly,
|
|
})
|
|
.CatchClrExceptions());
|
|
|
|
ScriptEngine.Execute(script);
|
|
ScriptEngine.SetValue("_localization", Utilities.CurrentLocalization);
|
|
dynamic pluginObject = ScriptEngine.GetValue("plugin").ToObject();
|
|
|
|
this.Author = pluginObject.author;
|
|
this.Name = pluginObject.name;
|
|
this.Version = (float)pluginObject.version;
|
|
|
|
|
|
try
|
|
{
|
|
if (pluginObject.isParser)
|
|
{
|
|
await OnLoadAsync(mgr);
|
|
IEventParser eventParser = (IEventParser)ScriptEngine.GetValue("eventParser").ToObject();
|
|
IRConParser rconParser = (IRConParser)ScriptEngine.GetValue("rconParser").ToObject();
|
|
Manager.AdditionalEventParsers.Add(eventParser);
|
|
Manager.AdditionalRConParsers.Add(rconParser);
|
|
}
|
|
}
|
|
catch { }
|
|
|
|
|
|
if (!firstRun)
|
|
{
|
|
await OnLoadAsync(mgr);
|
|
}
|
|
}
|
|
|
|
public Task OnEventAsync(GameEvent E, Server S)
|
|
{
|
|
lock (ScriptEngine)
|
|
{
|
|
ScriptEngine.SetValue("_gameEvent", E);
|
|
ScriptEngine.SetValue("_server", S);
|
|
ScriptEngine.SetValue("_IW4MAdminClient", Utilities.IW4MAdminClient(S));
|
|
return Task.FromResult(ScriptEngine.Execute("plugin.onEventAsync(_gameEvent, _server)").GetCompletionValue());
|
|
}
|
|
}
|
|
|
|
public Task OnLoadAsync(IManager manager)
|
|
{
|
|
ScriptEngine.SetValue("_manager", manager);
|
|
return Task.FromResult(ScriptEngine.Execute("plugin.onLoadAsync(_manager)").GetCompletionValue());
|
|
}
|
|
|
|
public Task OnTickAsync(Server S)
|
|
{
|
|
ScriptEngine.SetValue("_server", S);
|
|
return Task.FromResult(ScriptEngine.Execute("plugin.onTickAsync(_server)").GetCompletionValue());
|
|
}
|
|
|
|
public Task OnUnloadAsync()
|
|
{
|
|
return Task.FromResult(ScriptEngine.Execute("plugin.onUnloadAsync()").GetCompletionValue());
|
|
}
|
|
}
|
|
}
|