From 751e1a107195f0c9c98c866e8267a5a760545982 Mon Sep 17 00:00:00 2001 From: vnugent Date: Thu, 12 Jan 2023 17:47:41 -0500 Subject: Large project reorder and consolidation --- .../SessionProvider/src/SessionClientEntryPoint.cs | 158 +++++++++++++++++++++ 1 file changed, 158 insertions(+) create mode 100644 plugins/SessionProvider/src/SessionClientEntryPoint.cs (limited to 'plugins/SessionProvider/src/SessionClientEntryPoint.cs') diff --git a/plugins/SessionProvider/src/SessionClientEntryPoint.cs b/plugins/SessionProvider/src/SessionClientEntryPoint.cs new file mode 100644 index 0000000..ae3d166 --- /dev/null +++ b/plugins/SessionProvider/src/SessionClientEntryPoint.cs @@ -0,0 +1,158 @@ +/* +* Copyright (c) 2022 Vaughn Nugent +* +* Library: VNLib +* Package: SessionProvider +* File: SessionClientEntryPoint.cs +* +* SessionClientEntryPoint.cs is part of SessionProvider which is part of the larger +* VNLib collection of libraries and utilities. +* +* SessionProvider is free software: you can redistribute it and/or modify +* it under the terms of the GNU Affero General Public License as +* published by the Free Software Foundation, either version 3 of the +* License, or (at your option) any later version. +* +* SessionProvider is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +* GNU Affero General Public License for more details. +* +* You should have received a copy of the GNU Affero General Public License +* along with this program. If not, see https://www.gnu.org/licenses/. +*/ + +using System; +using System.IO; +using System.Linq; +using System.Threading; +using System.Threading.Tasks; +using System.Collections.Generic; + +using VNLib.Utils.Logging; +using VNLib.Utils.Extensions; +using VNLib.Net.Http; +using VNLib.Plugins.Extensions.Loading; + +namespace VNLib.Plugins.Essentials.Sessions +{ + /// + /// The implementation type for dynamic loading of unified session providers + /// + public sealed class SessionClientEntryPoint : PluginBase, ISessionProvider + { + /// + public override string PluginName => "Essentials.Sessions"; + + private RuntimeSessionProvider[] ProviderArray = Array.Empty(); + + + ValueTask ISessionProvider.GetSessionAsync(IHttpEvent entity, CancellationToken token) + { + //Loop through providers + for (int i = 0; i < ProviderArray.Length; i++) + { + //Check if provider can process the entity + if (ProviderArray[i].CanProcess(entity)) + { + //Get session + return ProviderArray[i].GetSessionAsync(entity, token); + } + } + + //Return empty session + return new ValueTask(SessionHandle.Empty); + } + + protected override void OnLoad() + { + List providers = new(); + + try + { + Log.Verbose("Loading all specified session providers"); + + //Get all provider names + IEnumerable providerAssemblyNames = PluginConfig.GetProperty("provider_assemblies") + .EnumerateArray() + .Where(s => s.GetString() != null) + .Select(s => s.GetString()!); + + + + foreach(string asm in providerAssemblyNames) + { + Log.Verbose("Loading {dll} session provider", asm); + + //Attempt to load provider + AssemblyLoader prov = this.LoadAssembly(asm); + + try + { + //Create localized log + LocalizedLogProvider log = new(Log, $"{Path.GetFileName(asm)}"); + + RuntimeSessionProvider p = new(prov); + + //Call load method + p.Load(this, log); + + //Add to list + providers.Add(p); + } + catch + { + prov.Dispose(); + throw; + } + } + + if(providers.Count > 0) + { + //Create array for searching for providers + ProviderArray = providers.ToArray(); + + Log.Information("Loaded {count} session providers", ProviderArray.Length); + } + else + { + Log.Information("No session providers loaded"); + } + + Log.Information("Plugin loaded"); + } + catch (KeyNotFoundException knf) + { + //Dispose providers + providers.ForEach(static s => s.Dispose()); + + Log.Warn("Plugin configuration was missing required variables {var}", knf.Message); + } + catch + { + //Dispose providers + providers.ForEach(static s => s.Dispose()); + throw; + } + } + + protected override void OnUnLoad() + { + //Cleanup assemblies + ProviderArray.TryForeach(static p => p.Dispose()); + + //Clear array + ProviderArray = Array.Empty(); + + Log.Information("Plugin unloaded"); + } + + protected override void ProcessHostCommand(string cmd) + { + if (!this.IsDebug()) + { + return; + } + } + } +} -- cgit